news 2026/6/15 13:43:00

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/15 10:28:09

无界微前端,零基础入门到精通,收藏这篇就够了

目录 前置知识 一、无界微前端的优缺点 1.优点 2.缺点 二、微前端技术选型决策树 三、无界通讯 1、通过props方法 2、通过 bus 方法 3.通过 postmessage 方法 4.路由跳转 四、插件系统 1. html-loader 可以对子应 html 进行处理 2. jsIgnoresh和cssIgnores(子应用…

作者头像 李华
网站建设 2026/6/15 7:25:27

前端组件库大合集-必备收藏

前端组件库 搭建web app常用的样式/组件等收集列表(移动优先) 0. 前端自动化(Workflow) 前端构建工具 Yeoman – a set of tools for automating development workflowgulp – The streaming build systemgrunt – the JavaScript Task RunnerF.I.S – 前端集成解决方案 前端模…

作者头像 李华
网站建设 2026/6/15 1:17:05

实战突破:用Vosk构建下一代离线语音应用的完整指南

实战突破:用Vosk构建下一代离线语音应用的完整指南 【免费下载链接】vosk-api vosk-api: Vosk是一个开源的离线语音识别工具包,支持20多种语言和方言的语音识别,适用于各种编程语言,可以用于创建字幕、转录讲座和访谈等。 项目地…

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

如何快速掌握光学原理:Born Wolf经典教材终极指南

光学原理是物理学中至关重要的基础学科,而《Principles of Optics 7th ed M.Born,E.Wolf.pdf》正是这一领域的权威著作。这本由诺贝尔奖得主Max Born与光学泰斗Emil Wolf合著的经典教材,被誉为"光学领域的权威指南",为无数光学研究…

作者头像 李华
网站建设 2026/6/15 11:20:33

NewGAN-Manager:足球经理玩家的终极面部包管理解决方案

NewGAN-Manager:足球经理玩家的终极面部包管理解决方案 【免费下载链接】NewGAN-Manager A tool to generate and manage xml configs for the Newgen Facepack. 项目地址: https://gitcode.com/gh_mirrors/ne/NewGAN-Manager 想要让《Football Manager》游戏…

作者头像 李华
网站建设 2026/6/15 13:33:16

Groove音乐播放器终极使用指南:从新手到高手的完整进阶路径

Groove音乐播放器终极使用指南:从新手到高手的完整进阶路径 【免费下载链接】Groove 项目地址: https://gitcode.com/gh_mirrors/gr/Groove 你是否曾经为音乐播放器的功能单一而烦恼?面对海量的本地音乐却无法高效管理?想要享受在线音…

作者头像 李华