美文网首页
ubuntu18.04+TensorRT 配置攻略

ubuntu18.04+TensorRT 配置攻略

作者: 有事没事扯扯淡 | 来源:发表于2021-06-08 11:19 被阅读0次

卷积网络的量化和部署是重要环节,以前我们训练好模型后直接trace进行调用,参考(C++ windows调用ubuntu训练的PyTorch模型(.pt/.pth),windows+VS2019+PyTorchLib配置使用攻略)。很多大佬都说TensorRT的推理效果更好,自己也想试一下。历尽千辛万苦,终于弄好了~~~ 供大家参考。

准备

确认CUDA安装正确,可使用如下命令:

>nvcc --version
nvcc: NVIDIA (R) Cuda compiler driver
Copyright (c) 2005-2019 NVIDIA Corporation
Built on Wed_Oct_23_19:24:38_PDT_2019
Cuda compilation tools, release 10.2, V10.2.89

如果不对,就参考ubuntu18.04+CUDA10.0+cuDNN+Tensorflow配置全解自己先配一下吧

1.TensorRT SDK下载

账号大家肯定都有了~~选择正确的版本下载。比如:此次编译的系统环境是cuda-10.2 + cuDNN-8.1,所以下载的是
TensorRT-7.2.3.4.Ubuntu-18.04.x86_64-gnu.cuda-10.2.cudnn8.1.tar.gz

下载后的文件放到目录 ~/softwares 下并解压,再更新环境变量。完整的命令操作如下:

# 创建存放软件的目录
mkdir -p ~/softwares

# 把下载得到的文件移动到~/softwares目录下
mv TensorRT-7.2.3.4.Ubuntu-18.04.x86_64-gnu.cuda-10.2.cudnn8.1.tar.gz ~/softwares

# 进入目录
cd ~/softwares

# 解压文件
tar -xvzf TensorRT-7.2.3.4.Ubuntu-18.04.x86_64-gnu.cuda-10.2.cudnn8.1.tar.gz

解压文件后,需要更新环境变量以方便后面的操作sudo gedit ~/.bashrc

# 定义TensorRT SDK所在的位置,方便后面的操作
export TRT_RELEASE=~/softwares/TensorRT-7.2.3.4
# 更新链接库,后面编译时才能正确编译
export LD_LIBRARY_PATH=$TRT_RELEASE/lib:$LD_LIBRARY_PATH

2.TensortRT 源码下载

  • 这是下载的TensorRT包含有用的一些插件和解析库。和前面的TensorRT SDK不一样
  • 这里一定要注意版本要求!!!我就是没仔细看吃了大亏,/(ㄒoㄒ)/~~
    尤其要注意CUDA和cudnn的版本匹配关系!!很多人都是cuda都是装好的再来装TRT,一定要看清楚!!
  • 注意CMake 的版本,ubuntu18.04默认安装的CMake版本是3.10不满足要求,我是自己下载的CMake的源码进行的安装,也很简单。github CMake
  • 如果编译ONNX报错,可以自己源码下载编译安装。github onnx-tensorrt

逐步进行如下操作

# 创建存放源代码的目录
mkdir -p ~/repos

# 进入目录
cd ~/repos

# 把源代码放到目录~/repos下 ,我用的master
git clone  https://github.com/nvidia/TensorRT TensorRT
cd TensorRT
git submodule update --init --recursive  

注意!!!

  • 最后一句话可能会因为网络的原因停止下载,多试几次就好了~~
  • 源码有很多submodule可能下载不下来,可以手动在github上单独下载,然后放到对应的文件夹下即可
# 创建用于编译的目录
mkdir build

# 进入编译目录
cd build

# 生成Makefile
cmake .. -DTRT_LIB_DIR=$TRT_RELEASE/lib -DTRT_OUT_DIR=./out -DCUDA_VERSION=10.2

# 开始多线程编译
# 编译完成后,生成的文件都在~/repos/TensorRT/build/out中
make -j$(nproc)

# 将生成的库文件复制到$TRT_RELEASE/lib目录下
# 将生成的可执行文件复制到$TRT_RELEASE/bin目录下
make install

# 编译成功后根据python的版本安装TensorRT的python扩展
#conda activate py37
pip install $TRT_RELEASE/python/tensorrt-7.2.3.4-cp37-none-linux_x86_64.whl

make的过程中可能会报错,不要害怕!首先排查版本是否匹配,然后在确认submodule是否都下载下来了,我就出现过问题,报错一直查不到,结果是因为少了一个文件夹,非常坑爹~~就是有个optimized.h,骂街了。。。。

3.验证

根据官网https://docs.nvidia.com/deeplearning/tensorrt/install-guide/可以查看详细的安装方法。输入以下指令进行验证。

>python3
>>> import tensorrt
>>> print(tensorrt.__version__)
>>> assert tensorrt.Builder(tensorrt.Logger())

If the final Python command fails with an error message similar to the error message below, then you may not have the NVIDIA driver installed or the NVIDIA driver may not be working properly. If you are running inside a container, then try starting from one of the nvidia/cuda:x.y-base-<os>containers.

[TensorRT] ERROR: CUDA initialization failure with error 100. Please check your CUDA installation: ...

如果出现上述问题,应该是NVIDIA Driver版本太低的问题,把驱动升级为最新版本的就OK了~~(我因为这个找了好久,苍天见怜啊~~)

[参考链接]
https://zhuanlan.zhihu.com/p/181274475
https://github.com/NVIDIA/TensorRT/issues?q=CUDA+initialization+failure
https://blog.csdn.net/dou3516/article/details/108314908
https://zhuanlan.zhihu.com/p/59618999
https://github.com/onnx/onnx-tensorrt/issues/355

相关文章

  • ubuntu18.04+TensorRT 配置攻略

    卷积网络的量化和部署是重要环节,以前我们训练好模型后直接trace进行调用,参考(C++ windows调用ubu...

  • Linux 环境变量配置全攻略

    Linux 环境变量配置全攻略 Linux环境变量配置 在自定义安装软件的时候,经常需要配置环境变量,下面列举出各...

  • 开始使用MacVim了

    我的MacVim配置最开始是参考 MacVim 配置攻略 | 卡瓦邦噶! 这篇文章的,不过里面有很坑的地方。 这个...

  • VS配置opencv(可复用属性管理页)

    本攻略目标: 如何配置VS的第三方库达到可复用的目的(即配置可复用的属性管理文件) 如何配置使能在VS中使用ope...

  • axios配置相关

    参考文档 Axios 请求配置参数详解 axios 全攻略之基本介绍与使用(GET 与 POST)

  • 儿童配置保险攻略

    昨夜观《银河补习班》,影片细节处理到位,将一份适宜孩子成长的父爱诠释的非常完整。我的泪点和笑点都极不具水平,全程跟...

  • 少儿保险配置攻略

    每个孩子的到来,对我们家庭来说,都是无可替代的天使降临。 鉴于给孩子买保险已经是当代父母的刚需,我整理了关于少儿保...

  • 家庭资产配置攻略

    很多人在开始理财时,都很困惑,我们该如何分配一个家庭的资产,有多少能拿出来投资股票? 今日阅读了 银行螺丝钉 老师...

  • hexo优化攻略

    写在前面 这个攻略主要是给有一定diy能力的hexo博主。一些细节的攻略可以参考如下文章:hexo 基础配置优化 ...

  • React Native安装入坑记录

    网络上配置node.js的攻略一大堆,在此不再多说,使用的开发工具是webstorm,在确认环境确实配置成功了,但...

网友评论

      本文标题:ubuntu18.04+TensorRT 配置攻略

      本文链接:https://www.haomeiwen.com/subject/hcmzsltx.html