在 Jetson 上构建
1. 安装 JetPack
JetPack 包含了运行 PyTorch 所需的 CUDA 相关库集合。
请参考 https://developer.nvidia.com/embedded/learn/get-started-jetson-agx-orin-devkit 获取最新的安装指南。
sudo bash -c 'echo "deb https://repo.download.nvidia.com/jetson/common r34.1 main" >> /etc/apt/sources.list.d/nvidia-l4t-apt-source.list'
sudo bash -c 'echo "deb https://repo.download.nvidia.com/jetson/t234 r34.1 main" >> /etc/apt/sources.list.d/nvidia-l4t-apt-source.list'
sudo apt update
sudo apt dist-upgrade
# REBOOT
sudo apt install nvidia-jetpack
检查版本
要检查已安装的版本,您可以使用以下命令;
# JetPack
$ apt list --installed | grep nvidia-jetpack
nvidia-jetpack-dev/stable,now 5.0.1-b118 arm64 [installed,automatic]
nvidia-jetpack-runtime/stable,now 5.0.1-b118 arm64 [installed,automatic]
nvidia-jetpack/stable,now 5.0.1-b118 arm64 [installed]
# CUDA
$ apt list --installed | grep cuda-toolkit
cuda-toolkit-11-4-config-common/stable,now 11.4.243-1 all [installed,automatic]
cuda-toolkit-11-4/stable,now 11.4.14-1 arm64 [installed,automatic]
cuda-toolkit-11-config-common/stable,now 11.4.243-1 all [installed,automatic]
cuda-toolkit-config-common/stable,now 11.4.243-1 all [installed,automatic]
# cuDNN
$ apt list --installed | grep cudnn
libcudnn8-dev/stable,now 8.3.2.49-1+cuda11.4 arm64 [installed,automatic]
libcudnn8-samples/stable,now 8.3.2.49-1+cuda11.4 arm64 [installed,automatic]
libcudnn8/stable,now 8.3.2.49-1+cuda11.4 arm64 [installed,automatic]
nvidia-cudnn8-dev/stable,now 5.0.1-b118 arm64 [installed,automatic]
nvidia-cudnn8-runtime/stable,now 5.0.1-b118 arm64 [installed,automatic]
2. [可选] 安装 jtop
由于 Tegra GPU 不受 nvidia-smi
命令支持,建议安装 jtop
。
只有超级用户才能安装 jtop
。因此请确保添加 -U
参数,以便运行 jtop
时不需要超级用户权限。
3. 在用户环境中安装 pip
默认情况下,pip
/ pip3
命令使用的是系统目录 /usr/bin/
中的版本,其 site-packages
目录受保护,无法在没有 sudo
权限的情况下进行修改。
一种解决方法是将 pip
安装到用户目录中。
https://forums.developer.nvidia.com/t/python-3-module-install-folder/181321
wget https://bootstrap.pypa.io/get-pip.py
python get-pip.py --user
之后请确认 pip
命令指向的是用户目录中的那个。
$ which pip
/home/USER/.local/bin/pip
4. 安装 PyTorch
自 PyTorch 1.13 和 torchaudio 0.13 起,官方并未提供适用于 Linux ARM64 的预构建二进制文件。Nvidia 提供了针对 PyTorch 的自定义预构建二进制文件,这些文件适用于特定的 JetPack。
请参考 https://docs.nvidia.com/deeplearning/frameworks/install-pytorch-jetson-platform/index.html 获取最新的 PyTorch 安装指南。
$ package=torch-1.13.0a0+340c4120.nv22.06-cp38-cp38-linux_aarch64.whl
$ wget "https://developer.download.nvidia.com/compute/redist/jp/v50/pytorch/${package}"
$ pip install --no-cache "${package}"
通过检查版本和 CUDA 设备的可访问性来验证安装。
$ python -c '
import torch
print(torch.__version__)
print(torch.cuda.is_available())
print(torch.empty((1, 2), device=torch.device("cuda")))
'
1.13.0a0+410ce96a.nv22.12
True
tensor([[0., 0.]], device='cuda:0')
5. 构建 TorchAudio
1. 安装构建工具
pip install cmake ninja
2. 安装依赖项
sudo apt install ffmpeg libavformat-dev libavcodec-dev libavutil-dev libavdevice-dev libavfilter-dev
3. 构建 TorchAudio
git clone https://github.com/pytorch/audio
cd audio
USE_CUDA=1 pip install -v -e . --no-use-pep517
4. 检查安装
import torchaudio
print(torchaudio.__version__)
torchaudio.utils.ffmpeg_utils.get_build_config()
2.0.0a0+2ead941
*-prefix=/usr --extra-version=0ubuntu0.1 --toolchain=hardened --libdir=/usr/lib/aarch64-linux-gnu --incdir=/usr/include/aarch64-linux-gnu --arch=arm64 --enable-gpl --disable-stripping --enable-avresample --disable-filter=resample --enable-avisynth --enable-gnutls --enable-ladspa --enable-libaom --enable-libass --enable-libbluray --enable-libbs2b --enable-libcaca --enable-libcdio --enable-libcodec2 --enable-libflite --enable-libfontconfig --enable-libfreetype --enable-libfribidi --enable-libgme --enable-libgsm --enable-libjack --enable-libmp3lame --enable-libmysofa --enable-libopenjpeg --enable-libopenmpt --enable-libopus --enable-libpulse --enable-librsvg --enable-librubberband --enable-libshine --enable-libsnappy --enable-libsoxr --enable-libspeex --enable-libssh --enable-libtheora --enable-libtwolame --enable-libvidstab --enable-libvorbis --enable-libvpx --enable-libwavpack --enable-libwebp --enable-libx265 --enable-libxml2 --enable-libxvid --enable-libzmq --enable-libzvbi --enable-lv2 --enable-omx --enable-openal --enable-opencl --enable-opengl --enable-sdl2 --enable-libdc1394 --enable-libdrm --enable-libiec61883 --enable-chromaprint --enable-frei0r --enable-libx264 --enable-shared