news 2026/6/9 19:25:50

MindSpore 模型训练踩坑:过拟合快速优化 + 混合精度训练 Nan/Inf 异常的解决经验

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MindSpore 模型训练踩坑:过拟合快速优化 + 混合精度训练 Nan/Inf 异常的解决经验

大家好~最近用 MindSpore 2.2.10 做 ResNet18 图像分类模型训练,踩了两个典型坑,整理成经验分享给同方向的朋友👇

一、场景:ResNet18 图像分类训练

数据集是自定义的小样本图像集(约 5k 张),目标是实现分类任务,但训练过程中遇到两个核心问题:

二、踩坑 1:过拟合严重(训练集 98%,验证集仅 65%)

初始训练配置:

  • 数据增强仅用了 Resize+Normalize;
  • 优化器用 Adam,未加权重衰减;
  • 没加正则化层。

训练到第 10 轮就出现 “训练集准确率飙升,验证集纹丝不动” 的过拟合情况。

三、踩坑 2:开启混合精度后出现 Nan/Inf

为了加速训练,开启 MindSpore 的混合精度训练(amp.auto_mixed_precision(model, amp_level="O2")),结果训练到第 3 轮,loss 直接变成 Nan。

四、排查 & 解决过程

针对 “过拟合”:

强化数据增强(补 MindSpore 的 ImageTransform 操作):

from mindspore.dataset.vision import transforms trans = transforms.Compose([ transforms.RandomHorizontalFlip(prob=0.5), # 新增随机水平翻转 transforms.RandomCrop(size=224, padding=4), # 新增随机裁剪 transforms.Resize((224,224)), transforms.Normalize(mean=[0.485,0.456,0.406], std=[0.229,0.224,0.225]) ])

给优化器加权重衰减(weight_decay=1e-4):

optimizer = nn.Adam(model.trainable_params(), learning_rate=1e-4, weight_decay=1e-4)

新增 Dropout 层(在 ResNet18 的全连接层前加nn.Dropout(p=0.5));

调整后,验证集准确率从 65% 提升到 89%。

针对 “混合精度 Nan”:

  1. 排查原因:学习率过高 + 未配置 loss scale;
  2. 改用动态 Loss Scale(MindSpore 推荐方案):
from mindspore import amp loss_scale_manager = amp.DynamicLossScaleManager() model = amp.auto_mixed_precision(model, amp_level="O2", loss_scale_manager=loss_scale_manager)

加梯度裁剪(限制梯度范围):

from mindspore.nn.wrap import GradientClipByNorm optimizer = GradientClipByNorm(optimizer, clip_norm=1.0)

降低初始学习率到5e-5

重新训练后,Nan 问题消失,训练速度提升约 40%。

五、总结 Tips

  • 小样本训练:优先强化 MindSpore 的数据增强 + 加权重衰减 / 正则化;
  • MindSpore 混合精度:必须配loss_scale_manager,高学习率易出 Nan,建议加梯度裁剪。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 12:37:32

Uniapp——史上最完整Android离线多渠道打包教程

Android离线多渠道打包教程 前言一、原生build.gradle文件配置?二、模块AndroidManifest.xml三、uniapp代码使用教程四、打包处理总结 前言 Android 需要多渠道打包的主要原因是 支持不同的设备、市场和用户需求。通过多渠道打包,可以将一个应用根据不同…

作者头像 李华
网站建设 2026/6/10 12:37:32

云顶之弈智能挂机全攻略:3步实现自动经验收割

云顶之弈智能挂机全攻略:3步实现自动经验收割 【免费下载链接】LOL-Yun-Ding-Zhi-Yi 英雄联盟 云顶之弈 全自动挂机刷经验程序 外挂 脚本 ,下载慢可以到https://gitee.com/stringify/LOL-Yun-Ding-Zhi-Yi 项目地址: https://gitcode.com/gh_mirrors/lo/LOL-Yun-Di…

作者头像 李华
网站建设 2026/6/10 10:59:01

中铁资源金港公司精准施策夯实外派劳务服务保障根基

在中国中铁深耕全球、助力国家“一带一路”倡议推进中,中铁资源金港公司聚焦境外企业外派人员服务保障,以“选、育、派、管、归”全流程闭环管理体系,持续深耕服务细节,筑牢基础业务“压舱石”,切实守护外派员工福祉。…

作者头像 李华
网站建设 2026/6/10 15:42:38

使用LLaMA-Factory快速训练自己的专用大模型

本文聊聊 LLama-Factory,它是一个开源框架,这里头可以找到一系列预制的组件和模板,让你不用从零开始,就能训练出自己的语言模型(微调)。不管是聊天机器人,还是文章生成器,甚至是问答…

作者头像 李华
网站建设 2026/6/10 13:56:28

Vosk Android Demo:安卓离线语音识别完整指南

Vosk Android Demo:安卓离线语音识别完整指南 【免费下载链接】vosk-android-demo alphacep/vosk-android-demo: Vosk Android Demo 是一个演示项目,展示了如何在Android平台上使用Vosk语音识别引擎进行实时语音转文本功能。Vosk是开源的离线语音识别库&…

作者头像 李华
网站建设 2026/6/10 11:40:53

南京大学学位论文排版系统:从零开始掌握LaTeX模板

南京大学学位论文排版系统:从零开始掌握LaTeX模板 【免费下载链接】njuthesis-nju-thesis-template 南京大学学位论文(本科/硕士/博士),毕业论文LaTeX模板 项目地址: https://gitcode.com/gh_mirrors/nj/njuthesis-nju-thesis-template 项目核心价…

作者头像 李华