[已更新前两问代码+全部建模]2024华为杯C题详细思路代码文章建模分享研究生数学建模竞赛数学建模研赛

请添加图片描述
请添加图片描述

截止9.21 12点 已更新问题一二的代码和全部内容的建模

下面我们会先进行代码讲解,之后给出全部内容的建模公式


## https://docs.qq.com/doc/DVWhyZ1NFY01XcmNw

基于磁通密度数据的特征提取与分类分析。

问题一代码详解

1. 导入必要的库

import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
import seaborn as sns
  • pandas 用于数据处理与操作。
  • numpy 用于科学计算。
  • matplotlib.pyplotseaborn 用于数据可视化。

2. 读取训练数据

data = pd.read_excel('附件一(训练集).xlsx', sheet_name='材料1')
  • 读取Excel中的训练数据,特别是“材料1”这一页。

3. 设置中文字体与负号显示

plt.rcParams['font.sans-serif'] = ['SimHei']
plt.rcParams['axes.unicode_minus'] = False
  • 设置中文字体为黑体,确保图表中的中文能够正常显示。
  • 解决了负号无法显示的问题。

4. 绘制磁通密度曲线

def plot_magnetic_flux_density(sample_id):sample = data.iloc[sample_id, 4:].valuestime = np.linspace(0, 1, len(sample))plt.figure(figsize=(8, 4))plt.plot(time, sample)plt.title(f"磁通密度随时间的变化 - 样本 {sample_id}")plt.xlabel("时间 (周期内归一化)")plt.ylabel("磁通密度 (T)")plt.grid(True)plt.show()plot_magnetic_flux_density(0)
  • 定义了一个函数 plot_magnetic_flux_density,通过样本ID绘制样本的磁通密度随时间的变化曲线。
  • 该函数读取样本的磁通密度数据,并生成与时间对应的曲线图。

5. 特征提取

from scipy.stats import kurtosis, skew
from scipy.fft import fftdef extract_features(sample):features = {}sample = sample.astype(float)sample = sample[~np.isnan(sample)]# 时间域特征features['mean'] = np.mean(sample)features['std'] = np.std(sample)features['max'] = np.max(sample)features['min'] = np.min(sample)features['kurtosis'] = kurtosis(sample)features['skew'] = skew(sample)# 频域特征fft_values = np.abs(fft(sample))features['fft_1'] = fft_values[1]features['fft_2'] = fft_values[2]features['fft_3'] = fft_values[3]return features
  • 定义了 extract_features 函数用于从磁通密度数据中提取特征。
  • 包括时间域特征(如均值、标准差、峰度等)和频域特征(通过傅里叶变换提取主要频率成分)。

6. 分类模型训练

from sklearn.model_selection import train_test_split
from sklearn.ensemble import GradientBoostingClassifier
from sklearn.metrics import classification_report, confusion_matrixX = features_df.drop('label', axis=1)
y = features_df['label']
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42)gbdt = GradientBoostingClassifier(n_estimators=100, learning_rate=0.1, max_depth=5, random_state=42)
gbdt.fit(X_train, y_train)y_pred = gbdt.predict(X_test)
print(classification_report(y_test, y_pred))cm = confusion_matrix(y_test, y_pred)
sns.heatmap(cm, annot=True, fmt="d", cmap="Blues", xticklabels=['正弦波', '三角波', '梯形波'], yticklabels=['正弦波', '三角波', '梯形波'])
plt.show()
  • 使用 GradientBoostingClassifier 模型进行分类训练。
  • 使用训练集数据训练模型,并评估模型在测试集上的性能,输出分类报告和混淆矩阵。

7. 测试集数据处理与预测

test_data = pd.read_excel('附件二(测试集).xlsx')
test_data_features_df = pd.DataFrame(test_data_features)
y_pred = gbdt.predict(test_data_features_df)
  • 读取测试数据,提取特征,并使用训练好的模型对测试集进行分类预测。

8. 结果保存与输出

test_data_features_df.to_csv('results.csv', index=False)
sample_df.to_csv("附件二_特定样本分类结果.csv", index=False)
  • 将预测结果保存为 CSV 文件,并将特定样本的分类结果输出。

9. 可视化特定样本分类结果

categories = {1: '正弦波', 2: '三角波', 3: '梯形波'}
fig, axs = plt.subplots(3, 1, figsize=(10, 12))for category, ax in zip([1, 2, 3], axs):selected_samples = sample_df[sample_df['分类结果'] == category]for _, row in selected_samples.iterrows():sample_id = row['样本序号']sample = test_data.iloc[sample_id - 1, 4:].valuestime = np.linspace(0, 1, len(sample))ax.plot(time, sample, label=f'样本 {sample_id}')ax.set_title(f"{categories[category]} 分类下的样本磁通密度曲线")ax.set_xlabel("时间 (周期归一化)")ax.set_ylabel("磁通密度 (T)")ax.grid(True)ax.legend(loc='best')plt.tight_layout()
plt.show()
  • 绘制了属于三种分类结果的样本的磁通密度曲线,方便可视化分类结果的准确性。

代码通过读取磁通密度数据,进行特征提取和分类模型训练,最后对测试集进行预测并展示了结果。

问题一部分结果
请添加图片描述

请添加图片描述

请添加图片描述

请添加图片描述

问题二代码详解:

使用**斯坦麦茨方程(Steinmetz equation)**及其修正形式来拟合并预测材料的磁芯损耗。

1. 导入必要的库

import pandas as pd
import numpy as np
from scipy.optimize import curve_fit
import matplotlib.pyplot as plt
  • pandas 用于读取和处理数据。
  • numpy 用于数值计算。
  • scipy.optimize.curve_fit 用于非线性曲线拟合。
  • matplotlib.pyplot 用于可视化。

2. 读取数据

data = pd.read_excel('附件一(训练集).xlsx', sheet_name='材料1')
  • 从 Excel 文件中读取训练数据,特别是“材料1”这一页的数据。

3. 筛选出正弦波数据

data = data[data['励磁波形']=='正弦波']
  • 筛选出励磁波形为“正弦波”的数据进行分析。

4. 提取变量

frequency = data['频率,Hz'].values
P_loss = data['磁芯损耗,w/m3'].values
flux_density_data = data.iloc[:, 4:1029]
B_max = flux_density_data.max(axis=1).values
  • 提取数据中的频率、磁芯损耗和磁通密度峰值数据,准备用于后续的拟合。

5. 定义斯坦麦茨方程

def steinmetz(f, B_max, k1, alpha1, beta1):return k1 * (f ** alpha1) * (B_max ** beta1)
  • 定义了斯坦麦茨方程,它描述了磁芯损耗 ( P ) 与频率 ( f ) 和磁通密度峰值 ( B_{\text{max}} ) 的关系。这里 ( k1 )、( \alpha1 ) 和 ( \beta1 ) 是需要拟合的参数。

6. 拟合斯坦麦茨方程

popt, pcov = curve_fit(lambda xdata, k1, alpha1, beta1: steinmetz(xdata[0], xdata[1], k1, alpha1, beta1), (frequency, B_max), P_loss, p0=initial_guess
)
  • 使用 curve_fit 函数来拟合斯坦麦茨方程,popt 是拟合得到的参数,包括 ( k1 )、( \alpha1 ) 和 ( \beta1 )。

7. 绘制拟合结果

P_pred_steinmetz = steinmetz(frequency, B_max, k1_opt, alpha1_opt, beta1_opt)
plt.plot(P_loss, label='实际磁芯损耗', marker='o')
plt.plot(P_pred_steinmetz, label='拟合磁芯损耗', linestyle='--')
  • 使用拟合得到的参数,计算预测的磁芯损耗,并与实际损耗进行对比。代码通过绘图直观展示了拟合结果的准确性。

8. 评估拟合效果

mse = mean_squared_error(P_loss, P_pred_steinmetz)
mae = mean_absolute_error(P_loss, P_pred_steinmetz)
r2 = r2_score(P_loss, P_pred_steinmetz)
  • 通过均方误差(MSE)、均绝对误差(MAE)和决定系数(R²)评估拟合的准确性。

9. 修正斯坦麦茨方程

def steinmetz_with_temp(T, f, B_max, k1, alpha1, beta1, a, b):gamma_T = 1 + a * (T - 25) + b * (T - 25)**2return k1 * (f ** alpha1) * (B_max ** beta1) * gamma_T
  • 为了提高模型的准确性,定义了一个包含温度修正因子的斯坦麦茨方程。这个修正方程引入了两个额外的参数 ( a ) 和 ( b ),用来修正温度对磁芯损耗的影响。

10. 拟合修正后的斯坦麦茨方程

popt, pcov = curve_fit(lambda inputs, k1, alpha1, beta1, a, b: steinmetz_with_temp(inputs[0], inputs[1], inputs[2], k1, alpha1, beta1, a, b),(temperature, frequency, B_max), P_loss, p0=initial_guess)
  • 使用 curve_fit 对修正后的斯坦麦茨方程进行拟合,拟合得到的参数包括温度修正因子的参数 ( a ) 和 ( b )。

11. 绘制修正后的拟合结果

P_pred = steinmetz_with_temp(temperature, frequency, B_max, k1_opt, alpha1_opt, beta1_opt, a_opt, b_opt)
plt.plot(P_loss, label='实际磁芯损耗', marker='o')
plt.plot(P_pred, label='拟合磁芯损耗', linestyle='--')
  • 使用修正后的方程预测磁芯损耗,并绘制实际损耗与预测损耗的对比图。

12. 计算误差与评估模型

mse = mean_squared_error(P_loss, P_pred)
mae = mean_absolute_error(P_loss, P_pred)
r2 = r2_score(P_loss, P_pred)
  • 再次使用均方误差、均绝对误差和决定系数对修正后的模型进行评估,判断其拟合效果。

13. 绘制误差对比

plt.fill_between(range(len(P_loss)), P_loss, P_pred_steinmetz, color='red', label='误差 (Steinmetz)')
plt.fill_between(range(len(P_loss)), P_loss, P_pred, color='blue', alpha = 0.5, label='误差 (修正)')
  • 通过图形展示传统斯坦麦茨方程和修正方程的误差对比,验证修正后的模型在误差方面的改进。

该代码通过斯坦麦茨方程及其温度修正形式,对数据集中的磁芯损耗进行拟合与预测,并通过绘图和误差计算来评估模型的准确性。修正后的模型考虑了温度对磁芯损耗的影响,进一步提高了预测的精度。

问题二代码结果展示:

请添加图片描述

请添加图片描述

请添加图片描述

请添加图片描述

问题3-5详细的思路建模:

问题三:磁芯损耗因素分析

问题分析:
温度、励磁波形和磁芯材料是影响磁芯损耗的关键因素。我们需要分析这些因素的独立及协同作用。

建模步骤:

  1. 单因素分析:
    对每个因素进行回归分析,计算它们对损耗的影响。可以采用多项式回归,考虑非线性关系:

  2. 协同作用分析:
    使用交互作用项来建模不同因素的协同作用,例如温度和频率的交互作用:
    在这里插入图片描述

    可以采用多因子方差分析(ANOVA)或广义线性模型(GLM)来评估这些交互作用的显著性。

  3. 高级算法:
    偏最小二乘回归(Partial Least Squares Regression, PLSR):PLSR 是一种多变量统计方法,适合用于处理高维相关性强的输入变量。在处理温度、波形、材料等多因素时,PLSR 可以有效提取出主要影响因素。

  4. 结果分析:
    分析不同条件下磁芯损耗最小的工况组合,例如使用梯度下降法优化不同因素的组合。

问题四:基于数据驱动的磁芯损耗预测模型

问题分析:
使用给定的实验数据,构建磁芯损耗预测模型,并在测试集中进行预测。

建模步骤:

  1. 数据处理:
    数据集较大,可能需要对特征进行降维。可以使用主成分分析(PCA)降维:

  2. 模型构建:
    XGBoost:XGBoost 是一种提升树模型,适合处理复杂的非线性回归问题。

  3. 模型评价:
    使用均方误差(MSE)和R平方作为模型评价指标。

问题五:磁性元件的最优化条件

问题分析:
基于磁芯损耗和传输磁能两个目标,建立优化模型,寻找最优工况。

建模步骤:

  1. 目标函数:
    损耗最小和传输磁能最大为优化目标:
    在这里插入图片描述

  2. 优化算法:
    可以使用遗传算法(GA)或粒子群优化(PSO)来解决这个多目标优化问题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/146682.html

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

相关文章

Innodb内存结构

缓冲池Buffer Pool: 缓冲池是innodb内存结构缓冲区中的核心部分,在服务启动的时候服务器会向操作系统申请一块大小为128MB的内存空间,所有对数据库中数据的增删查改操作均在缓冲池bufferPool中完成,并且缓冲区中其他组件的描述信息也都存储在…

AI绘画Flux【lora模型】【微缩景观】:惊艳!3D场景融入手机上的微景观!

大家好,我是灵魂画师向阳 今天和大家分享一款基于Flux底模训练的微缩景观模型——FLUX|手机上的微景观。此模型主要将手机作为微型景观的基底,强制将3d情景融入手机并控制在手机屏幕上方范围内。 作者在使用提示词直出和使用该Loar提示词生成的图片进行…

手撕小顶堆

1. 抛砖引玉 给定两个以升序排列的整数数组 nums1 和 nums2 , 以及一个整数 k 。 定义一对值 (u,v),其中第一个元素来自 nums1,第二个元素来自 nums2 。 请找到和最小的 k 个数对 (u1,v1), (u2,v2) … (uk,vk) 。 分析 大根堆(大顶堆&#x…

多旋翼无人机维修、组装、调试技术详解

多旋翼无人机作为现代航拍、农业植保、物流运输等领域的重要工具,其性能的稳定性和操作的便捷性对于任务的完成至关重要。因此,掌握多旋翼无人机的维修、组装与调试技术,对于无人机操作员及维修人员来说至关重要。本文将详细介绍这三个方面的…

线程池ForkJoinPool实战及其工作原理分析

1. 由一道算法题引发的思考 算法题:如何充分利用多核CPU的性能,快速对一个2千万大小的数组进行排序? 这道算法题可以拆解来看: 1)首先这是一道排序的算法题,而且是需要使用高效的排序算法对2千万大小的数…

从一个文本文件中挑选出符合条件的内容行

某天,张三得到一个需求,将如下格式的文本文件中的文件名开头的内容行提取出来,存入一个新的文本文件。 ok 0 文件名:1_zoukaige.mp3 index:10 文件名:2_dahan.mp3 index:20 文件名:3_kuai.mp3 index:30 文件…

【JavaEE精炼宝库】HTTP | HTTPS 协议详解

文章目录 一、HTTP 简介二、HTTP 协议格式:2.1 抓包工具的使用:2.2 HTTP 请求报文格式:2.3 HTTP 响应报文格式:2.4 HTTP 协议格式总结: 三、HTTP 请求详解:3.1 刨析 URL:3.2 方法(method)&#…

Kerberos自我总结Kerberos自我总结

1、协议原理与漏洞产生 1.1 kerberos Kerberos协议是一种基于票据Ticket的认证方式,它由三个角色组成,分别是客户端Client、服务端Server和秘钥分发中心KDC。 协议中的交互分为六步,为AS_REQ、AS_REP、TGS_REQ、TGS_REP、AP_REQ和AP_REP …

揭露大模型本质,大模型入门必看的12本书!看完我直接跪了

敢不敢用一年时间读完这12本书,模型入门必看的12本书!建议收藏!! 第一本: 《基于GPT-3,ChatGPT,GPT-4等Transformer架构的自然语言处理》 主要内容 了解用于解决复杂语言问题的新技术。将GPT-3与T5、GPT-2和基于BE…

用Python实现时间序列模型实战——Day 28-29: 项目报告与展示

一、学习内容 1.1 项目报告的撰写与优化 项目报告应该从项目背景、数据探索、建模过程、预测结果、模型评估等方面进行全面描述。通过清晰的图表、简明的文字和合理的模型选择来优化报告的表达。 1.2 项目结果的展示与交流 通过展示图表、代码、关键模型的结果,…

Linux系统中的进程调度队列

目录 一、进程调度队列结构 二、活动队列与过期队列 1.queue[140] 2.bitmap[5] 一、进程调度队列结构 Linux系统中,每一个CPU都有一个进程调度队列runqueue,如图所示 二、活动队列与过期队列 运行队列runqueue中有两个指针*active、*expired。*acti…

从小白到大神:C语言预处理与编译环境的完美指南(下)

从小白到大神:C语言预处理与编译环境的完美指南(上)-CSDN博客 👆👆👆👆👆👆上篇链接在这~~👆👆👆👆👆&#x…

角色权限管理实现学习

逻辑: 权限表(Sys_Power):存所需授权才能访问的检验字段 授权表/角色权限表(Sys_RolePower):存角色所能访问的权限字段 角色表(Sys_Role):定义角色(管理员,部门负责人,项目负责人...) 用唯一的权限字段标注所要授权才能访问的…

心理辅导系统设计与Spring Boot技术

5 系统的实现 5.1学生功能模块的实现 学生进入本系统可查看系统信息,系统主界面展示如图5-1所示。 图5-1系统主界面图 5.1.1 学生登录界面 学生在登录时需输入正确的登录用户名和密码,系统会以登录用户名、密码为参数进行登录信息的验证,信…

Keil MDK5学习记录

2024.9.19 1. no browse information available in ‘xxx’的问题 成功解决Keil MDK5中no browse information available in ‘xxx’的问题-CSDN博客https://blog.csdn.net/bean_business/article/details/1091894452. .c文件中显示函数列表 如何在Keil5里.c文件中显示函数列表…

oracle数据库启动

文章目录 背景一、步骤1.登录oracle用户2.启动监听服务3.启动数据库 背景 oracle数据库启动 一、步骤 1.登录oracle用户 代码如下(示例): su - oracle2.启动监听服务 代码如下(示例): lsnrctl start成…

AI音乐创作带给音乐原创人的挑战和机遇

随着人工智能(AI)技术的迅速发展,AI音乐创作在全球音乐产业中逐渐崭露头角。人工智能不仅能生成旋律、和声,甚至可以模仿艺术家风格创作出接近真实人类创作的作品。这一技术的崛起给音乐原创人带来了前所未有的挑战,但…

【PyQt5】QWidget子类所有子类

QWidget子类 [QObject 学习](https://editor.csdn.net/md/?articleId142371795) 2024-09-19更新QWidget子类所有子类 2024-09-17发布子类QAbstractButton类 2024-09-17正在学习中QAbstractslider类QAbstractSpinBox类QFrame类QCalendarwidget类QComboBox类QDialogButtonBox类Q…

【计算机网络 - 基础问题】每日 3 题(十八)

✍个人博客:Pandaconda-CSDN博客 📣专栏地址:http://t.csdnimg.cn/fYaBd 📚专栏简介:在这个专栏中,我将会分享 C 面试中常见的面试题给大家~ ❤️如果有收获的话,欢迎点赞👍收藏&…

uniapp 微信小程序 订阅消息功能实现

该网址 https://api.weixin.qq.com 上线后不可访问,调用该网址操作需在后端( 重要! 重要! 重要!) 1.首先拿到的三个码 //微信公众平台 //https://mp.weixin.qq.com const wxappid "管理-开发管理-A…