Deepstream6.0-Jetpark4.6-yolov5-v6.0-tensorRT-Jetson-xavier-nx项目部署环境搭建

本文主要是介绍Deepstream6.0-Jetpark4.6-yolov5-v6.0-tensorRT-Jetson-xavier-nx项目部署环境搭建,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 开机后,给root用户设置密码:

Jetback在4.6版本改动较多,对应的Deepstream也增加了python版本的插件

sudo passwd root

Root用户下python3的版本对应的应该是3.6.9
检测python版本:
python3 –V
如果需要固定版本,将软连接指向python3.6
输入Python3进入python环境
Import tensorrt然后回车检测是否安装的有trt

tensorRT安装

假如烧录后,检测是否存在trt的时候,发现环境中没有tensorrt需要自己安装,安装需要英伟达账号登录,连接地址 :
TensorRT7.2.3
https://developer.nvidia.com/compute/machine-learning/tensorrt/secure/7.2.3/tars/TensorRT-7.2.3.4.Ubuntu-18.04.x86_64-gnu.cuda-11.1.cudnn8.1.tar.gz
解压,将 TensorRT 库放到系统环境,然后安装 TensorRT python 接口:
cd /python
cd …/uff
pip install uff-0.6.9-py2.py3-none-any.whl

系统查看

#驱动版本

head -n 1 /etc/nv_tegra_release

#内核版本查看命令:uname -r
#操作系统查看命令:lsb_release -i -r
#CUDA版本查看命令:nvcc -V
#cuDNN版本查看命令:dpkg -l libcudnn8
#opencv版本查看命令:dpkg -l libopencv / pkg-config opencv --modversion
#Tensorrt版本查看:dpkg -l tensorrt

2. CUDA配置

将下载好的CUDA转移到Jetson,或者可检测以下Jetson是否内置了CUDA,大部分都已经是内置了只要配置一下环境变量即可。

vim ~/.bashrc

#在最后面添加

export PATH=/usr/local/cuda-10.2/bin${PATH:+:${PATH}}
export LD_LIBRARY_PATH=/usr/local/cuda-10.2/lib64${LD_LIBRARY_PATH:+:${LD_LIBRARY_PATH}}
export CUDA_ROOT=/usr/local/cuda

#刷新,让配置生效

Source ~/.bashrc

换源
#备份原有软件源

sudo cp /etc/apt/sources.list /etc/apt/sources.list.bak
sudo vi /etc/apt/sources.list 

#清华源

deb http://mirrors.tuna.tsinghua.edu.cn/ubuntu-ports/ bionic main multiverse restricted universe
deb http://mirrors.tuna.tsinghua.edu.cn/ubuntu-ports/ bionic-security main multiverse restricted universe
deb http://mirrors.tuna.tsinghua.edu.cn/ubuntu-ports/ bionic-updates main multiverse restricted universe
deb http://mirrors.tuna.tsinghua.edu.cn/ubuntu-ports/ bionic-backports main multiverse restricted universe
deb-src http://mirrors.tuna.tsinghua.edu.cn/ubuntu-ports/ bionic main multiverse restricted universe
deb-src http://mirrors.tuna.tsinghua.edu.cn/ubuntu-ports/ bionic-security main multiverse restricted universe
deb-src http://mirrors.tuna.tsinghua.edu.cn/ubuntu-ports/ bionic-updates main multiverse restricted universe
deb-src http://mirrors.tuna.tsinghua.edu.cn/ubuntu-ports/ bionic-backports main multiverse restricted universe

更新

sudo apt-get update

3. 安装pip3

sudo apt-get update
sudo apt-get install python3-pip python3-dev –y

4. 安装一些库和工具

sudo -H pip3 install jetson-stats
sudo apt-get install build-essential make cmake cmake-curses-gui -y
sudo apt-get install git g++ pkg-config curl -y
sudo apt-get install libatlas-base-dev gfortran libcanberra-gtk-module libcanberra-gtk3-module -y
sudo apt-get install nano locate screen –y
sudo apt-get install libfreetype6-dev -y
sudo apt-get install protobuf-compiler libprotobuf-dev openssl -y
sudo apt-get install libssl-dev libcurl4-openssl-dev -y
sudo apt-get install cython3 –y
sudo apt-get install build-essential -y
sudo apt-get install cmake git libgtk2.0-dev pkg-config libavcodec-dev libavformat-dev libswscale-dev -y
sudo apt-get install python-dev python-numpy libtbb2 libtbb-dev libjpeg-dev libpng-dev libtiff5-dev libdc1394-22-dev -y
sudo apt-get install libavcodec-dev libavformat-dev libswscale-dev libv4l-dev liblapacke-dev -y
sudo apt-get install libxvidcore-dev libx264-dev -y
sudo apt-get install libatlas-base-dev gfortran -y
sudo apt-get install ffmpeg -y
sudo apt-get install libopenmpi2
sudo apt-get install libopenblas-dev
sudo apt-get install libjpeg-dev zlib1g-dev
sudo apt-get install python-gi-dev

5. 安装CMake

wget http://www.cmake.org/files/v3.13/cmake-3.13.0.tar.gz
tar xpvf cmake-3.13.0.tar.gz cmake-3.13.0/ 
cd cmake-3.13.0/
./bootstrap --system-curl	
make -j4
echo 'export PATH=~/cmake-3.13.0/bin/:$PATH' >> ~/.bashrc
source ~/.bashrc 

6. 安装torch和tenchvision

将下载好的torch1.8 和torchvision0.9.0版本需要对应
Torch安装指令

Sudo pip3 install torch-1.8-0-cp36-cp36-m-linux_aarch64.whl
git clone --branch v0.9.0 https://github.com/pytorch/vision torchvision
cd torchvision	
export BUILD_VERSION=0.9.0
sudo python3 setup.py install	

检测是否安装成功

import torch
import torchvision
print(torch.__version__)
print(torchvision.__version__)

7. 安装yolov5需要的包

sudo pip3 install matplotlib==3.2.2
sudo pip3 install --upgrade Cython	
sudo apt-get remove python-numpy
sudo pip3 install numpy==1.19.4
sudo pip3 install scipy
sudo pip3 install tqdm==4.61.2
sudo pip3 install seaborn==0.11.1
sudo pip3 install scikit-build==0.11.1
sudo pip3 install opencv-python==4.5.3.56
sudo pip3 install tensorboard==2.5.0 -i https://pypi.tuna.tsinghua.edu.cn/simple
sudo pip3 install PyYAML==5.4.1
sudo pip3 install thop
sudo pip3 install pycocotools

8. 安装Deepstream-JDK,Gstreamer

sudo apt-get install libhdf5-serial-dev hdf5-tools
sudo apt-get install zlib1g-dev zip libjpeg8-dev libhdf5-dev
sudo pip3 install -U grpcio absl-py py-cpuinfo psutil portpicker grpcio six mock requests gast h5py astor termcolor

tensorflow有需要再装,不需要可以先不做,时间要比较久#sudo pip3 install --pre --extra-index-url https://developer.download.nvidia.com/compute/redist/jp/v45 tensorflow-gpu --user

安装deepstream6.0

安装Deepstream-sdk6.0版本的,或者支持的Jetback的版本是4.6版本,如果是Jetback其他版本的话,检查需要是4.5或者4.5.1的版本,然后两个不同版本的代码还有轻微的区别,Deepstream6.0的版本增加了python的一些插件,和更改了追踪器的使用方法,具体可以阅读,英伟达的说明文档,接下来先说明安装Jetback4.6 + Deepstream-sdk6.0的 版本,也是比较新的,最近更新就在两个月前。
JetBack 4.6 Deepstream-sdk 6.0版本
版本需求:
Jetson Xavier Nx Ubuntu 18.04
Gstreamer 1.0
CUDA = 10.2
TensorRT = 8.0.1

$ 安装相关依赖
sudo apt install libssl1.0.0 libgstreamer1.0-0 gstreamer1.0-tools gstreamer1.0-plugins-good gstreamer1.0-plugins-bad gstreamer1.0-plugins-ugly gstreamer1.0-libav libgstrtspserver-1.0-0 libjansson4 gcc make git python3
$安装librdkafka

sudo git clone https://github.com/edenhill/librdkafka.git
cd librdkafka
git reset --hard 7101c2310341ab3f4675fc565f64f0967e135a6a
sudo ./configure
sudo make –j4
sudo make install
sudo mkdir -p /opt/nvidia/deepstream/deepstream-6.0/lib
sudo cp /usr/local/lib/librdkafka* /opt/nvidia/deepstream/deepstream-6.0/lib

$安装SDK

方法一:使用Debian安装
下载 deepstream-6.0_6.0.0-1_amd64.deb Debian 包地址:
https://developer.nvidia.com/deepstream-6.0_6.0.0-1_amd64deb
执行命令安装: sudo apt-get install ./deepstream-6.0_6.0.0-1_amd64.deb
方法二:使用源码安装
下载Deepstream源码包,
https://developer.nvidia.com/deepstream_sdk_v6.0.0_x86_64tbz2
sudo tar -xvf deepstream_sdk_v6.0.0_x86_64.tbz2 -C /
cd /opt/nvidia/deepstream/deepstream-6.0/
sudo ./install.sh
sudo ldconfig
验证是否安装成功
which deepstream-app
能定位到 deepstream-app 一般就成功了,然后可以用 deepstram-app 执行一些 samples,基本命令如下:
deepstream-app -c <path_to_config_file>

#安装 Gstreamer
sudo apt-get install libgstrtspserver-1.0-0 gstreamer1.0-rtsp
sudo apt-get install libgirepository1.0-dev
sudo apt-get install gobject-introspection gir1.2-gst-rtsp-server-1.0
sudo apt-get install libgstreamer1.0-0 gstreamer1.0-plugins-base gstreamer1.0-plugins-good gstreamer1.0-plugins-bad gstreamer1.0-plugins-ugly gstreamer1.0-libav gstreamer1.0-doc gstreamer1.0-tools gstreamer1.0-x gstreamer1.0-alsa gstreamer1.0-gl gstreamer1.0-gtk3 gstreamer1.0-qt5 gstreamer1.0-pulseaudio libssl1.0.0 libgstrtspserver-1.0-0 libjansson4
检查是否安装成功:
dpkg -l | grep gstreamer
安装一下 python 接口:
sudo apt update
sudo apt install python3-gi python3-dev python3-gst-1.0 -y
下载deepstream _python_apps
cd /opt/nvidia/deepstream/deepstream/sources
sudo git clone https://github.com/NVIDIA-AI-IOT/deepstream_python_apps

安装些依赖

sudo apt install -y git python-dev python3 python3-pip python3.6-dev python3.8-dev \
cmake g++ build-essential libglib2.0-dev libglib2.0-dev-bin \
python-gi-dev libtool m4 autoconf automake
cd /opt/nvidia/deepstream/deepstream/sources/deepstream_python_apps/
git submodule update –init       (初始化,会在3rt…的文件中下载pybinds和gst-python)
下载gst-python
cd /opt/nvidia/deepstream/deepstream/sources/deepstream_python_apps/3rdparty

sudo ./autogen.sh 这里很容易连接不上网络,但是就是下载一个common的文件,可以使用其他的方法代替掉,把当前目录下面的common文件夹删除掉,然后克隆https://github.com/GStreamer/common.git
然后执行 sudo ./autogen.sh
sudo make –j4
sudo make install
然后安装pyds包
cd /opt/nvidia/deepstream/deepstream/sources/deepstream_python_apps/bindings
sudo mkdir build
cd build
sudo cmake … -DPYTHON_MAJOR_VERSION=3 -DPYTHON_MINOR_VERSION=6 -DPIP_PLATFORM=linux_aarch64 -DDS_PATH=/opt/nvidia/deepstream/deepstream-6.0/
sudo make –j4
编译成功截图
在这里插入图片描述
然后安装生成的pyds 的whl包
cd /opt/nvidia/deepstream/deepstream/sources/deepstream_python_apps/bindings/build/
sudo pip3 install ./ pyds-1.1.0-py3-none*.whl

如果遇到pip版本问题if you report an error here, please pip3 to the latest version.

python3 -m pip install --upgrade pip
这里python的一些接口安装完毕了可以运行一个案例进行测试

cd /opt/nvidia/deepstream/deepstream/sources/deepstream_python_apps/apps/deepstream-test1
python3 deepstream_test_1.py /opt/nvidia/deepstream/deepstream/samples/streams/sample_720p.h264
接下来生成部署代码。
Deepstream6.0的需要用这个代码去生成engine文件
首先克隆yolov5和tensorrt项目
cd /opt/nvidia/deepstream/deepstream-6.0/source/deepstream-python-apps/apps/
克隆YOLOV5项目:git clone https://github.com/ultralytics/yolov5.git

克隆项目git clone https://github.com/marcoslucianops/DeepStream-Yolo.git
进入项目cd Deepstream-Yolo
Jetson平台编译:
CUDA_VER=10.2 make -C nvdsinfer_custom_impl_Yolo
转移自己的权重文件这里以yolov5s.pt为例
python3 gen_wts_yoloV5.py -w yolov5s.pt 这个可以生成cfg和wts文件

编辑配置文件:sudo vim config_infer_primary_yoloV5.txt
配置文件内容如下
[property]
gpu-id=0
net-scale-factor=0.0039215697906911373
model-color-format=0
custom-network-config=yolov5s.cfg ###这个需要修改 自己训练的使用使用的是哪个就把那个cfg文件拷贝过来,配置cfg下载地址https://github.com/enazoe/yolo-tensorrt/tree/TRT8/configs/yolov5-6.0
model-file=yolov5s.wts #
#model-engine-file=niaodao_best.engine
#int8-calib-file=calib.table
labelfile-path=label.txt
batch-size=1
network-mode=0
num-detected-classes=80
interval=0
gie-unique-id=1
process-mode=1
network-type=0
cluster-mode=4
maintain-aspect-ratio=1
parse-bbox-func-name=NvDsInferParseYolo
custom-lib-path=nvdsinfer_custom_impl_Yolo/libnvdsinfer_custom_impl_Yolo.so
engine-create-func-name=NvDsInferYoloCudaEngineGet

[class-attrs-all]
pre-cluster-threshold=0.25
~
这个是配置文件。标黄的位置是需要动态修改的
然后执行测试运行deepstream-app –c deepstream_app_config.txt
运行会先生存engine 文件, 然后出效果。

自己的代码逻辑,需要根据自己的需求去完成

9. 风扇控制(板子过热会导致网络连接不稳定,可以手动开启风扇)

echo 255 > /sys/devices/pwm-fan/target_pwm #0:表示关闭风扇 0-255可选,

运行后可以通过VLC等软件进行播放播放网络串流rtsp://192.168.1.62:8554/ds-test
远程运行项目的时候会遇到
在这里插入图片描述
需要在~/.bashrc 的后面加上
在这里插入图片描述

从命令行模式切换成桌面模式的命令

sudo systemctl set-default graphical.target

这篇关于Deepstream6.0-Jetpark4.6-yolov5-v6.0-tensorRT-Jetson-xavier-nx项目部署环境搭建的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/475904

相关文章

centos7基于keepalived+nginx部署k8s1.26.0高可用集群

《centos7基于keepalived+nginx部署k8s1.26.0高可用集群》Kubernetes是一个开源的容器编排平台,用于自动化地部署、扩展和管理容器化应用程序,在生产环境中,为了确保集... 目录一、初始化(所有节点都执行)二、安装containerd(所有节点都执行)三、安装docker-

在Ubuntu上部署SpringBoot应用的操作步骤

《在Ubuntu上部署SpringBoot应用的操作步骤》随着云计算和容器化技术的普及,Linux服务器已成为部署Web应用程序的主流平台之一,Java作为一种跨平台的编程语言,具有广泛的应用场景,本... 目录一、部署准备二、安装 Java 环境1. 安装 JDK2. 验证 Java 安装三、安装 mys

Mycat搭建分库分表方式

《Mycat搭建分库分表方式》文章介绍了如何使用分库分表架构来解决单表数据量过大带来的性能和存储容量限制的问题,通过在一对主从复制节点上配置数据源,并使用分片算法将数据分配到不同的数据库表中,可以有效... 目录分库分表解决的问题分库分表架构添加数据验证结果 总结分库分表解决的问题单表数据量过大带来的性能

Java汇编源码如何查看环境搭建

《Java汇编源码如何查看环境搭建》:本文主要介绍如何在IntelliJIDEA开发环境中搭建字节码和汇编环境,以便更好地进行代码调优和JVM学习,首先,介绍了如何配置IntelliJIDEA以方... 目录一、简介二、在IDEA开发环境中搭建汇编环境2.1 在IDEA中搭建字节码查看环境2.1.1 搭建步

javafx 如何将项目打包为 Windows 的可执行文件exe

《javafx如何将项目打包为Windows的可执行文件exe》文章介绍了三种将JavaFX项目打包为.exe文件的方法:方法1使用jpackage(适用于JDK14及以上版本),方法2使用La... 目录方法 1:使用 jpackage(适用于 JDK 14 及更高版本)方法 2:使用 Launch4j(

Docker集成CI/CD的项目实践

《Docker集成CI/CD的项目实践》本文主要介绍了Docker集成CI/CD的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录一、引言1.1 什么是 CI/CD?1.2 docker 在 CI/CD 中的作用二、Docke

SpringBoot项目引入token设置方式

《SpringBoot项目引入token设置方式》本文详细介绍了JWT(JSONWebToken)的基本概念、结构、应用场景以及工作原理,通过动手实践,展示了如何在SpringBoot项目中实现JWT... 目录一. 先了解熟悉JWT(jsON Web Token)1. JSON Web Token是什么鬼

手把手教你idea中创建一个javaweb(webapp)项目详细图文教程

《手把手教你idea中创建一个javaweb(webapp)项目详细图文教程》:本文主要介绍如何使用IntelliJIDEA创建一个Maven项目,并配置Tomcat服务器进行运行,过程包括创建... 1.启动idea2.创建项目模板点击项目-新建项目-选择maven,显示如下页面输入项目名称,选择

Jenkins中自动化部署Spring Boot项目的全过程

《Jenkins中自动化部署SpringBoot项目的全过程》:本文主要介绍如何使用Jenkins从Git仓库拉取SpringBoot项目并进行自动化部署,通过配置Jenkins任务,实现项目的... 目录准备工作启动 Jenkins配置 Jenkins创建及配置任务源码管理构建触发器构建构建后操作构建任务

Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)

《Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)》:本文主要介绍Python基于火山引擎豆包大模型搭建QQ机器人详细的相关资料,包括开通模型、配置APIKEY鉴权和SD... 目录豆包大模型概述开通模型付费安装 SDK 环境配置 API KEY 鉴权Ark 模型接口Prompt