1 问题描述
[Info] Using cuda for inference.
[Step 0] Number of frames available for inference: 9828
[Step 1] Using saved landmarks.
[Step 2] 3DMM Extraction In Video::
using expression center
Load checkpoint from: checkpoints/DNet.pt
Load checkpoint from: checkpoints/LNet.pth
Load checkpoint from: checkpoints/ENet.pth
[Step 3] Using saved stabilized video.
[Step 4] Load audio; Length of mel chunks: 2141
[Step 5] Reference Enhancement: 398.69it/s]
INTEL MKL ERROR: /root/anaconda3/lib/libmkl_vml_avx512.so.1: undefined symbol: mkl_blas4vml_dptrmm.
Intel MKL FATAL ERROR: cannot load libmkl_vml_avx512.so.1 or libmkl_vml_def.so.1.
2 问题分析
从错误信息中分析,与mkl有关,anaconda3中默认链接了一个自己的mkl库。代码中使用到mkl时,会报以下错误:
INTEL MKL ERROR: /root/anaconda3/lib/libmkl_vml_avx512.so.1: undefined symbol: mkl_blas4vml_dptrmm.
Intel MKL FATAL ERROR: cannot load libmkl_vml_avx512.so.1 or libmkl_vml_def.so.1.
查看符号表
(retalking) [root@localhost video-retalking]# nm -D /root/anaconda3/lib/libmkl_vml_avx512.so.1 |grep mkl_blas4vml_dptrmm
U mkl_blas4vml_dptrmm
尝试不同版本的mkl安装
pip install mkl==2021.1.1
pip install mkl==2024.0.0
pip install mkl==2022.1.0
安装成功后,问题依然存在。
3 问题解决
在retalking的conda环境下创建激活环境自动执行脚本:
vi /root/anaconda3/envs/retalking/etc/conda/activate.d/mkl_preload.sh
在脚本中配置LD_PRELOAD环境变量
export LD_PRELOAD=$LD_PRELOAD:/root/anaconda3/lib/libmkl_def.so.1:/root/anaconda3/lib/libmkl_avx2.so.1:/root/anaconda3/lib/libmkl_core.so.1:/root/anaconda3/lib/libmkl_intel_lp64.so.1:/root/anaconda3/lib/libmkl_intel_thread.so.1:/root/anaconda3/lib/libmkl_sequential.so.1:/root/anaconda3/lib/libiomp5.so
重新激活conda环境,环境变量已经生效
(retalking) [root@localhost video-retalking]# conda deactivate
(base) [root@localhost video-retalking]#
(base) [root@localhost video-retalking]# conda activate retalking
(retalking) [root@localhost video-retalking]#
(retalking) [root@localhost video-retalking]# echo $LD_PRELOAD
/root/anaconda3/lib/libmkl_core.so:/root/anaconda3/lib/libmkl_sequential.so
再次运行程序,不再抛出异常,问题解决。
4 conda环境介绍
Conda是一个开源的包管理器和环境管理系统,用于安装、运行和更新包和其依赖项。它是由Anaconda, Inc.(以前称为Continuum Analytics)创建,用于支持Python程序开发,但它也可以用来管理来自其他语言的包。Conda使得包管理和环境隔离变得简单,对于处理多个项目中的依赖关系和版本控制尤其有用。
Conda是一个强大的工具,对于管理复杂的Python项目和环境至关重要。它简化了包管理和环境设置,使得Python开发更加容易和高效。通过使用Conda,开发者可以确保他们的项目在不同机器和操作系统上都能以相同的方式运行,大大提高了项目的可移植性和可复现性。
4.1 Conda的核心功能
-
包管理:Conda作为包管理器,可以安装、更新和移除Python包。它通过Conda仓库,如Anaconda Cloud或Conda Forge,来获取包。
-
环境管理:Conda允许用户创建隔离的环境,以便于不同项目可以拥有不同的库和/或Python版本。这在处理不兼容的依赖项或不同项目的需求时非常有用。
-
跨平台:Conda支持Linux、OS X和Windows,并允许创建跨平台的Python环境。
-
开源: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来管理项目依赖,确保一致的开发环境。
-
教学和学术研究:教师和研究人员使用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 的信息。