news 2026/1/20 5:46:08

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/1/16 4:30:14

轮换代理 vs 静态代理 —— 全面对比

轮换代理 vs 静态代理 —— 全面对比 在这篇文章中,我会拆解静态代理和轮换代理的关键特性及其主要使用场景,并对它们的优缺点进行对比。读完之后,你就能清楚判断哪种代理类型更适合你的需求。 下面我们就进入细节,帮你选对代理…

作者头像 李华
网站建设 2026/1/16 22:34:33

搭建AnythingLLM专属AI知识库!小白也能轻松搞定

• 有人在 ChatGPT 的 Android 版本上看到了 “GPT 4.5 研究预览”(GPT 4.5 research preview) 的标记,并提示 “将为 Pro 用户提供最新模型”,合理猜测将推出GPT4.5 。 –ChatGPT• OpenAI 宣布,免费开放 ChatGPT 的高级语音模式 (Advanced Voice Mode)…

作者头像 李华
网站建设 2025/12/25 21:07:20

前端学习路线,零基础入门到精通,收藏这篇就够了

目录 第一阶段:前端入门 1.Html5 2.Css3 第二阶段:JavaScript ①JavaScript 基础语法 ②JavaScript 高级(WebAPI/Dom Bom) ③JavaScript 框架(jQuery) ④数据可视化(echarts&#xff09…

作者头像 李华
网站建设 2025/12/21 15:16:51

赛马娘汉化补丁终极指南:从零到精通的完整配置手册

赛马娘汉化补丁终极指南:从零到精通的完整配置手册 【免费下载链接】umamusume-localify Localify "ウマ娘: Pretty Derby" DMM client 项目地址: https://gitcode.com/gh_mirrors/um/umamusume-localify 想要让你的赛马娘游戏体验焕然一新吗&…

作者头像 李华