Pytorch运行过程中解决出现内存不足的问题

这篇具有很好参考价值的文章主要介绍了Pytorch运行过程中解决出现内存不足的问题。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1. 前提

利用Transformer模型进行O3浓度的反演

2. 问题

2.1 速度慢

一开始模型是在CPU上面跑的,为了加快速度,我改成了在GPU上跑
方法如下:
1、验证pytorch是否存在GPU版本
在Pycharm命令行输入

import torch

print(torch.cuda.is_available)
# 若输出为True,则存在GPU版本
# 若输出为False,则不存在GPU版本

我的输出为True,说明pytorch是存在GPU版本的
2、将模型从CPU版本转换到GPU版本

  • 声明使用GPU(指定具体的卡)
    PS:torch.device()是装torch.Tensor的一个空间。
device=torch.device('cuda' if torch.cuda.is_available() else 'cpu')
# 'cuda' 这里如果没有指定具体的卡号,系统默认cuda:0
device = torch.device('cuda:2') 		# 使用2号卡
  • 将模型(model)加载到GPU上
model = Transformer()	#例子中,采用Transformer模型
model.to(device)
  • 将数据和标签放到GPU上【注意!什么数据可以被放入GPU-Tensor类型的数据】
# 只有Tensor类型的数据可以放入GPU中
# 可以一个个【batch_size】进行转换
inputs = inputs.to(device)
labels = labels.to(device)

如果结果还是显示你是在CPU上进行训练,要不就是模型没有加进去,要不就是数据没有加进去

2.2 内存不足

  1. 在使用CPU时,出现了内存不足的情况

RuntimeError: [enforce fail at C:\cb\pytorch_1000000000000\work\c10\core\impl\alloc_cpu.cpp:72] data. DefaultCPUAllocator: not enough memory: you tried to allocate 280410627200 bytes.

  1. 在使用GPU时,出现了内存不足的情况

torch.cuda.OutOfMemoryError: CUDA out of memory. Tried to allocate 261.15 GiB (GPU 0; 8.00 GiB total capacity; 487.30 MiB already allocated; 5.71 GiB free; 506.00 MiB reserved in total by PyTorch) If reserved memory is >> allocated memory try sett

我的模型在训练的时候没有问题,在进行预测的时候,总是出现内存不足
(1)一开始我以为是batch_size大小的问题,在从128更改到4后,发现依旧存在问题,这说明不是batch_size大小的问题。
(2)然后,我猜测是反演过程的问题
我在进行模型反演的过程中,直接将全部数据输入到模型model中(大概有10万行),为了验证这个问题,我添加了一个for循环,一个一个数据的反演
Pytorch运行过程中解决出现内存不足的问题
问题解决!


学习链接:文章来源地址https://www.toymoban.com/news/detail-414652.html

  • pytorch 中判断和指定模型和数据在GPU或CPU上–有用
  • Pytorch | GPU | 将代码加载到GPU上运行
  • pytorch中cuda out of memory问题

到了这里,关于Pytorch运行过程中解决出现内存不足的问题的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • TinyHttpd 运行过程出现的问题

    最近拉了个 TinyHttpd 的工程下来,不过好像各个都有些改动,最后挑了篇阅读量最多的。工程也是从这里面给的链接下载的。 参考自:https://blog.csdn.net/jcjc918/article/details/42129311 拿下来在编译运行前,按这里说的,需要有些修改: 1、Makefile 文件,如果直接执行 make 的话,你会

    2024年02月05日
    浏览(28)
  • 基于WebRTC构建的程序因虚拟内存不足导致闪退问题的排查以及解决办法的探究

    目录 1、WebRTC简介 2、问题现象描述 3、将Windbg附加到目标进程上分析

    2024年02月08日
    浏览(39)
  • 微信小程序报错:运行内存不足,请重新打开该小程序

    微信小程序官方链接 https://developers.weixin.qq.com/miniprogram/dev/framework/performance/tips/runtime_memory.html 当小程序占用系统资源过高,可能会被系统销毁或被微信客户端主动回收。在 iOS 上,当微信客户端在一定时间间隔内连续收到系统内存告警时,会根据一定的策略,主动销毁小程序

    2024年02月16日
    浏览(24)
  • docker出现问题:docker所在盘存储空间不足问题

    docker使用教程相关系列 目录 docker所在盘存储空间不足问题 查看Docker容器占用的存储空间 删除不用的image或容器。 如果上面还不行,就删除大文件 查找docker目录下大于100M的文件 然后删除不必要的文件

    2024年04月16日
    浏览(22)
  • 内存不足的原因及解决方法

    实际上,剪贴板是内存中的一块临时区域,当你在程序中使用了“复制”或“剪切”命令后,Windows将把复制或剪切的内容及其格式等信息暂时存储在剪贴板上,以供“粘贴”使用。如果当前剪贴板中存放的是一幅图画,则剪贴板就占用了不少的内存。这时,请按下述步骤清除

    2024年02月11日
    浏览(37)
  • Ubuntu 20.04设置虚拟内存 (交换内存swap)解决内存不足

    数据库服务器程序在运行起来之后,系统内存不足。 在系统监控中发现,当数据库服务程序启动后,占用了大量内存空间,导致系统的剩余的内存往往只有几十MB。 在ubuntu系统中,swap空间就是虚拟内存,所以考虑在磁盘空间富余的目录下设置虚拟内存swap文件,用来缓解内存

    2024年02月06日
    浏览(41)
  • 解决uniapp运行手机基座出现的问题

    常见的问题: (往往在更新编辑器版本后会出现以下问题) 问题1.明明已经连接到手机,就是检测不到设备   问题2.同步资源失败,未得到同步资源的授权   问题1解决办法:          方法一:进入HBuilderX安装目录下pluginslaunchertoolsadbs文件夹中,替换成1..0.31里面的文件

    2024年02月16日
    浏览(37)
  • 解决Linux内存不足,无法启动elasticsearch

    众所周知,es运行非常占用内存,很多小伙伴在学习elasticsearch的时候总是因为Linux内存不足,导致es启动失败,这个时候只要指定elasticsearch的启动内存大小就可以解决了 同时给es和kibana设置指定内存限制,docker-compose.yml文件如下,我这里设置的是512m,大家设置256m也是可以的,

    2024年02月16日
    浏览(36)
  • idea中编译内存不足的解决方法

    Idea中在编译项目内存不足 问题 原因 解决方案 然后重新再build之后看看

    2024年02月14日
    浏览(25)
  • IIS由于出现权限不足而无法读取配置文件解决方案

    今天来谈一谈关于iis配置上的问题,在启动网站时,提示由于权限不足而无法读取配置,查看本地所有账户均有读写操作的权限 图上显示由于权限不足由于权限不足而无法读取配置文件,所以就从权限入手: 1、右击文件夹-属性-安全,点击编辑,添加 Everyone用户 赋予它所有

    2024年02月15日
    浏览(35)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包