解决Pytorch的cuDNN error: CUDNN_STATUS_NOT_INITIALIZED

目录

  • [1. 问题报错](#1. 问题报错)
  • [2. 可能原因](#2. 可能原因)
    • [2.1 GPU内存不足](#2.1 GPU内存不足)
    • [2.2 缓存问题](#2.2 缓存问题)
    • [2.3 CUDA和Pytorch版本不兼容](#2.3 CUDA和Pytorch版本不兼容)
    • [2.4 CUDA和cuDNN版本不兼容](#2.4 CUDA和cuDNN版本不兼容)
  • [3. 验证CUDA是否可用](#3. 验证CUDA是否可用)
  • [4. 参考](#4. 参考)

1. 问题报错

在使用GPU加速模型训练的过程中经常会遇到这样的错误:

复制代码
RuntimeError: cuDNN error: CUDNN_STATUS_NOT_INITIALIZED

这个错误通常表示cuDNN库未能正确初始化。

2. 可能原因

2.1 GPU内存不足

在终端输入nvidia-smi查看GPU占用情况,如下图中的GPU 0几乎跑满,如果再使用该GPU运行其他占用内存较大的程序可能会报错。

复制代码
>>> nvidia-smi

2.2 缓存问题

有时,cuDNN错误可能是由于缓存问题引起的。尝试清除缓存,然后重新运行代码。可以在Python代码中使用以下代码来清除缓存:

python 复制代码
import torch
torch.cuda.empty_cache()

2.3 CUDA和Pytorch版本不兼容

不同版本的深度学习框架对CUDA和Pytorch的要求可能有所不同。在使用特定版本的框架时,查阅其文档或要求,了解所需的CUDA和Pytorch版本,并确保安装了正确的版本。

前往Pytorch官网查看版本对应关系:https://pytorch.org/get-started/previous-versions/,如果版本不匹配则需要重新安装Pytorch或者更新CUDA版本。注意同一Pytorch版本适配多个CUDA版本,具体还需要考虑cuDNN的版本,详情见下一节。

显卡的CUDA版本同样可以通过nvidia-smi进行查看:

2.4 CUDA和cuDNN版本不兼容

确保你使用的CUDA版本与cuDNN版本兼容,验证CUDA和cuDNN是否正确安装并配置。

cuDNN官网下载地址提供了二者版本对应关系:https://developer.nvidia.com/rdp/cudnn-archive

如果需要重新下载CUDA,可以前往官网下载:https://developer.nvidia.com/cuda-toolkit-archive

这篇博客记录了部分CUDA Toolkit 和cuDNN的版本对应关系:https://blog.csdn.net/tangjiahao10/article/details/125225786

3. 验证CUDA是否可用

查看CUDA是否可用命令如下:

python 复制代码
import torch
print(torch.cuda.is_available())

返回True即可用。

4. 参考


创作不易,麻烦点点赞和关注咯!

相关推荐
Eric.Lee202113 小时前
ubuntu 安装 Miniconda
linux·运维·python·ubuntu·miniconda
无心水13 小时前
【Python实战进阶】1、Python高手养成指南:四阶段突破法从入门到架构师
开发语言·python·django·matplotlib·gil·python实战进阶·python工程化实战进阶
杭州泽沃电子科技有限公司13 小时前
在线监测:为医药精细化工奠定安全、合规与质量基石
运维·人工智能·物联网·安全·智能监测
GIS数据转换器13 小时前
GIS+大模型助力安全风险精细化管理
大数据·网络·人工智能·安全·无人机
李剑一13 小时前
Python学习笔记1
python
OJAC11114 小时前
AI跨界潮:金融精英与应届生正涌入人工智能领域
人工智能·金融
机器之心14 小时前
Adam的稳+Muon的快?华为诺亚开源ROOT破解大模型训练「既要又要」的两难困境
人工智能·openai
可观测性用观测云14 小时前
观测云 MCP Server 接入和使用最佳实践
人工智能
掘金一周14 小时前
大部分人都错了!这才是chrome插件多脚本通信的正确姿势 | 掘金一周 11.27
前端·人工智能·后端
xier_ran14 小时前
深度学习:生成对抗网络(GAN)详解
人工智能·深度学习·机器学习·gan