Window on arm上编译pytorch


pip无法安装,想自己编译,并且有错误的都可以看这篇

1、下载pytorch源码

git clone --recursive https://github.com/pytorch/pytorch.git
cd pytorch
git submodule sync
git submodule update --init --recursive --jobs 0

2、创建编译文件夹

通过设置配置或者修改cmakelists的配置来关闭一些不支持的功能
在目录中打开cmd

set SLEEF_ARCH_AARCH64=
交叉编译 PyTorch 是一项复杂的任务,通常用于在一种架构(如 x86)上为另一种架构(如 ARM)构建 PyTorch 库。这在嵌入式系统、边缘计算或特定硬件平台上部署 PyTorch 模型时非常有用。 --- ### 🧩 一、交叉编译 PyTorch 的主要步骤 #### 1. **准备交叉编译环境** 你需要一个支持目标平台的交叉编译工具链。例如: - ARM:使用 `arm-linux-gnueabi-gcc` 或 `aarch64-linux-gnu-gcc` - RISC-V:使用 `riscv64-unknown-linux-gnu-gcc` 安装交叉编译工具链(以 ARM 为例): ```bash sudo apt-get install gcc-arm-linux-gnueabi ``` #### 2. **设置交叉编译配置** 你需要为 CMake 指定交叉编译工具链文件(toolchain file),例如: ```cmake # toolchain-arm.cmake set(CMAKE_SYSTEM_NAME Linux) set(CMAKE_SYSTEM_PROCESSOR arm) set(CMAKE_C_COMPILER arm-linux-gnueabi-gcc) set(CMAKE_CXX_COMPILER arm-linux-gnueabi-g++) set(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER) set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY) set(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY) set(CMAKE_FIND_ROOT_PATH_MODE_PACKAGE ONLY) ``` #### 3. **获取 PyTorch 源码** ```bash git clone https://github.com/pytorch/pytorch.git cd pytorch git submodule update --init --recursive ``` #### 4. **配置并构建** ```bash mkdir build && cd build cmake -DCMAKE_TOOLCHAIN_FILE=../toolchain-arm.cmake .. make -j$(nproc) ``` > ⚠️ 注意:PyTorch 依赖项较多(如 BLAS、OpenMP、CUDA 等),需要确保目标平台支持这些依赖。 --- ### 🧱 二、交叉编译的注意事项 1. **依赖项管理** - 所有依赖库(如 protobuf、eigen、openblas)也需要交叉编译。 - 推荐使用 `conan` 或 `vcpkg` 等包管理器简化依赖管理。 2. **禁用不需要的模块** 如果你只需要 PyTorch 的推理功能,可以关闭训练相关模块: ```bash cmake -DUSE_CUDA=OFF -DUSE_DISTRIBUTED=OFF -DBUILD_TEST=OFF ... ``` 3. **使用 Docker 或虚拟机** 为了确保环境一致性,推荐使用 Docker 容器进行交叉编译: ```dockerfile FROM arm32v7/ubuntu:20.04 RUN apt-get update && apt-get install -y build-essential cmake ... ``` 4. **PyTorch Lite** 如果目标平台资源受限,可以考虑使用 [PyTorch Lite](https://pytorch.org/blog/introducing-pytorch-lite/),它是一个轻量级的 PyTorch 子集,更适合嵌入式部署。 --- ### 🧪 三、验证交叉编译结果 1. **在目标平台运行测试** 将编译好的库文件(如 `libtorch.so`)拷贝到目标设备上,运行简单的 PyTorch 推理测试: ```python import torch x = torch.randn(1, 3, 224, 224) print(x.device) ``` 2. **使用 C++ 示例验证** 编译 `libtorch` 后,可以使用 C++ 示例测试: ```cpp #include <torch/torch.h> int main() { torch::Tensor tensor = torch::rand({2, 3}); std::cout << tensor << std::endl; return 0; } ``` --- ### 🧰 四、替代方案(更简单) 如果你只是需要在目标平台运行 PyTorch 模型,而不一定非要交叉编译整个 PyTorch: - 使用 **TorchScript** 导出模型(`.pt` 文件),然后在目标平台加载: ```python script_model = torch.jit.script(model) torch.jit.save(script_model, "model.pt") ``` - 在目标平台使用 **PyTorch 官方预编译 wheel**(如果支持): ```bash pip install torch --index-url https://download.pytorch.org/whl/cpu ``` --- ### 📚 五、参考资料 - PyTorch 官方文档:https://pytorch.org/docs/stable/index.html - PyTorch GitHub 仓库:https://github.com/pytorch/pytorch - CMake 交叉编译指南:https://cmake.org/cmake/help/latest/manual/cmake-toolchains.7.html ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值