主页 > 知识库 > 解决Pytorch中的神坑:关于model.eval的问题

解决Pytorch中的神坑:关于model.eval的问题

热门标签:武汉外呼系统平台 富锦商家地图标注 沈阳防封电销卡品牌 沈阳外呼系统呼叫系统 沈阳人工外呼系统价格 池州外呼调研线路 江西省地图标注 如何申请400电话费用 外呼系统哪些好办

有时候使用Pytorch训练完模型,在测试数据上面得到的结果令人大跌眼镜。

这个时候需要检查一下定义的Model类中有没有 BN 或 Dropout 层,如果有任何一个存在

那么在测试之前需要加入一行代码:

#model是实例化的模型对象
model = model.eval()

表示将模型转变为evaluation(测试)模式,这样就可以排除BN和Dropout对测试的干扰。

因为BN和Dropout在训练和测试时是不同的:

对于BN,训练时通常采用mini-batch,所以每一批中的mean和std大致是相同的;而测试阶段往往是单个图像的输入,不存在mini-batch的概念。所以将model改为eval模式后,BN的参数固定,并采用之前训练好的全局的mean和std;

对于Dropout,训练阶段,隐含层神经元先乘概率P,再进行激活;而测试阶段,神经元先激活,每个隐含层神经元的输出再乘概率P。

如下图所示:

补充:pytorch中model.eval之后是否还需要model.train的问题

答案是:需要的

正确的写法是

for循环之后再开启train,

循环之后的评估model.eval之后就会再次回到model.train

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
  • 聊聊pytorch测试的时候为何要加上model.eval()
  • pytorch:model.train和model.eval用法及区别详解
  • 解决BN和Dropout共同使用时会出现的问题

标签:阿里 通辽 铜川 潜江 常德 株洲 黑龙江 吕梁

巨人网络通讯声明:本文标题《解决Pytorch中的神坑:关于model.eval的问题》,本文关键词  解决,Pytorch,中的,神坑,关于,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《解决Pytorch中的神坑:关于model.eval的问题》相关的同类信息!
  • 本页收集关于解决Pytorch中的神坑:关于model.eval的问题的相关信息资讯供网民参考!
  • 推荐文章