解决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. 参考


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

相关推荐
云卓SKYDROID1 分钟前
无人机遥测系统工作与技术难点分析!
人工智能·无人机·科普·高科技·云卓科技
Start_Present6 分钟前
Pytorch 第十三回:神经网络编码器——自动编解码器
pytorch·python·深度学习·神经网络
互联网杂货铺7 分钟前
黑盒测试、白盒测试、集成测试和系统测试的区别与联系
自动化测试·软件测试·python·功能测试·测试工具·单元测试·集成测试
databook8 分钟前
线性模型与多分类问题:简单高效的力量
python·机器学习·scikit-learn
Moutai码农9 分钟前
大模型-提示词(Prompt)技巧
人工智能·语言模型·prompt
Moutai码农13 分钟前
大模型-提示词(Prompt)最佳实践
人工智能·语言模型·prompt
阿巴阿巴拉13 分钟前
Scala简介与基础语法学习总结
人工智能
阿巴阿巴拉30 分钟前
Scala相关知识总结3
开发语言·python
zxsz_com_cn32 分钟前
风电行业预测性维护解决方案:AIoT驱动下的风机健康管理革命
大数据·运维·人工智能