当前位置: 首页 > news >正文

Jetson NX Python环境搭建:使用APT轻松安装NumPy, scikit-learn, OpenCV

引言

在NVIDIA Jetson NX等ARM架构的嵌入式AI板子上搭建Python开发环境,特别是安装像NumPy、OpenCV这样包含C/C++底层代码的科学计算库时,经常会遇到编译失败、耗时过长或依赖冲突等问题。这些问题尤其在通过pip从源代码编译安装时更为突出,例如常见的ModuleNotFoundError: No module named 'skbuild'Cython编译错误。

本文将介绍一种通过APT包管理器快速、稳定地安装NumPyscikit-learnOpenCV的方法。这种方法极大地简化了安装流程,避免了繁琐的源代码编译过程。

重要提示:
通过APT安装的OpenCV版本通常是CPU版本,不会利用Jetson板子特有的GPU(CUDA)加速。如果您对OpenCV的性能有较高要求(例如用于深度学习推理),建议考虑使用预编译的.whl文件自行编译(这两种方法更为复杂,但能发挥Jetson的硬件优势)。本文主要面向追求安装简便和稳定性的用户。

前期准备与清理

在开始之前,为了避免新旧安装方式之间的冲突,我们首先需要清除之前可能失败的pip安装尝试以及相关的缓存。

  1. 终止所有不必要的进程:
    如果你的Jetson NX当前运行着大量占用CPU和内存的服务(如ROS2节点),请务必在开始安装前停止它们。最彻底的方法是重启你的Jetson NX板子,重启后直接进入终端,不要启动任何其他应用程序。

  2. 彻底清除pip的安装残余和缓存:

    # 终止任何正在运行的 pip 命令 (如果还在运行,可按 Ctrl + C 几次)# 卸载所有可能已部分安装或失败的 Python 包
    pip3 uninstall opencv-python
    pip3 uninstall numpy
    pip3 uninstall scikit-learn
    pip3 uninstall Cython
    pip3 uninstall scikit-build# 清除 pip 的下载缓存,确保下次下载的是干净的版本
    pip3 cache purge# 删除 pip 的临时构建目录(这些通常在 /tmp 下,重启后也会自动清除)
    rm -rf /tmp/pip-build-*
    
  3. 更新系统包列表和已安装的包:
    这是一个好习惯,确保你的系统是最新的,并且可以获取到最新的软件包信息。

    sudo apt update
    sudo apt full-upgrade -y # 升级所有已安装的包,包括依赖关系
    

核心库安装 (使用APT)

现在我们可以开始使用apt来安装所需的Python库了。

  1. 安装NumPy
    NumPy是Python科学计算的基础库,提供高性能的多维数组对象和工具。

    sudo apt install -y python3-numpy
    
  2. 安装scikit-learn
    scikit-learn是一个强大的机器学习库,依赖于NumPy和SciPy。APT会自动处理这些依赖。

    sudo apt install -y python3-sklearn
    
  3. 安装OpenCV及其Python绑定:
    python3-opencv包会安装OpenCV库的核心文件以及Python 3的绑定。

    sudo apt install -y python3-opencv
    

    再次提醒: 这个通过apt安装的OpenCV版本通常是通用CPU版本,无法利用Jetson NX的GPU加速功能。如果您有高性能需求,请务必考虑其他安装方式。

验证安装

安装完成后,我们可以进入Python环境,导入这些库并检查它们的版本,以确认安装成功。

python3

在Python解释器中输入以下命令:

import numpy
print(f"NumPy Version: {numpy.__version__}")import sklearn
print(f"scikit-learn Version: {sklearn.__version__}")import cv2
print(f"OpenCV Version: {cv2.__version__}")# 简单测试一下 OpenCV 和 NumPy 功能,确保其能正常工作
import numpy as np
img = np.zeros((200, 300, 3), dtype=np.uint8) # 创建一个200x300的黑色图像
cv2.rectangle(img, (50, 50), (250, 150), (0, 255, 0), -1) # 在图像上画一个绿色矩形
cv2.imwrite("my_output_image_apt_test.png", img) # 保存图像文件
print("OpenCV (via apt) installed successfully and created my_output_image_apt_test.png")exit() # 退出 Python 解释器

如果所有命令都成功执行,并打印出了版本号,且在当前目录下生成了 my_output_image_apt_test.png 文件,那么恭喜你,你的环境已经搭建成功了!

如何运行Python文件

安装完成后,你可以像运行其他Python脚本一样运行你的文件。

假设你有一个名为my_project.py的Python文件,内容如下:

#!/usr/bin/env python3
# my_project.pyimport numpy as np
import cv2
from sklearn.linear_model import LinearRegressionprint("--- Python Script Started ---")# 使用 NumPy
arr = np.array([1, 2, 3, 4, 5])
print(f"NumPy array: {arr}")# 使用 OpenCV
img = np.zeros((150, 250, 3), dtype=np.uint8)
cv2.circle(img, (125, 75), 50, (255, 0, 0), -1) # 在图像上画一个蓝色圆形
cv2.imwrite("my_circle_image.png", img)
print("Created my_circle_image.png using OpenCV.")# 使用 scikit-learn
X_train = np.array([[1], [2], [3], [4], [5]])
y_train = np.array([2, 4, 5, 4, 5])
model = LinearRegression()
model.fit(X_train, y_train)
print(f"scikit-learn Linear Regression Coefficient: {model.coef_[0]:.2f}")print("--- Python Script Finished ---")

有以下两种常用方式运行它:

  1. 直接使用python3命令 (最常用):
    在终端中,导航到你的my_project.py文件所在的目录,然后运行:

    python3 my_project.py
    
  2. 使脚本可执行并直接运行 (Shebang方式):
    如果你想让脚本像普通程序一样直接运行,可以在脚本文件开头添加#!/usr/bin/env python3这一行,并赋予执行权限。

    • 编辑my_project.py文件,在最顶部添加#!/usr/bin/env python3
    • 给脚本添加执行权限:
      chmod +x my_project.py
      
    • 运行脚本:
      ./my_project.py
      

重要注意事项

  1. OpenCV的GPU加速: 如前所述,通过apt安装的OpenCV版本通常是CPU版本,无法利用Jetson的GPU加速。如果您对性能有较高要求:

    • 推荐方案: 寻找并安装专门为Jetson ARM架构和CUDA编译的opencv-python .whl文件。这些文件通常在NVIDIA官方社区、Qengineering等网站上提供。安装.whl文件只需几分钟,且能充分利用GPU。
    • 自行编译: 如果找不到合适的.whl文件,您可以尝试从OpenCV源代码进行编译。这个过程极其耗时且复杂,需要正确配置CMake选项来启用CUDA加速,并确保所有依赖库版本兼容。
  2. Python虚拟环境(venv): apt安装的Python包是针对系统级别的Python环境。如果你在将来使用venv(Python虚拟环境)来管理项目依赖,这些apt安装的包默认不会在虚拟环境中可用。你需要在激活虚拟环境后,使用pip install在虚拟环境中再次安装这些包(此时pip会尝试下载预编译的.whl文件或再次进行编译)。

结论

通过本文介绍的APT安装方法,你可以快速、简便地在NVIDIA Jetson NX板子上搭建起包含NumPy、scikit-learn和OpenCV的Python开发环境。尽管APT安装的OpenCV版本在GPU加速方面存在局限,但对于大多数日常开发和学习任务而言,它提供了一个稳定且易于维护的基础环境。

希望这篇教程能帮助读者们在Jetson NX上顺利开展Python开发!

http://www.lryc.cn/news/619382.html

相关文章:

  • java学习 leetcode 二分查找 图论
  • 图论理论部分
  • 【C++ STL】list详解和模拟
  • Day52--图论--101. 孤岛的总面积(卡码网),102. 沉没孤岛(卡码网),103. 水流问题(卡码网),104. 建造最大岛屿(卡码网)
  • day50 图论基础 卡码网98. 所有可达路径
  • 15-docker的企业级私有仓库之docker-harbor
  • 若依plus SpringCloud [DUBBO] 多模块异常抛出 异常里面包了一层异常
  • docker load镜像后 名字和标签异常解决
  • 【Docker项目实战】使用Docker部署todo任务管理器
  • 飞算JavaAI云原生实践:基于Docker与K8s的自动化部署架构解析
  • python环境依赖冲突问题(1)
  • Docker 在 Linux 中的额外资源占用分析
  • Java设计模式全景解析:从演进历程到创新实践
  • 【网络运维】Playbook进阶: 管理变量
  • Windows11 运行IsaacSim GPU Vulkan崩溃
  • ADB 无线调试连接(Windows + WSL 环境)
  • 药房智能盘库系统:基于CV与时间序列预测的库存革命
  • vue3 el-select el-button 在同一行显示
  • Vue:实现一个无线滚动列表的解决方案
  • 【密码学实战】国密SM2算法介绍及加解密/签名代码实现示例
  • 2021 年全国硕士研究生招生考试真题笔记
  • 若依前后端分离版学习笔记(九)——登录和操作日志
  • Android中获取状态栏高度
  • 算法题打卡力扣第11题:盛最多水的容器(mid)
  • [AI React Web]`意图识别`引擎 | `上下文选择算法` | `url内容抓取` | 截图捕获
  • 【递归、搜索与回溯算法】穷举、暴搜、深搜、回溯、剪枝
  • BGE:智源研究院的通用嵌入模型家族——从文本到多模态的语义检索革命
  • 海洋通信系统技术文档(1)
  • 高可用实战之Nginx + Apache篇
  • QT常用类解析