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

news2024/11/19 5:28:01

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.coloradmin.cn/o/1276057.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Android 应用程序无响应定位ANR原因

废话不多说,直接上方案: 第一步: 执行adb命令 adb bugreport /Users/mac/Desktop/anr 解压后FS/data/anr下就会有相关anr文件 /Users/mac/Desktop/anr 是电脑存储文件的路径,可以随便定义,这个没有影响。我的电脑是…

RHCSA学习笔记(RHEL8) - Part2.RH134

Chapter Ⅰ 提高命令行生产率 SHELL脚本 #/bin/bash声明使用的shell翻译器 for循环 for VAR in LIST doCOMMAND1COMMAND2 done实验1:显示host1-5 #! /bin/bash for host in host{1..5} doecho $host done实验2:显示包含kernel的软件包安装时间 #! /…

【微服务 SpringCloudAlibaba】实用篇 · Gateway服务网关

微服务(8) 文章目录 微服务(8)1. 为什么需要网关2. gateway快速入门1)创建gateway服务,引入依赖2)编写启动类3)编写基础配置和路由规则4)重启测试5)网关路由的…

linux 内核工作队列技术原理

首先介绍一下工作队列使用的术语。 work:工作,也称为工作项。work queue:工作队列,就是工作的集合, work queue 和 work 是一对多的关系。worker: 工人, 一个工人对应一个内核线程,…

助力android面试2024【面试题合集】

转眼间,2023年快过完了。今年作为口罩开放的第一年大家的日子都过的十分艰难,那么想必找工作也不好找,在我们android开发这一行业非常的卷,在各行各业中尤为突出。android虽然不好过,但不能不吃饭吧。卷归卷但是还得干…

什么是美颜SDK?市面常用直播美颜SDK的技术比较

直播平台美颜技术其中的核心就是美颜SDK。本文将深入探讨什么是美颜SDK,以及市面上常用的直播美颜SDK的技术比较。 一、美颜SDK简介 美颜SDK,使开发者能够在其应用或平台中集成美颜特效。对于直播平台而言,美颜SDK的引入旨在提供实时、高质…

LabVIEW在调用image.cpp或drawmgr.cpp因为DAbort而崩溃

LabVIEW在调用image.cpp或drawmgr.cpp因为DAbort而崩溃 出现下列问题,如何解决? 1. LabVIEW 程序因image.cpp或drawmgr.cpp中的错误而崩溃 2. 正在通过cRIO-9034运行独立的LabVIEW应用程序,但它因drawmgr.cpp中的错误而崩溃 …

利用reddit的api进行爬虫

1 介绍 Reddit是一个社交新闻聚合网站,用户可以发布、评价和讨论各种话题。Reddit的内容涵盖了广泛的主题,可以从中获取大量的文本数据进行情绪分析。 2 注册 2.1 注册reddit 你需要先注册一个reddit的账号。 2.2 注册api https://www.reddit.com/…

微服务架构:解析分布式系统的演进

目录 微服务是什么? 微服务的优势 微服务的挑战 应对微服务挑战的方法 结论 在当今快速发展的软件开发领域,微服务架构成为一种备受瞩目的设计理念,被广泛应用于构建灵活、可扩展的分布式系统。本文将深入探讨什么是微服务,为…

LeetCode困难题(分发糖果--接雨水)

分发糖果 n 个孩子站成一排。给你一个整数数组 ratings 表示每个孩子的评分。 你需要按照以下要求,给这些孩子分发糖果: 每个孩子至少分配到 1 个糖果。相邻两个孩子评分更高的孩子会获得更多的糖果。 请你给每个孩子分发糖果,计算并返回…

线性回归既是一种数据挖掘与建模算法,也是统计学领域、计量经济学领域的常用学术建模方法,有何不同?

一.线性回归的基本形式 线性回归既是一种数据挖掘与建模算法,也是统计学领域、计量经济学领域的常用学术建模方法。在数据挖掘与建模领域,线性回归算法是一种较为基础的机器学习算法,其基本思想是将响应变量(因变量、被解释变量&…

MySQL安全相关——TDE和数据脱敏功能介绍

MySQL作为一款广泛使用的开源关系型数据库管理系统(RDBMS),其安全性一直是开发者和企业关注的重点。在MySQL中,有一些与安全相关的功能,其中包括Transparent Data Encryption(TDE)和数据脱敏。本文将对这些功能进行介绍。 一、Transparent Da…

使用 kubeadm 部署 Kubernetes 集群(二)k8s环境安装

一、安装containerd 安装 k8s 有几种方式: 1、 Kubeadm 2、 二进制 这两个是 k8s 官网提供的方式,也是生产环境用的还可以借助第三方平:rancher、kubesphere 都可以装 k8s 这里使用 kubeadm 1.安装 containerd 在 Kubernetes 集群中&#…

CSS——基础选择器、文字控制属性

1、CSS定义 层叠样式表(Cascading Style Sheets,缩写为CSS),是一种 样式表 语言,用来描述 HTML 文档的呈现(美化内容)。 书写位置:title 标签下方添加style双标签,styl…

externalTrafficPolicy 再探

一 externalTrafficPolicy 属性再探 一次网络不通"争吵"引发的思考 K8s中的external-traffic-policy是什么? 说明: 阿里云的 EDAS 和ACK的默认行为不一样 Kubernetes(二十三)Service(二)会话保持和获取客户端的ip 访问 externalTrafficPolicy 为 L…

二分查找与搜索树高频问题

关卡名 逢试必考的二分查找 我会了✔️ 内容 1.山脉数组的峰顶索引 ✔️ 2.旋转数字的最小数字 ✔️ 3.寻找缺失数字 ✔️ 4.优化求平方根 ✔️ 5.中序与搜索树原理 ✔️ 6.二叉搜索树中搜索特定值 ✔️ 7.验证二叉搜索树 ✔️ 基于二分查找思想,可以拓展出很…

IntelliJ IDEA 之初体验(上)

IntelliJ IDEA 是一款由 JetBrains 公司开发的强大的集成开发环境(IDE),专注于 Java 开发,同时支持多种其他编程语言。本文将详细介绍 IntelliJ IDEA 的安装过程以及一些常用的基本操作。 第一步:下载与安装 IntelliJ…

LeetCode Hot100 75.颜色分类

题目: 给定一个包含红色、白色和蓝色、共 n 个元素的数组 nums ,原地对它们进行排序,使得相同颜色的元素相邻,并按照红色、白色、蓝色顺序排列。 我们使用整数 0、 1 和 2 分别表示红色、白色和蓝色。 必须在不使用库内置的 so…

LeetCode 2661. 找出叠涂元素:多次映射

【LetMeFly】2661.找出叠涂元素:多次映射 力扣题目链接:https://leetcode.cn/problems/first-completely-painted-row-or-column/ 给你一个下标从 0 开始的整数数组 arr 和一个 m x n 的整数 矩阵 mat 。arr 和 mat 都包含范围 [1,m * n] 内…