当前位置: 首页 > article >正文

2023第十二届“认证杯”数学中国数学建模国际赛赛题A完整解析

A题完整题解

  • 写在前面
    • 假设
      • 数据预处理
    • 问题一
    • 1 基于自适应ARIMA-BP神经网络模型的影响因素预测
      • 1.1 ARIMA模型的建立
      • 1.2 BP神经网络模型的建立
      • 1.3 基于GABP神经网络的预测模型构建
      • 1.4 自适应混合ARIMA-BP神经网络模型的建立
      • 1.5 模型求解
    • 代码
      • Q1_1.m
      • Q1_2.m
  • 完整代码与论文获取

写在前面

发布赛题一直到现在,总算完成了认证杯A题完整的解题过程,包括代码完整代码与结果、解题思路、模型文档与论文框架~

学姐的代码和论文框架保证原创,保证高质量哦,都是跟国奖学长一起努力完成的!!

假设

数据预处理

磁场数据中包含缺失值,故需对缺失值进行插补。在本文中,利用拟合模型对缺失值的进行插补。基于拟合的插补方法的一般步骤如下:
1、收集已有数据:首先,需要收集包含缺失数据的数据集。确保数据集中有足够的样本和特征来进行非线性拟合。
2、建立模型:选择适当的模型来拟合已有数据。常见的非线性模型包括多项式回归、指数函数、对数函数、幂函数等。根据数据的特点和领域知识,选择合适的模型。
3、拟合已有数据:使用已有数据来拟合选定的非线性模型。可以使用回归分析等方法来估计模型的参数。
4、预测缺失数据:使用拟合好的非线性模型来预测缺失数据的值。将已有数据中的特征值代入模型,得到对应的预测值。
在这里插入图片描述

其次,题目中要求以月份为单位对数值进行统计,而原始数据集的统计单位时日。故对日期进行转换,得到以月为单位的序列图如下所示:
在这里插入图片描述

问题一

1 基于自适应ARIMA-BP神经网络模型的影响因素预测

在本章中,基于自适应ARIMA-BP神经网络模型对数据进行预测。

1.1 ARIMA模型的建立

在这里插入图片描述

1.2 BP神经网络模型的建立

BP神经网络是是一种多层前馈算法,由输入层、隐含层和输出层组成。层与层之间有工作信号与误差信号传播。如下图所示为神经网络结构图。
在这里插入图片描述
BP神经网络的运算原理如下:
在这里插入图片描述

1.3 基于GABP神经网络的预测模型构建

(这里写一段话,描述一下问题的复杂度,引出为什么要在BP的基础上设计GABP
本文采用遗传算法对BP神经网络的进行了优化,并在迭代过程中利用BP神经网络的前向传播过程来计算每个个体的适应度,以此来提升算法的优化效率。算法的设计框架如算法如下所示。
在这里插入图片描述

在遗传算法的编码环节,IGABP将神经网络的权重和阈值连续地表示为一个向量,用于构成个体基因的表达。由于在算法运行过程中网络的结构已经确定,所需确定的权重及阈值数量也已经被确定,故在迭代过程中染色体的长度保持不变。
在遗传算法中计算个体适应度的部分,相比GABP使用解码后的个体初始化神经网络,然后根据训练后的输出计算适应度,IGABP从原理上着手,利用神经网络前向传播的过程,直接计算个体的适应度,免去了训练所需的计算量,提高了算法的优化效率。
编码及解码
假设BAGP中所使用的神经网络如下图所示:
在这里插入图片描述

则在确定网络的权重和阈值时,可以设计编码结构为:
在这里插入图片描述

在本文所设计的染色体中,基因位依次分别表述:输入层与隐含层之间的权值、隐含层的阈值、隐含层与输出层之间的权值,输出层的权值。由此,即可确定一个神经网络完整的结构。

在本文所设计的染色体中,基因位依次分别表述:输入层与隐含层之间的权值、隐含层的阈值、隐含层与输出层之间的权值,输出层的权值。由此,即可确定一个神经网络完整的结构。

1.4 自适应混合ARIMA-BP神经网络模型的建立

对于每一预测算法,均通过部分序列作为测试集。本文所设计的混合算法的混合思想主要为:在往期的预测中性能越好则在未来的预测中的权重就越高,对预测值的贡献度就越高。
在这里插入图片描述

式中,为算法k在混合算法中的权重。在每次计算混合预测值时,需要将ARIMA算法与BP神经网络算法的预测值结合起来。其计算公式可以表述为:
在这里插入图片描述

1.5 模型求解

模型求解结果如下:

在这里插入图片描述
(分析一下预测结果,识别出了波动。。。。)
在这里插入图片描述
结合黑子数进行分析,解得下一个太阳周期的开始时间约为2031年,结束时间约为2042年。

代码

Q1_1.m

clc
clear
data=xlsread('磁场.xlsx');
for i=1:size(data,1)
   if isnan(data(i,3)) 
       if isnan(data(i-1,3))
           data(i,3)=data(i+1,3);
       elseif isnan(data(i+1,3))
           data(i,3)=data(i-1,3);
       else
           data(i,3)=round((data(i-1,3)+data(i+1,3))/2);
       end
   end
end

color=[250/255,127/255,111/255;
    130/255,176/255,210/255;
    190/255,184/255,220/255;
    231/255,218/255,210/255;
    153/255,153/255,153/255];
plot([1:1:size(data,1)],data(:,3),'color',color(1,:))
set(gcf,'Color',[1 1 1])
xlabel({'Time'},'Color','k','FontSize',20,'FontName','Times New Roman')
ylabel({'magnetic field'},'Color','k','FontSize',20,'FontName','Times New Roman')

Q1_2.m

clc
clear
data=xlsread('磁场.xlsx');
index=[];
M=Inf;
for i=1:size(data,1)
    if data(i,2)~=M
       index=[index;i]; 
       M=data(i,2);
    end
end
index=[index;size(data,1)+1];
new_data=[];
for i=1:size(index,1)-1
   temp_data=data(index(i):index(i+1)-1,:); 
   new_data(i,1:2)=temp_data(1,1:2);
    new_data(i,3)=mean(temp_data(:,3));
end

color=[250/255,127/255,111/255;
    130/255,176/255,210/255;
    190/255,184/255,220/255;
    231/255,218/255,210/255;
    153/255,153/255,153/255];
plot([1:1:size(new_data,1)],new_data(:,3),'color',color(1,:))
set(gcf,'Color',[1 1 1])
xlabel({'Time'},'Color','k','FontSize',20,'FontName','Times New Roman')
ylabel({'magnetic field'},'Color','k','FontSize',20,'FontName','Times New Roman')

完整代码与论文获取

目前只分享第一问哦,以下是我们的论文框架、技术模板,代码以及使用到的数据。有需要的小伙伴看下面哦

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述


http://www.kler.cn/a/162264.html

相关文章:

  • 比ChatGPT更酷的AI工具
  • AI制作ppt
  • UVC 输出视频格式修改和windows下数据分析
  • NVIDIA Isaac Sim 仿真平台体验测评
  • STM32单片机WIFI语音识别智能衣柜除湿消毒照明
  • Unity3D 包体裁剪与优化详解
  • 文本润色工具有哪些,高质量的文本润色软件
  • 57、postgresql 查询流程
  • 聊聊模糊测试,以及几种模糊测试工具的介绍!
  • 解决Flutter运行报错Could not run build/ios/iphoneos/Runner.app
  • win10编译golang程序报病毒错误
  • js中数组对象去重的方法
  • 【mysql】事物与隔离级别
  • CKafka 一站式搭建数据流转链路,助力长城车联网平台降低运维成本
  • 模块式雨水调蓄池施工简单,无需大型机械,可实现当天开挖当天回填
  • Python Appium Selenium 查杀进程的实用方法
  • 微信小程序 - PC端选择ZIP文件
  • 微软 Power Platform 零基础 Power Pages 网页搭建实际案例实践(三)
  • 013 OpenCV copyMakeBorder(padding)
  • vscode如何在没有网络的情况下安装插件
  • Python 中 Thread 线程的用法
  • 非常抱歉的通知
  • 在imx6ull中加入ov5640模块
  • Linux查看命令的绝对路径
  • 企业贷款行业如何获客?
  • 无公网IP环境如何SSH远程连接Deepin操作系统