解决pytorch GPU 计算过程中出现内存耗尽的问题


Posted in Python onAugust 19, 2019

Pytorch GPU运算过程中会出现:“cuda runtime error(2): out of memory”这样的错误。通常,这种错误是由于在循环中使用全局变量当做累加器,且累加梯度信息的缘故,用官方的说法就是:"accumulate history across your training loop"。在默认情况下,开启梯度计算的Tensor变量是会在GPU保持他的历史数据的,所以在编程或者调试过程中应该尽力避免在循环中累加梯度信息。

下面举个栗子:

上代码:

total_loss=0
for i in range(10000):
  optimizer.zero_grad()
  output=model(input)
  loss=criterion(output)
  loss.backward()
  optimizer.step()
  total_loss+=loss
  #这里total_loss是跨越循环的变量,起着累加的作用,
  #loss变量是带有梯度的tensor,会保持历史梯度信息,在循环过程中会不断积累梯度信息到tota_loss,占用内存

以上例子的修正方法是在循环中的最后一句修改为:total_loss+=float(loss),利用类型变换解除梯度信息,这样,多次累加不会累加梯度信息。

局部变量逗留导致内存泄露

局部变量通常在变量作用域之外会被Python自动销毁,在作用域之内,不需要的临时变量可以使用del x来销毁。

在设计Linear Layers 的时候,尽量让其规模小点

对于nn.Linear(m,n)这样规模的线性函数,他的空间规模为O(mn),除此规模的空间来容纳参数意外,还需要同样规模的空间来存储梯度,由此很容易造成GPU空间溢出。

相关的进程管理bash cmd

nvidia-smi监控GPU,

watch -n 1 nvidia-smi实时监控GPU,

watch -n 1 lscpu实时监控CPU,

ps -elf进程查看,

ps -elf | grep python查看Python子进程,

kill -9 [PID]杀死进程PID。

Referance:

Pytorch documentations

以上这篇解决pytorch GPU 计算过程中出现内存耗尽的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python 排序算法总结及实例详解
Sep 28 Python
Flask框架的学习指南之用户登录管理
Nov 20 Python
快速入门python学习笔记
Dec 06 Python
Python tornado队列示例-一个并发web爬虫代码分享
Jan 09 Python
Python实现京东秒杀功能代码
May 16 Python
python3 打印输出字典中特定的某个key的方法示例
Jul 06 Python
简单了解python的break、continue、pass
Jul 08 Python
Pytorch Tensor的索引与切片例子
Aug 18 Python
Python:type、object、class与内置类型实例
Dec 25 Python
学点简单的Django之第一个Django程序的实现
Feb 24 Python
python之np.argmax()及对axis=0或者1的理解
Jun 02 Python
python实现A*寻路算法
Jun 13 Python
将Pytorch模型从CPU转换成GPU的实现方法
Aug 19 #Python
pytorch 使用单个GPU与多个GPU进行训练与测试的方法
Aug 19 #Python
在pytorch中为Module和Tensor指定GPU的例子
Aug 19 #Python
pytorch使用指定GPU训练的实例
Aug 19 #Python
关于pytorch多GPU训练实例与性能对比分析
Aug 19 #Python
pytorch 更改预训练模型网络结构的方法
Aug 19 #Python
pytorch打印网络结构的实例
Aug 19 #Python
You might like
在MongoDB中模拟Auto Increment的php代码
2011/03/06 PHP
php在文件指定行中写入代码的方法
2012/05/23 PHP
PHP5中GD库生成图形验证码(有汉字)
2013/07/28 PHP
php获得url参数中具有&的值的方法
2014/03/05 PHP
phplist及phpmailer(组合使用)通过gmail发送邮件的配置方法
2016/03/30 PHP
PHP7.1新功能之Nullable Type用法分析
2016/09/26 PHP
用js生产批量批处理执行命令
2008/07/28 Javascript
jQuery 选择器理解
2010/03/16 Javascript
等待指定时间后自动跳转或关闭当前页面的js代码
2013/07/09 Javascript
利用jq让你的div居中的好方法分享
2013/11/21 Javascript
javascript匿名函数实例分析
2014/11/18 Javascript
jQuery实现的分页功能示例
2017/01/22 Javascript
vue 怎么创建组件及组件使用方法
2017/07/27 Javascript
JS去掉字符串末尾的标点符号及删除最后一个字符的方法
2017/10/24 Javascript
浅析Javascript中双等号(==)隐性转换机制
2017/10/27 Javascript
BootStrap TreeView使用实例详解
2017/11/01 Javascript
Vue的elementUI实现自定义主题方法
2018/02/23 Javascript
微信小程序swiper实现滑动放大缩小效果
2018/11/15 Javascript
JavaScript async/await原理及实例解析
2020/12/02 Javascript
Python获取远程文件大小的函数代码分享
2014/05/13 Python
在Python中使用SimpleParse模块进行解析的教程
2015/04/11 Python
python中requests使用代理proxies方法介绍
2017/10/25 Python
Python实现列表删除重复元素的三种常用方法分析
2017/11/24 Python
Python字典中的值为列表或字典的构造实例
2019/12/16 Python
DRF使用simple JWT身份验证的实现
2021/01/14 Python
HTML5 Canvas像素处理使用接口介绍
2012/12/02 HTML / CSS
详解如何解决H5开发使用wx.hideMenuItems无效果不生效
2021/01/20 HTML / CSS
Abe’s of Maine:自1979以来销售相机和电子产品
2016/11/21 全球购物
Tiqets英国:智能手机上的文化和娱乐门票
2019/07/10 全球购物
银行员工辞职信范文
2014/01/20 职场文书
学生手册评语
2014/05/05 职场文书
统计专业自荐书
2014/07/06 职场文书
合伙经营协议书范本(通用版)
2014/12/03 职场文书
质量保证书格式模板
2015/02/27 职场文书
2015年高校保卫处工作总结
2015/07/23 职场文书
升学宴家长致辞
2015/07/27 职场文书