pytorch中model.eval()和torch.no_grad()的区别

  • model.train()

在train模式下,dropout网络层会按照设定的参数p,设置保留激活单元的概率(保留概率=p),并且batch norm层会继续计算数据的mean和var等参数并更新,总结如下:
在这里插入图片描述

  • model.eval()——正常推理

在PyTorch中进行validation时,会使用model.eval()切换到测试或者称为验证模式下。model.eval()仅作用于dropout层和batchnorm层,让其与训练状态不同,相当于 dropout的参数为0 ,batchnorm也 不再更新和计算 mean和var值,而是使用训练阶段学习到的mean和var。

model.eval()不会影响各层的gradient计算行为,即gradient计算和存储与training模式一样,只是不进行反向传播。
在这里插入图片描述

  • with torch.no_grad()——没有梯度计算

而 with torch.no_grad()的作用是 停止对梯度的计算和存储 ,从而减少对内存的消耗,不会进行反向传播

with torch.no_grad()并不会影响dropout和batchnorm层的行为

在这里插入图片描述

总结如下:如果不在意显存大小和计算时间的话,仅使用model.eval()已足够得到正确的validation的结果;而with torch.zero_grad()则是更进一步加速和节省gpu空间(因为不用计算和存储gradient),从而可以更快计算,也可以跑更大的batch来测试

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

非晚非晚

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值