2018年MathorCup数学建模A题矿相特征迁移规律研究解题全过程文档及程序
2018年第八届MathorCup高校数学建模挑战赛
A题 矿相特征迁移规律研究
原题再现:
背景材料:
球团矿具有含铁品位高、粒度均匀、还原性能好、机械强度高、微气孔多等特性, 是高炉炼铁的重要原料之一。近年来国内外普遍认识到球团矿高温状态下冶金性能是评价炉料质量的重要指标, 而球团矿冶金性能 ( N碱度” 是一个重要指标) 与其微观结构密切相关。基于球团矿冶金性能决定其微观结构, 微观结构反映其冶金性能的角度出发, 探索球团矿不同位置的矿相特征, 并建立矿相特征与碱度之间的关系, 对球团矿实际生产有重要的指导意义。
如图 1 所示, 球团矿不同的微观结构, 对应着不同碱度, 碱度与结构之间存在的关联有待研究。

图 1 所示的不同碱度下的球团矿微观结构呈现了较为明显的视觉差异,造成差异的主要原因为球团矿中不同元素的大小和分布差异,这些元素主要有: [ 铝] ,[ 钙] , [ 碳] , [ 铁] , [ 镁] , [ 氧] , [ 硅] 。这些元素的大小和分布特征是影响其碱度的关键因素。SEM 电镜分析: 获取球团矿微观矿相, 将每一个球团矿样品进行切片磨光,在电镜下获取其中心部位、四分之一部位和边缘部位的矿相, 即每个样品获取三张原始矿相。电镜分析还能对每张矿相进行元素着色标记, 标记的元素有铝含量[ A1 ] 、钙含量[ Ca ] 、碳含量[ C ] 、铁含量[ Fe ] 、镁含量[ Mg ] 、氧含量[ o] 、硅含量[ Si ] , 获取碱度为 0 .6 的一个样品的所有电镜图像有 24 张, 见表 1 , 表 1 中每列是相互对应的,即第一行第一列为中心部位电镜原始图像,第二行第一列为中心部位[ A1 ] 元素的着色标记, 依次类推。

正题:
附件 1~ 附件 4 分别给出了碱度为 0 .6、0 .8、1 .0、1 .2 情况下的球团微观矿相, 基于附件中给定的内容, 解决如下三个问题(推荐用 MAmLAB 软件处理图像):
问题 1: 应用图像图形处理算法, 研究附件 1~ 附件 4 中的球团矿相, 试提取所有矿相的视觉特征(如: 表征不同元素或物质颗粒大小的边缘、面积等特征, 表征不同元素或物质分布的密度、聚集区域等特征, 表征矿相复杂性的分形、纹理等特征, 不局限于上述特征)。
问题 2: 纵向研究同一部位(均为中心部位或均为四分之一部位或均为边缘部位) 的矿相在四种碱度下各种特征的变化梯度。试提取可以表征球团矿碱度的矿相主特征, 并实现基于该主特征的碱度判别。(碱度判别指对碱度的类别识别, 实质是分类)。
问题 3:横向研究同一碱度(均为 0 .6 的碱度或均为 0 .8 的碱度或均为 1 .0的碱度或均为 1 .2 的碱度) 的矿相在三种部位下各种特征的变化梯度。试提取可以表征球团矿部位的矿相主特征, 并实现基于该主特征的部位判别。( 部位判别指对部位的类别识别, 实质也是分类)。
问题 4: 基于问题 1 至问题 3 的研究, 试判别附件 5 中给定的 24 张球团矿相的碱度类别和部位类别。需要说明的是附件 5 中的 24 张矿相来源于一个球团矿样品, 碱度类别的判别结果为一个值 (0 .6 或 0 .8 或 1 .0 或 1 .2 )。
问题 5: 完成一篇给球团矿生产者的操作说明 (简明扼要的写出实现问题 4的操作步骤, 带截图, 字数少于 1000 , 页数不限), 并将该操作说明与其相关的文件放入一个文件夹内打包作为支撑材料提交。
整体求解过程概述(摘要)
本文主要针对球团矿矿相特征迁移规律进行研究,首先采用图像图形处理算法提取矿相的视觉特征,其次通过横向比较和纵向分析分别建立碱度与矿相微观结构、部位与矿相微观结构的矿相碱度判别模型和矿相部位综合判别模型,最后基于上述模型确定附件 5 中球团矿相的碱度和部位类别。
针对问题一,首先我们用 MATLAB 提取附件 1~附件 4 中所有球团矿相的灰度图像,再应用图像分割算法分离出电镜扫描图像中矿相微观结构孔隙的二值图和矿相元素颗粒分布的二值图。随后根据分割出图像的几何特征和分布特征,我们提出矿相孔隙平均直径(MA)、孔隙比(PO)、孔隙分形维数(Dim)、矿相元素聚集区域分形维数(Dimbox)、聚集体延展方向发散度(StdD)、聚集体发散方向均匀度(StdU)、矿相元素格子均值(NorM)、矿相元素格子分布均匀度(NorS)八种特征参数用于表征矿相电镜扫描图像的视觉特征。
针对问题二,为研究矿相同一部位在不同碱度下各种特征的变化梯度,结合问题一中提出的表征电镜扫描图像的八种特征参数,我们选取中心部位矿相微观结构图和矿相元素分布图在各个碱度下的参数值。首先用单调模型判断各元素的各个参数与碱度增加的相关性,计算单调相关系数;其次结合单调相关系数采用改进的多元回归拟合各组参数与碱度变化的相关系数,权重系数绝对值越大对应的参数对碱度变化贡献越大。剔除系数较小即对碱度变化不明显的参数系数即得到同一部位影响碱度变化的主特征参数,最后根据保留的参数建立碱度判别判据。同时,在 1/4 部位和边缘部位使用判别模型结果显示其准确程度为 87.5%。
针对问题三,首先用聚类分析将所有球团矿相聚为两类,即矿相微观结构图和各矿相元素分布图。其次在问题一确定的八种特征参数的基础上,以 0.6 碱度
为例,研究矿相微观结构图和各矿相元素分布图八种特征参数随部位的化关系。研究结果显示,对于矿相微观结果图,主特征参数 MA、PO、StdD 与部位变化有明显的规律,对于各矿相元素分布图,主特征参数 StdD、StdU、NorM 与部位变化具有明显的规律。最后根据以上规律,建立了球团矿相部位综合判别模型,同时基于该判别模型,也可实现其他三种碱度矿相的部位判别。
针对问题四,首先采用问题一的方法,根据图像图形处理算法,提取附件 5中矿相微观结构图的主特征参数 MA、PO、StdD 以及各矿相元素分布图的主特征参数 StdD、StdU、NorM,然后分别将上述主特征参数代入问题三建立的球团矿相部位综合判别模型,实现球团矿相部位判别。最后后提取同一部位的特征参数,代入问题二建立的矿相碱度判别模型,实现球团矿相碱度判别。
针对问题五,根据问题一至问题四提取球团矿相特征参数,建立矿相部位综合判别模型和矿相碱度判别模型的步骤,完成一篇给球团矿生产者的操作说明。基于该操作说明,可实现对球团矿矿相的部位判别和碱度判别。
模型假设:
1、假设矿相电镜扫描图像不同部位的特征参数受碱度影响的趋势一致,即任意部位特征参数随碱度变化的趋势同样适用于其它部位。
2、假设矿相电镜扫描图像任意碱度下不同部位的特征参数变化趋势同样适用于其它碱度。
3、假设附件中的图片均能代表不同碱度和不同部位的主要视觉特征。
4、假设图片分割算法对特征参数提取影响很小,可以忽略不计。
问题分析:
问题 1 的分析
首先我们需要通过 MATLAB 提取附件 1~附件 4 中所有球团矿相的灰度图像,再应用图像分割算法分离出电镜扫描图像中矿相微观结构孔隙的二值图和矿相元素颗粒分布的二值图。随后根据分割出图像的几何特征和分布特征,我们提出了矿相孔隙平均直径(MA)、孔隙比(PO)、孔隙分形维数(Dim)、矿相元素聚集区域分形维数(Dimbox)、聚集体延展方向发散度(StdD)、聚集体发散方向均匀度(StdU)、矿相元素格子均值(NorM)、矿相元素格子分布均匀度(NorS)八个指标表征矿相电镜扫描图像的视觉特征。
问题 2 的分析
纵向研究同一部位的矿相在四种碱度下各种特征的变化梯度,试提取可以表征球团矿碱度的矿相主特征,并实现基于该主特征的碱度判别。为研究同一部位的矿相碱度下各种特征的变化梯度,结合问题一中提出的表征电镜扫描图像的八个参数,我们用 matlab 计算中心部位微观结构图和元素分布图在各个碱度下的参数值。建立判别模型前我们先用单调模型判断各元素的各个参数与碱度变化的相关性,即提取出随着碱度单调变化参数也发生单调变化的参数;随后我们可以利用多元线性回归拟合各组参数与碱度的系数,系数绝对值越大对应的参数对碱度变化就越明显。剔除系数较小即对碱度变化不明显的参数系数即得到同一部位影响碱度变化的主特征参数,并根据保留的参数建立碱度判别判据。同时,为了验证我们提出的判据,我们将其它部位在多个碱度的参数信息代入测试其准确程度。
问题 3 的分析
问题三需要研究同一碱度的的矿相在三个部位的变化梯度。需要结合问题一中的确定的八种特征指标进行分析,首先运用聚类分析将各种矿相分为不同的两个部分。然后在两类矿相的基础上研究八个特征参数随部位变化的关系,进而分析八种特征参数的变化规律,最后从中提取出矿相主特征并实现部位判别。
问题 4 的分析
首先我们将附件 5 中未知碱度和部位类别的 24 张球团矿相,采用
问题 1 中的图像图形处理算法对其进行分析,从而得到矿相微观结构图的主特征参数 MA、PO、StdD,将其代入问题 3 建立的对应于矿相微观结构图的“球团矿相部位综合判别模型”,实现矿相微观结构图的部位判别。接着将得到的各元素矿相分布图的主特征参数 StdD、StdU、NorM,代入对应于矿相元素分布图的的“球团矿相部位综合判别模型”,实现矿相元素分布图的部位判别;最后对已实现部位判别的球团矿,提取同一部位的特征参数,代入问题 2 建立的“矿相碱度判别模型”,实现球团矿相碱度判别。并对另两个部位也进行碱度判别,检验此碱度的准确性。
模型的建立与求解整体论文缩略图

全部论文请见下方“ 只会建模 QQ名片” 点击QQ名片即可
程序代码:(代码和文档not free)
The actual procedure is shown in the screenshot
model_conv = torchvision.models.resnet18(pretrained=True)
for param in model_conv.parameters():param.requires_grad = False #特征层中参数都固定住,不会发生梯度的更新;# Parameters of newly constructed modules have requires_grad=True by default
num_ftrs = model_conv.fc.in_features
model_conv.fc = nn.Linear(num_ftrs, 2)model_conv = model_conv.to(device)criterion = nn.CrossEntropyLoss()# Observe that only parameters of final layer are being optimized as
# opposed to before.
optimizer_conv = optim.SGD(model_conv.fc.parameters(), lr=0.001, momentum=0.9) #定义一个优化器,这个优化器的作用是优化全连接层中的参数# Decay LR by a factor of 0.1 every 7 epochs
exp_lr_scheduler = lr_scheduler.StepLR(optimizer_conv, step_size=7, gamma=0.1)
全部论文请见下方“ 只会建模 QQ名片” 点击QQ名片即可
相关文章:
2018年MathorCup数学建模A题矿相特征迁移规律研究解题全过程文档及程序
2018年第八届MathorCup高校数学建模挑战赛 A题 矿相特征迁移规律研究 原题再现: 背景材料: 球团矿具有含铁品位高、粒度均匀、还原性能好、机械强度高、微气孔多等特性, 是高炉炼铁的重要原料之一。近年来国内外普遍认识到球团矿高温状态下冶金性能是评价炉料…...
如何在 Python 中创建对象列表
Python 中要创建对象列表: 声明一个新变量并将其初始化为一个空列表。使用 for 循环迭代范围对象。实例化一个类以在每次迭代时创建一个对象。将每个对象附加到列表中。 class Employee():def __init__(self, id):self.id idlist_of_objects []for i in range(5…...
Canny算法原理和应用
Canny算法的原理使用高斯滤波器滤波使用 Sobel 滤波器滤波获得在 x 和 y 方向上的输出,在此基础上求出梯度的强度和梯度的角度edge为边缘强度,tan为梯度方向上图表示的是中心点的梯度向量、方位角以及边缘方向(任一点的边缘与梯度向量正交&am…...
数据挖掘(2.2)--数据预处理
目录 二、数据描述 1.描述数据中心趋势 1.1平均值和截断均值 1.2加权平均值 1.3中位数(Median)和众数(Mode) 2.描述数据的分散程度 2.1箱线图 2.2方差和标准差 2.3正态分布 3.数据清洗 3.1数据缺失的处理 3.2数据清洗 二、数据描述 描述数…...
JVM堆与堆调优以及出现OOM如何排查
调优的位置——堆 Heap,一个JVM只有一个堆内存,堆内存的大小是可以调节的。 类加载器读取了类文件后,一般会把什么东西放到堆中?类,方法,常量,变量~,保存我们所有引用类型的真实对象; 堆内存中…...
Springboot——自定义Filter使用测试总结
文章目录前言自定义过滤器并验证关于排除某些请求的方式创建测试接口请求测试验证异常过滤器的执行流程注意事项资料参考前言 在Java-web的开发领域,对于过滤器和拦截器用处还是很多,但两者的概念却极易混淆。 过滤器和拦截器都是采用AOP的核心思想&am…...
软件测试(进阶篇)(1)
一)如何根据需求来设计测试用例? 1)验证功能的正确性,合理性,无二义性,逻辑要正确 2)分析需求,细化需求,从需求中提取出测试项,根据测试项找到测试点,根据测试点具体的来进行设计测试…...
(七十三)大白话深入探索多表关联的SQL语句到底是如何执行的?(1)
今天我们来继续跟大家聊聊多表关联语句是如何执行的这个问题,上次讲了一个最最基础的两个表关联的语句和执行过程,其实今天我们稍微来复习一下,然后接着上次的内容,引入一个“内连接”的概念来。 假设我们有一个员工表࿰…...
SYSU程设c++(第三周) 对象类、类的成员、类与结构体的区别、类的静态成员
对象&类 类用于指定对象的形式,它包含数据的表示方法和用于处理数据的方法。 • 类中的数据和方法称为类的成员。 • 函数在一个类中也被称为类的成员。 定义一个类,其效果是定义一个数据类型的蓝图。它定义了类的对象包括了什么,以及可…...
Redis管道
目录 1、什么是管道? 2、案例演示 3、注意事项 4、面试题 1、什么是管道? 管道(pipeline)可以一次性发送多条命令给服务端,服务端依次处理完,通过一条响应一次性将结果返回,减少 IO 的次数&…...
conda的共用package[硬链接]@pytorch和tensorflow装在同一个环境里好不好?
文章目录refpackage复用(指定同版本)conda install 比pip install 更可能节省空间pytorch和tensorflow装在同一个环境里?导入依赖导入依赖试验ref python - Can packages be shared across Anaconda environments? - Stack OverflowManaging environments — conda 23.1.0.p…...
「Vue面试题」动态给vue的data添加一个新的属性时会发生什么?怎样去解决的?
一、直接添加属性的问题 我们从一个例子开始 定义一个p标签,通过v-for指令进行遍历 然后给botton标签绑定点击事件,我们预期点击按钮时,数据新增一个属性,界面也 新增一行 <p v-for"(value,key) in item" :key&q…...
Flutter-Scaffold组件
在Flutter开发当中,我们可能会遇到以下的需求:实现页面组合使用,比如说有悬浮按钮、顶部菜单栏、左右抽屉侧边栏、底部导航栏等等效果。Scaffold组件可以帮我们实现上面需求说的效果。这篇博客主要分享容器组件的Scaffold组件的使用ÿ…...
Postman简介及接口测试流程(小菜鸟攻略)
目录 前言 一、常见接口 二、前端和后端 三、什么是接口测试 四、接口组成 1、接口说明 2、调用url 3、请求方法(get\post) 4、请求参数、参数类型、请求参数说明 5、返回参数说明 五、为什么要做接口测试 本章主要介绍如何使用postman做接口…...
kubebuilder注释
标记语法Empty kubebuilder:validation:Optional:空标记像命令行中的布尔标记位-- 仅仅是指定他们来开启某些行为。Anonymous kubebuilder:validation:MaxItems2:匿名标记使用单个值作为参数。Multioption kubebuilder:printcolumn:JSONPath".statu…...
java日志
日志是软件开发的重要组成部分。一个精心编写的日志代码提供快速的调试,维护方便,以及应用程序的运行时信息结构化存储。日志记录确实也有它的缺点。它可以减缓的应用程序Log4jLog4j是Apache的一个开放源代码项目,通过使用Log4j,我…...
研发中台拆分过程的一些心得总结
背景在 21 年,中台拆分在 21 年,以下为中台拆分的过程心得,带有一定的主观,偏向于中小团队中台建设参考(这里的中小团队指 3-100 人的团队),对于大型团队不太适用,毕竟大型团队人中 …...
HTTP介绍
HTTP1、简介HTTP概念:HyperText Transfer Protocol,超文本传输协议,规定了浏览器和服务器之间数据传输的规则。数据传输的规则指的是请求数据和响应数据需要按照指定的格式进行传输。如果想知道具体的格式,可以打开浏览器…...
10 卷积神经网络及python实现
1 卷积神经网络简介 卷积神经网络(Convolutional Neural Network, CNN)由LeCun在上世纪90年代提出。 LeCun Y., Bottou L., Bengio Y., and Haffner P., Gradient-based learning applied to document recognition, Proceedings of the IEEE, pp. 1-7, 1998. 卷积核和特征图&…...
【立体匹配论文阅读】AANet: Adaptive Aggregation Network for Efficient Stereo Matching
Authors: Haofei Xu, Juyong Zhang Link: https://arxiv.org/abs/2004.09548 Years: 2020 Credit Novelty and Question set up 主流的立体匹配模型的代价聚合操作主要用了3D卷积,这部分操作的算力和内存消耗过大,因此作者提出一种新的模型AANet&#x…...
Linux 文件类型,目录与路径,文件与目录管理
文件类型 后面的字符表示文件类型标志 普通文件:-(纯文本文件,二进制文件,数据格式文件) 如文本文件、图片、程序文件等。 目录文件:d(directory) 用来存放其他文件或子目录。 设备…...
.Net框架,除了EF还有很多很多......
文章目录 1. 引言2. Dapper2.1 概述与设计原理2.2 核心功能与代码示例基本查询多映射查询存储过程调用 2.3 性能优化原理2.4 适用场景 3. NHibernate3.1 概述与架构设计3.2 映射配置示例Fluent映射XML映射 3.3 查询示例HQL查询Criteria APILINQ提供程序 3.4 高级特性3.5 适用场…...
中南大学无人机智能体的全面评估!BEDI:用于评估无人机上具身智能体的综合性基准测试
作者:Mingning Guo, Mengwei Wu, Jiarun He, Shaoxian Li, Haifeng Li, Chao Tao单位:中南大学地球科学与信息物理学院论文标题:BEDI: A Comprehensive Benchmark for Evaluating Embodied Agents on UAVs论文链接:https://arxiv.…...
Java如何权衡是使用无序的数组还是有序的数组
在 Java 中,选择有序数组还是无序数组取决于具体场景的性能需求与操作特点。以下是关键权衡因素及决策指南: ⚖️ 核心权衡维度 维度有序数组无序数组查询性能二分查找 O(log n) ✅线性扫描 O(n) ❌插入/删除需移位维护顺序 O(n) ❌直接操作尾部 O(1) ✅内存开销与无序数组相…...
无法与IP建立连接,未能下载VSCode服务器
如题,在远程连接服务器的时候突然遇到了这个提示。 查阅了一圈,发现是VSCode版本自动更新惹的祸!!! 在VSCode的帮助->关于这里发现前几天VSCode自动更新了,我的版本号变成了1.100.3 才导致了远程连接出…...
智能分布式爬虫的数据处理流水线优化:基于深度强化学习的数据质量控制
在数字化浪潮席卷全球的今天,数据已成为企业和研究机构的核心资产。智能分布式爬虫作为高效的数据采集工具,在大规模数据获取中发挥着关键作用。然而,传统的数据处理流水线在面对复杂多变的网络环境和海量异构数据时,常出现数据质…...
有限自动机到正规文法转换器v1.0
1 项目简介 这是一个功能强大的有限自动机(Finite Automaton, FA)到正规文法(Regular Grammar)转换器,它配备了一个直观且完整的图形用户界面,使用户能够轻松地进行操作和观察。该程序基于编译原理中的经典…...
SQL慢可能是触发了ring buffer
简介 最近在进行 postgresql 性能排查的时候,发现 PG 在某一个时间并行执行的 SQL 变得特别慢。最后通过监控监观察到并行发起得时间 buffers_alloc 就急速上升,且低水位伴随在整个慢 SQL,一直是 buferIO 的等待事件,此时也没有其他会话的争抢。SQL 虽然不是高效 SQL ,但…...
Qemu arm操作系统开发环境
使用qemu虚拟arm硬件比较合适。 步骤如下: 安装qemu apt install qemu-system安装aarch64-none-elf-gcc 需要手动下载,下载地址:https://developer.arm.com/-/media/Files/downloads/gnu/13.2.rel1/binrel/arm-gnu-toolchain-13.2.rel1-x…...
Kubernetes 网络模型深度解析:Pod IP 与 Service 的负载均衡机制,Service到底是什么?
Pod IP 的本质与特性 Pod IP 的定位 纯端点地址:Pod IP 是分配给 Pod 网络命名空间的真实 IP 地址(如 10.244.1.2)无特殊名称:在 Kubernetes 中,它通常被称为 “Pod IP” 或 “容器 IP”生命周期:与 Pod …...
