GPU显存老是溢出的问题

最近在跑实验的时候,遇到模型训练到一定step,GPU memory溢出的问题,刚开始想调batch size,从96->48->24,一方面还是会溢出,另一方面训练的时间会成倍数地增加,目前用的是6张GPU进行训练,即DUDA_VISIABLE_DEVICES = 0,1,2,3,4,5

解决思路:
第一个问题是为什么模型会跑着跑着中途显存溢出?

显存占用主要存在于数据输入,模型参数,中间变量以及pytorch自身消耗,模型参数根据不同的优化器可能会有倍数增加,因为涉及到梯度回传,比如adam最终内存消耗一般是参数的4倍。

关于显存溢出:https://www.jianshu.com/p/28581e8ee6c7
显存去哪儿了?http://www.aibbt.com/a/44242.html?from=groupmessage

监测显存变化:watch -n 1 nvidia-smi

优化方式
(1)model里面不过多引入中间变量
(2)临时变量及时del
(3)小心自己模型里面写的for循环,对于不依赖于i的操作,提至循环外
(4)部分语句
hidden_tmp = (hidden @ self.weight_W_a).unsqueeze(1).repeat(1,steps,1) 变为
hidden_tmp = (hidden @ self.weight_W_a)[:,None,:]
(5)对于改动LSTM,for循环里面调用nn.LSTMCell rather than nn.LSTM

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

猴猴猪猪

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

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

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

打赏作者

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

抵扣说明:

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

余额充值