使用caffe训练时Loss变为nan的原因
来源:互联网 发布:fatezero的saber 知乎 编辑:程序博客网 时间:2024/05/16 13:47
梯度爆炸
原因:梯度变得非常大,使得学习过程难以继续
现象:观察log,注意每一轮迭代后的loss。loss随着每轮迭代越来越大,最终超过了浮点型表示的范围,就变成了NaN。
措施:
1. 减小solver.prototxt中的base_lr,至少减小一个数量级。如果有多个loss layer,需要找出哪个损失层导致了梯度爆炸,并在train_val.prototxt中减小该层的loss_weight,而非是减小通用的base_lr。
2. 设置clip gradient,用于限制过大的diff
不当的损失函数
原因:有时候损失层中loss的计算可能导致NaN的出现。比如,给InfogainLoss层(信息熵损失)输入没有归一化的值,使用带有bug的自定义损失层等等。
现象:观测训练产生的log时一开始并不能看到异常,loss也在逐步的降低,但突然之间NaN就出现了。
措施:看看你是否能重现这个错误,在loss layer中加入一些输出以进行调试。
示例:有一次我使用的loss归一化了batch中label错误的次数。如果某个label从未在batch中出现过,loss就会变成NaN。在这种情况下,可以用足够大的batch来尽量避免这个错误。
不当的输入
原因:输入中就含有NaN。
现象:每当学习的过程中碰到这个错误的输入,就会变成NaN。观察log的时候也许不能察觉任何异常,loss逐步的降低,但突然间就变成NaN了。
措施:重整你的数据集,确保训练集和验证集里面没有损坏的图片。调试中你可以使用一个简单的网络来读取输入层,有一个缺省的loss,并过一遍所有输入,如果其中有错误的输入,这个缺省的层也会产生NaN。
案例:有一次公司需要训练一个模型,把标注好的图片放在了七牛上,拉下来的时候发生了dns劫持,有一张图片被换成了淘宝的购物二维码,且这个二维码格式与原图的格式不符合,因此成为了一张“损坏”图片。每次训练遇到这个图片的时候就会产生NaN。良好的习惯是,你有一个检测性的网络,每次训练目标网络之前把所有的样本在这个检测性的网络里面过一遍,去掉非法值。
池化层中步长比核的尺寸大
如下例所示,当池化层中stride > kernel的时候会在y中产生NaN
layer { name: "faulty_pooling" type: "Pooling" bottom: "x" top: "y" pooling_param { pool: AVE stride: 5 kernel: 3 } }
致谢
http://stackoverflow.com/questions/33962226/common-causes-of-NaNs-during-training
- 顶
- 0
- 踩
- 使用caffe训练时Loss变为nan的原因
- 使用caffe训练时Loss变为nan的原因
- 使用caffe训练时Loss变为nan的原因
- 使用caffe训练时Loss变为nan的原因
- 使用caffe训练时Loss变为nan的原因
- caffe训练时loss=nan的原因
- Caffe 训练时loss等于87.33的原因及解决方法
- Caffe 训练时loss等于87.33的原因及解决方法
- Caffe 训练时loss等于87.33的原因及解决方法
- Caffe 训练时loss等于87.33的原因及解决方法
- Caffe 训练时loss等于87.33的原因及解决方法
- caffe 训练中loss 为nan
- caffe训练CNN时,loss不收敛原因分析
- 转:Caffe 训练时loss等于87.33的原因及解决方法
- caffe loss NaN
- caffe loss NaN
- 在卷积神经网络训练过程中loss出现NaN的原因以及可以采取的方法
- 神经网络训练时,出现NaN loss
- 课后练习 2.3
- 关于WIN10安装oracle报错INS-13001环境不满足最低要求
- Android App 沉浸式状态栏解决方案
- 枚举的原理
- 1. Two Sum && 167. Two Sum II
- 使用caffe训练时Loss变为nan的原因
- 欢迎使用CSDN-markdown编辑器
- Select模型原理
- Python GUI框架Tkinter简介
- TI-Davinci开发系列之七DVSDK-4.03目录介绍
- jQuery.nicescroll美化滚动条
- JavaEE面试题集锦
- JDK安装与环境变量配置
- 动态添加删除网卡