建完虚拟环境后 运行 pip install .
出现报错,显示svox2安装出错,然后开始进入到svox2中进行手动编译和安装。
1. cmake svox2/csrc pybind11找不到
conda install pybind11
用 pip install
在虚拟环境中安装不行,据说会安装到全局下…
2. cmake svox2/csrc时 libtorch 找不到
先conda方式安装libtorch
conda install libtorch
打开CMakeList.txt
set(CMAKE_PREFIX_PATH "/home/paper/anaconda3/envs/stega-nerf/lib/python3.8/site-packages/torch/share/cmake/Torch")
find_package(Torch REQUIRED)
CMakeLists.txt文件依据依赖的路径设置不同的两种配置方式
3. cuDNN 7 以上版本信息找不到
cudnn8及以上版本版本信息放到了上面指令中路径的另一个cudnn_version.h中,因此需要将/home/xxx/.local/lib/python3.8/site-packages/torch/share/cmake/Caffe2/public/cuda.cmake 中的第150行:
file(READ ${CUDNN_INCLUDE_PATH}/cudnn.h CUDNN_HEADER_CONTENTS)
# 修改为:
file(READ ${CUDNN_INCLUDE_PATH}/cudnn_version.h CUDNN_HEADER_CONTENTS)
高版本cudnn(cudnn8以上版本)下编译spconv的问题和解决方法
4. pip install .
仍然失败
完成以上步骤,svox2被成功build,仍然存在安装失败的问题,并且运行时产生以下报错:
AssertionError: CUDA extension is currently required for accelerate
(stega-nerf) paper@paperscmp:~/Desktop/StegaNeRF$ python setup.py install
时 出现以下报错:
真的会拴q系列… 之后百度了一下会产生这个问题的原因… 据说是因为cuda版本不对应问题… 猜想大概率是pytorch出问题了… 于是去比较了一下 该环境和我之前通用的环境中的torch版本… 确实是不一样的… emmm…
于是为开始拆掉这个conda环境进行重装,把该项目里的python版本改成3.9.9
然后执行 conda env create -f environment.yml && conda activate stega-nerf
重建环境,完成之后,手动安装pytorch:(这个是之前根据我的cuda版本对应的)
pip3 install torch==1.10.1+cu113 torchvision==0.11.2+cu113 torchaudio==0.10.1+cu113 -f https://download.pytorch.org/whl/cu113/torch_stable.html
可验证的,cuda
能正常使用。pip list
一下就可以看到以下结果:
再 pip install .
就能成功安装好啦
之后由于torch版本的原因,可能还会出现一点小问题:
AttributeError: module ‘distutils‘ has no attribute ‘version‘ 解决方案
pip uninstall setuptools
pip install setuptools==59.5.0
敲重点:每次安装环境的时候要提前看一下… 他的python版本和torch版本是否和你的cuda环境相适应… 不要一股脑地直接按着它给的yaml就装了…【大坑】
项目地址:StegaNeRF