news 2026/6/25 8:02:04

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/24 22:51:35

Flutter 原生开发指南

欢迎大家加入开源鸿蒙跨平台开发者社区,一起共建开源鸿蒙跨平台生态。### # Flutter 原生开发指南 Flutter 是由 Google 开发的开源 UI 软件开发工具包,用于构建高性能、高保真的跨平台应用程序。它采用 Dart 编程语言,并提供了丰富的组件库…

作者头像 李华
网站建设 2026/6/22 4:30:19

35道常见的前端vue面试题,零基础入门到精通,收藏这篇就够了

来源 | https://segmentfault.com/a/1190000021936876 今天这篇文章给大家分享一些常见的前端vue面试题。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 对于前端来说,尽管css、html、js是主要的基础知识,但…

作者头像 李华
网站建设 2026/6/23 18:38:39

GTH系列模组介绍

Toyo(东佑达)GTH 系列是一款轨道内嵌式丝杆模组,是该品牌经典 ETH 系列的升级款,包含 GTH4、GTH5、GTH8、GTH12 等多个单轴型号,还有 GTH4D、GTH5D 等双滑座型号TOYO东佑达。其凭借高精度、高刚性等优势,广…

作者头像 李华
网站建设 2026/6/25 12:02:35

BlenderMCP革命性AI辅助3D建模:从零到专业场景的智能创作指南

BlenderMCP革命性AI辅助3D建模:从零到专业场景的智能创作指南 【免费下载链接】blender-mcp 项目地址: https://gitcode.com/GitHub_Trending/bl/blender-mcp 引言:AI如何重塑3D建模工作流? 你是否曾经面对空白Blender场景时感到无从…

作者头像 李华
网站建设 2026/6/25 6:58:48

JavaScript进阶(三):DOM事件

文章目录一.事件核心概念二.常见事件类型(按场景分类)1.鼠标事件2.键盘事件3.表单事件4.页面 / 窗口事件5.触摸事件(移动端)三.事件绑定方式(优先级:推荐 ③ > ② > ①)1.行内绑定(原生 HTML,不推荐)2.DOM 属性绑定(简单场景可用)3.addEventListener(推荐,标准方式)四.事…

作者头像 李华