解决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使用递归解决全排列数字示例
Feb 11 Python
python中二维阵列的变换实例
Oct 09 Python
使用Python对MySQL数据操作
Apr 06 Python
Python使用add_subplot与subplot画子图操作示例
Jun 01 Python
Python列表生成式与生成器操作示例
Aug 01 Python
python3中os.path模块下常用的用法总结【推荐】
Sep 16 Python
Python 3.x基于Xml数据的Http请求方法
Dec 28 Python
Pandas时间序列:时期(period)及其算术运算详解
Feb 25 Python
详解Pycharm与anaconda安装配置指南
Aug 25 Python
Python监听键盘和鼠标事件的示例代码
Nov 18 Python
python实现语音常用度量方法的代码详解
May 25 Python
 分享一个Python 遇到数据库超好用的模块
Apr 06 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
全国FM电台频率大全 - 31 新疆维吾尔族自治区
2020/03/11 无线电
php中通过Ajax如何实现异步文件上传的代码实例
2011/05/07 PHP
Zend Framework教程之Application和Bootstrap用法详解
2016/03/10 PHP
详解PHP安装mysql.so扩展的方法
2016/12/31 PHP
Laravel学习基础之migrate的使用教程
2017/10/11 PHP
PHP使用Session实现上传进度功能详解
2019/08/06 PHP
php设计模式之工厂方法模式分析【星际争霸游戏案例】
2020/01/23 PHP
多次注册事件会导致一个事件被触发多次的解决方法
2013/08/12 Javascript
Asp.Net alert弹出提示信息的几种方法总结
2014/01/29 Javascript
Javascript中Array.prototype.map()详解
2014/10/22 Javascript
javascript跨域方法、原理以及出现问题解决方法(详解)
2015/08/06 Javascript
极力推荐一款小巧玲珑的可视化编辑器bootstrap-wysiwyg
2016/05/27 Javascript
AngularJS框架的ng-app指令与自动加载实现方法分析
2017/01/04 Javascript
JS使用正则表达式验证身份证号码
2017/06/23 Javascript
前端把html表格生成为excel表格的实例
2017/09/19 Javascript
Vue Socket.io源码解读
2018/02/07 Javascript
javascript将非数值转换为数值
2018/09/13 Javascript
elementUI select组件默认选中效果实现的方法
2019/03/25 Javascript
详解vue-cli+element-ui树形表格(多级表格折腾小计)
2019/04/17 Javascript
监控微信小程序中的慢HTTP请求过程详解
2019/07/05 Javascript
react实现复选框全选和反选组件效果
2020/08/25 Javascript
numpy数组拼接简单示例
2017/12/15 Python
使用numpy和PIL进行简单的图像处理方法
2018/07/02 Python
python爬虫爬取淘宝商品比价(附淘宝反爬虫机制解决小办法)
2020/12/03 Python
Python爬虫中Selenium实现文件上传
2020/12/04 Python
python自动打开浏览器下载zip并提取内容写入excel
2021/01/04 Python
CSS3之transition实现下划线的示例代码
2018/05/30 HTML / CSS
使用HTML5 Canvas绘制圆角矩形及相关的一些应用举例
2016/03/22 HTML / CSS
StubHub中国:购买和出售全球活动门票
2020/01/01 全球购物
介绍一下常见的木马种类
2014/11/15 面试题
2014年音乐教师工作总结
2014/12/03 职场文书
北京英语导游词
2015/02/12 职场文书
HR必备:超全面的薪酬待遇管理方案!
2019/07/12 职场文书
mysql自增长id用完了该怎么办
2022/02/12 MySQL
数据设计之权限的实现
2022/08/05 MySQL
前端框架ECharts dataset对数据可视化的高级管理
2022/12/24 Javascript