pytorch相关报错【报错】

news2024/12/25 13:37:22

AttributeError: cannot assign module before Module.init() call

  • 原因:自定义类中缺少supre()函数
    在这里插入图片描述
  • 解决
    在这里插入图片描述

KeyError: tensor(1)

报错原因:tensor不能作为字典的键
解决:转化为numpy

x = torch.tensor([1,2,3])
y = {1:'1',2:'2',3:'3'}
z = [y[i] for i in x.numpy()]

CUDA out of memory.

  • 背景:使用clip处理数据,想要得到50w个句子的clip特征,每个句子是单独处理的。处理到300多的时候出现cuda out of memory错误。理论上不应该呀。
  • 解决:

1)是否有没有杀干净的进程
2)batch size过大,调小
3)及时清理缓存,在报错的位置/新一轮epoch开始的时候

import torch, gc

gc.collect()
torch.cuda.empty_cache()

4 ) 验证的时候去掉梯度计算

def test(model,dataloader):
    model.eval()
    with torch.no_grad(): ###插在此处
        for batch in tqdm(dataloader):
			……

5 ) dataloader中的pin_memory设置为false
参考链接:pytorch cuda out of memory的四种解决方案

RuntimeError: CUDA error: initialization error

  • 定位
def train_collate_fn(data):
    data.sort(key=lambda x: x[-1], reverse=True)

    # videos, regions, spatials, captions, pos_tags, lengths, video_ids = zip(*data)
    videos, text_feature, captions, svb, mlm_input, mlm_cap, length, video_id = zip(*data)

    print(f'video:{videos[0].device}, text:{text_feature[0].device}, mlm:{mlm_cap[0].device}, cap:{captions[0].device}')

    videos = torch.stack(videos, 0)
    # regions = torch.stack(regions, 0)
    # spatials =torch.stack(spatials, 0)
    text_feature = torch.stack(text_feature, 0)   # 这一行报错
    captions = torch.stack(captions, 0)
    svb = torch.stack(svb, 0)
    mlm_input = torch.stack(mlm_input, 0)
    mlm_cap = torch.stack(mlm_cap, 0)
    # pos_tags = torch.stack(pos_tags, 0)
    # return videos, regions, spatials, captions, pos_tags, lengths, video_ids
    print(videos[0].dtype)
    return videos,text_feature, captions, svb, mlm_input, mlm_cap, length, video_id

在这里插入图片描述

  • 原因:在text_feature传入dataloader之前就已经在GPU上,导致初始化失败。因为这里的text_feature是使用clip模型得到的文本特征,模型和数据在gpu上,得到的结果也在gpu上,将其写入pkl文件之后读出没想到device还是gpu。
  • 解决:在数据放入dataloader之前,device应该是cpu。将数据使用.cpu()转换到cpu上
  • 参考资料:
    RuntimeError: CUDA error: initialization error
    【Pytorch】RuntimeError: CUDA error: initialization error

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/622619.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

提交arxiv的格式调整与流程

提交arxiv的格式调整与流程 进入arxiv网站(注册或登录): https://arxiv.org/ 点击发布submission 上传本地资源,完成以下步骤: 许可证一般需要选: 这个表示最小的利益冲突,因为我们最后肯定希望publi…

如何在项目中优雅的抛出异常,这些知识佬们还记得嘛

前言: 本篇文章主要讲解Java中的几种异常关键字和异常类相关知识。该专栏比较适合刚入坑Java的小白以及准备秋招的大佬阅读。 如果文章有什么需要改进的地方欢迎大佬提出,对大佬有帮助希望可以支持下哦~ 小威在此先感谢各位小伙伴儿了😁 以…

lua编程——air724二次开发之点亮led教程

一.硬件 硬件型号:银尔达 Core-Air724模块; 杜邦线若干; micro Usb线; USB转TTL工具; 杜邦线用于电源(12V/1A)和TTL信号连接,micro Usb用于下载和调试。 硬件资源,如下图: 二.软件 u…

❤️最详细的Python学习路线-图文不废话

当谈论学习Python编程时,有许多不同的途径和资源可供选择。为了帮助你建立起一个学习Python的有效路线,下面是一个包含基本步骤和关键资源的建议。请注意,这只是一个指南,你可以根据自己的兴趣和学习风格进行调整。 ❝ 以下时间不…

推荐对象转换解决方案:MapStruct

1、什么是MapStruct 1.1 JavaBean 的困扰 对于代码中 JavaBean之间的转换, 一直是困扰我很久的事情。在开发的时候我看到业务代码之间有很多的 JavaBean 之间的相互转化, 非常的影响观感,却又不得不存在。我后来想的一个办法就是通过反射&a…

Django新手必看:从入门到精通Web应用开发①【文末送书三本】

Django新手必看:从入门到精通Web应用开发① 1. Django是什么1.2 Django的由来1.3 Django的命名1.4 Django的版本发布1.5 Django框架的特点 2 Django的设计模式2.1 MVC设计模式2.2 MTV设计模式 3 Django安装与配置3.1 Python支持版本:3.2 Django 3.2与4.1…

Filter设计模式,责任链模式一如既往的妙

场景1: 每种Filter进行某种处理,将各个Filter连在一起形成一个FilterChain。当需要往FilterChain中加入新的Filter,或者改变各个Filter的处理顺序时,可以方便的扩展。 1个接口: public interface Filter {public Str…

前端技术搭建拼图小游戏(内含源码)

The sand accumulates to form a pagoda ✨ 写在前面✨ 功能介绍✨ 页面搭建✨ 样式设置✨ 逻辑部分 ✨ 写在前面 上周我们实通过前端基础实现了俄罗斯方块游戏,今天还是继续按照我们原定的节奏来带领大家完成一个拼图游戏,功能也比较简单简单&#xff…

chatgpt赋能python:Python数组:如何使用Python将数据存入数组中

Python数组:如何使用Python将数据存入数组中 Python是一个非常强大的高级编程语言,在人工智能、数据科学和机器学习等领域有广泛应用。Python允许将数据存储在不同的数据结构中,其中,数组是最常用的。 在这篇文章中,…

卡尔曼滤波与组合导航原理(一)滤波的基本概念、递推最小二乘

文章目录 一、滤波的基本概念1、传统数字滤波器2、现代控制中的状态观测器3、最优估计的含义4、温度估计的例子1.问题描述2.分析 二、递推最小二乘 课程链接:https://www.bilibili.com/video/BV11K411J7gp/?p1 参考书目:《捷联惯导算法与组合导航原理》…

微信小程序nodejs+vue+uniapp大学体育场馆场地预约系统

开发语言 node.js 框架:Express 前端:Vue.js 数据库:mysql 数据库工具:Navicat 开发软件:VScode 本文以nodejs为开发技术,一开始,本文就对系统内谈到的基本知识,从整体上进行了描述&#xff0c…

人事管理项目-部门数据删除

人事管理项目-部门数据删除 后端实现前端实现 Spring Boot是一个框架,一种全新的编程规范,它的产生简化了框架的使用,所谓简化是指简化了Spring众多框架中所需的大量且烦琐的配置文件,所以Spring Boot是一个服务于框架的框架&…

Netty之Channel解读

目录 channel 的主要作用 ChannelFuture CloseFuture 为什么要异步关闭 channel 的主要作用 close() 可以用来关闭 channelcloseFuture() 用来处理 channel 的关闭 sync 方法作用是同步等待 channel 关闭而 addListener 方法是异步等待 channel 关闭pipeline() 方法添加处理…

使用CodeAnt查找并修复IDE中的开源漏洞与许可证合规问题

不断加快的开发步伐正在将软件安全的责任转移到开发人员的桌面上,但是处理在下游构建和测试中检测到的安全问题可能是非常具有破坏性的。直至报告漏洞的时候,开发人员已经转移到他们的下一个任务。为了修复问题,他们必须中断正在做的事情&…

【OpenAI】Python:基于 Gym-CarRacing 的自动驾驶项目(4) | 车辆控制功能的实现

猛戳!跟哥们一起玩蛇啊 👉 《一起玩蛇》🐍 ​ 💭 写在前面:本篇是关于多伦多大学自动驾驶专业项目的博客。GYM-Box2D CarRacing 是一种在 OpenAI Gym 平台上开发和比较强化学习算法的模拟环境。它是流行的 Box2D 物…

Faiss PQ 乘积量化

Approximate Nearest Neighbor搜索简称ANN。 从宏观上看ANN brute-force搜索的方式是在全空间进行搜索,为了加快查找的速度,几乎所有的ANN方法都是通过对全空间分割,将其分割成很多小的子空间,在搜索的时候,通过某种…

爬虫分布式爬虫部署知识详解

分布式爬虫是指将一个爬虫任务分解成多个子任务,由多个爬虫节点同时执行,以提高爬取效率和速度的一种爬虫方式。下面是分布式爬虫部署的详细步骤: 确定爬虫任务:首先需要确定要爬取的网站和数据,以及需要爬取的频率和深…

公牛33W车充评测 | 拓尔微 IM2403+TMI3451快充方案实力在线

本期嘉宾是我们的老熟人 公牛PD 33W的车载充电器,此前我们对其进行过拆解,那它的充电表现和各方面性能到底如何呢? 下面我们将围绕协议测试、供电方案和产品测试展开评测解读,帮助小伙伴们全方位了解这款1A1C双口快充车充及相应的…

maven私服搭建详细教程(看完必会)

目录 1 为什么需要私服 2 Nexus私服 2.1 Nexus下载及登录 2.2 maven仓库 2.2.1 代理仓库 2.2.2 宿主仓库 2.2.3 仓库组 3 本地Maven下载构建 3.1 pom.xml方式 3.2 镜像方式 4 本地依赖发布到私服 4.1 maven部署到nexus私服 4.1.1 快照版本 ​4.1.2 release版本 4.2 …

Jar包下载失败的解决方案

Jar包下载失败的解决方案 🔎配置阿里源🔎重新下载Jar包🔎结尾 🔎配置阿里源 点击 Settings 搜索 Maven 进行如下修改 注意🍭 User settings file 路径与 Local repository 路径中应尽量避免出现中文 搜索 User setti…