conda环境下Torch not compiled with CUDA enabled解决方法

1 问题描述

在运行wav2lip模型训练时,报如下错误:

Traceback (most recent call last):
  File "D:\ml\Wav2Lip\preprocess.py", line 32, in <module>
    fa = [face_detection.FaceAlignment(face_detection.LandmarksType._2D, flip_input=False, 
  File "D:\ml\Wav2Lip\preprocess.py", line 32, in <listcomp>
    fa = [face_detection.FaceAlignment(face_detection.LandmarksType._2D, flip_input=False, 
  File "D:\ml\Wav2Lip\face_detection\api.py", line 62, in __init__
    self.face_detector = face_detector_module.FaceDetector(device=device, verbose=verbose)
  File "D:\ml\Wav2Lip\face_detection\detection\sfd\sfd_detector.py", line 28, in __init__
    self.face_detector.to(device)
  File "D:\.conda\wav2lip\lib\site-packages\torch\nn\modules\module.py", line 987, in to
    return self._apply(convert)
  File "D:\.conda\wav2lip\lib\site-packages\torch\nn\modules\module.py", line 639, in _apply
    module._apply(fn)
  File "D:\.conda\wav2lip\lib\site-packages\torch\nn\modules\module.py", line 662, in _apply
    param_applied = fn(param)
  File "D:\.conda\wav2lip\lib\site-packages\torch\nn\modules\module.py", line 985, in convert
    return t.to(device, dtype if t.is_floating_point() or t.is_complex() else None, non_blocking)
  File "D:\.conda\wav2lip\lib\site-packages\torch\cuda\__init__.py", line 221, in _lazy_init
    raise AssertionError("Torch not compiled with CUDA enabled")
AssertionError: Torch not compiled with CUDA enabled

2 问题分析

从错误信息描述中可知

AssertionError: Torch not compiled with CUDA enabled

运行环境中有GPU,而安装的torch版本是非CUDA编译的版本,需要安装CUDA编译的版本。

3 问题解决

访问pytorch的官网,地址如下:https://pytorch.org/get-started/previous-versions/

查找对应的版本进行安装:

conda install pytorch==1.13.1 torchvision==0.14.1 torchaudio==0.13.1 pytorch-cuda=11.7 -c pytorch -c nvidia

再次运行模型训练,不再报错。

 

  4 conda环境介绍

Conda是一个开源的包管理器和环境管理系统,用于安装、运行和更新包和其依赖项。它是由Anaconda, Inc.(以前称为Continuum Analytics)创建,用于支持Python程序开发,但它也可以用来管理来自其他语言的包。Conda使得包管理和环境隔离变得简单,对于处理多个项目中的依赖关系和版本控制尤其有用。

7fe216bee95143b88dd373480ba452ee.webp

Conda是一个强大的工具,对于管理复杂的Python项目和环境至关重要。它简化了包管理和环境设置,使得Python开发更加容易和高效。通过使用Conda,开发者可以确保他们的项目在不同机器和操作系统上都能以相同的方式运行,大大提高了项目的可移植性和可复现性。

4.1 Conda的核心概念

  • 包管理:Conda作为包管理器,能够安装、更新和卸载软件包。这些包可能包含Python或其他编程语言的库和应用程序。Conda通过包含所有依赖性的方式来解决包之间的依赖关系问题。

  • 环境管理:Conda允许用户创建隔离的环境,以便在不同的项目之间切换,而不会导致依赖项或版本的冲突。每个环境都有自己的一套独立的安装的软件包。

  • 跨平台:Conda是跨平台的,可以在Windows、macOS和Linux操作系统上运行。这使得在不同操作系统上保持一致的开发和部署环境成为可能。

  • 语言无关性:虽然Conda最初是为Python生态系统设计的,但它实际上是语言无关的,可以管理多种编程语言的软件包。

  • 通道(Channels):Conda软件包可以从所谓的“通道”中获得。这些通道是包存储库,可以是公共的或私有的。Anaconda Cloud提供了许多预建的包,而用户也可以创建自己的通道来托管和分享包。

  • 依赖和兼容性管理:Conda在安装软件包时会自动处理依赖关系和版本控制,确保所有依赖项都兼容,并且不会发生冲突。

4.2 使用Conda的优势

  • 解决依赖性问题:Conda可以自动解决包之间的依赖关系,简化了安装过程。

  • 环境隔离:创建独立的环境可以避免包之间的版本冲突,使得项目更稳定。

  • 易于使用:Conda的命令行界面简单直观,易于学习和使用。

  • 广泛的包支持:Conda支持Python的许多流行库和应用程序。

  • 社区支持:作为一个流行的工具,Conda拥有一个活跃的社区,用户可以从中找到支持和资源。

4.3 Conda环境的创建和管理

  • 创建新环境:使用conda create命令创建一个新环境,可以指定Python版本和所需的包。

  • 激活环境:使用conda activate命令来激活环境。

  • 安装包:在激活的环境中使用conda install命令来安装新的包。

  • 环境列表:使用conda env list来查看所有可用的Conda环境。

  • 移除环境:使用conda env remove命令来移除不再需要的环境。

4.4 应用场景

Conda作为一个强大的包和环境管理工具,广泛应用于需要精确控制依赖和环境的各种软件开发和科学计算领域,主要包括:

  • 数据科学和机器学习项目:由于Conda可以轻松安装和管理各种数据科学和机器学习的库(如NumPy, Pandas, Scikit-learn, TensorFlow, PyTorch等),它成为了这些领域专家的首选工具。

  • 多语言项目:对于涉及Python、R、Ruby、Lua、Scala等多种编程语言的项目,Conda能够有效管理不同语言的依赖和环境,使项目维护变得更加简单。

  • 环境隔离:在需要为不同项目创建隔离的运行环境时,Conda可以创建独立的环境,每个环境具有不同的库和版本,这有助于防止依赖冲突。

  • 跨平台开发:由于Conda支持Windows、macOS和Linux,它允许开发者在不同的操作系统上以一致的方式设置和维护他们的开发环境。

  • 科学研究:在科学研究中,需要使用特定版本的软件和库来重现实验结果。Conda可以确保这些环境的一致性和可复制性。

  • 软件开发:对于需要确保应用程序在特定版本的库上正常运行的开发场景,Conda可以帮助管理和锁定这些依赖。

  • 教育和培训:在教育场景中,Conda可以帮助创建统一的学习环境,确保所有学生都在相同的软件设置下学习。

  • 持续集成/持续部署(CI/CD):在自动化构建和部署流程中,Conda可以用于创建和管理构建环境,确保软件在不同环境中的一致性和可靠性。

4.5 常用命令

Conda 是一个开源的包管理器和环境管理器,广泛用于管理Python环境和包。以下是一些常用的 Conda 命令:

  • 安装 Conda 包:

    • conda install [package-name]: 安装指定的包。
  • 创建和管理环境:

    • conda create --name [env-name]: 创建一个新的环境。
    • conda activate [env-name]: 激活指定环境。
    • conda deactivate: 退出当前环境。
    • conda env list: 列出所有可用的环境。
  • 管理包:

    • conda list: 在当前环境中列出所有已安装的包。
    • conda update [package-name]: 更新指定的包。
    • conda remove [package-name]: 移除指定的包。
  • 搜索包:

    • conda search [package-name]: 搜索可用的包版本。
  • 环境导出和导入:

    • conda env export > environment.yml: 导出当前环境的配置到一个YAML文件。
    • conda env create -f environment.yml: 使用YAML文件创建一个新环境。
  • 更新 Conda:

    • conda update conda: 更新 Conda 到最新版本。
  • 查看 Conda 信息:

    • conda info: 显示关于 Conda 的信息。

 

当您收到 "torch not compiled with CUDA enabled" 的错误消息时,这意味着您正在尝试在支持CUDA环境中运行PyTorch,但是PyTorch的实际构建并未包括CUDA功能。 **详细解释及解决步骤:** ### 解释: - **PyTorch**:是一个用于深度学习和其他计算任务的强大工具包。 - **CUDA**:是一种并行计算平台和API,由NVIDIA提供,旨在让开发者利用GPU硬件加速计算。 当你安装了PyTorch并且系统中已经安装了CUDA驱动程序和相应的库文件(例如cuDNN),但是在尝试运行某些依赖CUDA的功能时出现了上述错误,这通常意味着在原始的PyTorch编译过程中,没有启用CUDA选项。 ### 解决步骤: 1. **确认环境配置**:首先检查您的Python环境是否确实包含CUDA版本的PyTorch。可以通过在命令行中输入 `python -c "import torch; print(torch.__version__)"` 来查看已安装的PyTorch版本,并注意其版本信息是否显示支持CUDA。 2. **安装CUDAPyTorch**: 如果没有安装CUDA版的PyTorch,你需要重新安装它。通常需要指定正确的`TORCH_CUDA_ARCH_LIST`选项来确保兼容您的GPU架构。例如,对于包含单个现代GPU的系统,命令可能如下所示: ```bash pip install torch==1.10.0+cu113 torchvision==0.11.0+cu113 torchaudio==0.10.0 -f https://download.pytorch.org/whl/cu113/torch_stable.html ``` 这里假设你使用的CUDA版本是11.3,具体的版本号可能会有所不同,请查阅PyTorch官方文档获取最新指南。 3. **检查安装日志**:如果你之前曾经尝试过安装,可以检查安装过程的日志文件(通常是`pip.log`或`install.log`)来看是否有关于未启用CUDA的提示信息。 4. **验证GPU支持**:使用`nvidia-smi`命令检查你的系统是否能够识别GPU及其版本号和是否支持CUDA。 5. **重新启动环境**:有时候,重启你的终端或开发环境会帮助解决一些临时的安装问题。 6. **更新或刷新依赖项**:有时,清理或刷新依赖项(如通过运行`conda clean --all` 或使用pip的清理命令)可以帮助解决问题。 ### 额外资源和相关问题: - **如何选择正确的CUDA版本?** - **为什么我的GPU型号不被支持?** - **如果我没有足够的GPU内存怎么办?** 通过按照上述步骤操作,你应该能成功解决 "torch not compiled with CUDA enabled" 的问题,并能够在CUDA环境下有效使用PyTorch
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

智慧医疗

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值