pointpillars点云算法TensorRT环境加速系列三

2024-01-11 01:48

本文主要是介绍pointpillars点云算法TensorRT环境加速系列三,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

简述

  在之前的两篇博客基础上,继续写下通过TensorRT加速onnx模型的速度与精度提升了多少,主要是通过github上开源的代码onnx_tensorrt来优化加载onnx进行加速。onnx_tensorrt环境配置有点麻烦,需要相对应的onnx与tensorrt与onnx_tensorrt的版本。我的版本为:onnx = 1.4.0 + tensorrt = 5.1.5.0 + onnx_tensorrt = 5.1 。 NVIDIA官方issues里面有许多关于tensorrt版本的问题,不过建议按照对应的成功版本,按照onnx_tensorrt的步骤进行安装onnx_tensorrt库。当然,文末有我提交docker版本的onnx_tensorrt镜像。另外:我的之前两篇pointpillars点云算法链接如下:

pointpillars点云算法TensorRT环境加速系列一

pointpillars点云算法TensorRT环境加速系列二

  同时,我的主要代码会提交到github上面:点击传送门。如果觉得有用,还请star一下哈。

Compare pfe.onnx ONNX with TensorRT

  首先我们来进行pfe.onnx模型验证,通过两种方式进行加载:1、直接通过onnx方式进行加载预测;2、通过onnx_tensorrt进行加载来优化加速;注:因为之前博客已经对比过onnx加载输出与原始的pytorch模型对比过精度,损失系数在小数点后三位。那么,我们现在直接用onnx_tensorrt加速对比onnx方式即可。

  onnx方式直接加载,请参考我的上一篇博客,下面我们来看下通过onnx_tensorrt加速优化的主要部分代码:

def tensorrt_backend_pfe_onnx():pillar_x = np.ones([1, 1, 12000, 100], dtype=np.float32)pillar_y = np.ones([1, 1, 12000, 100], dtype=np.float32)pillar_z = np.ones([1, 1, 12000, 100], dtype=np.float32)pillar_i = np.ones([1, 1, 12000, 100], dtype=np.float32)num_points_per_pillar = np.ones([1, 12000], dtype=np.float32)x_sub_shaped = np.ones([1, 1, 12000, 100], dtype=np.float32)y_sub_shaped = np.ones([1, 1, 12000, 100], dtype=np.float32)mask = np.ones([1, 1, 12000, 100], dtype=np.float32)pfe_inputs = [pillar_x, pillar_y, pillar_z, pillar_i, num_points_per_pillar,x_sub_shaped, y_sub_shaped, mask]print("pfe_inputs length is : ", len(pfe_inputs))start = time.time()pfe_model = onnx.load("pfe.onnx")engine = backend.prepare(pfe_model, device="CUDA:0", max_batch_size=1)for i in range(1, 1000):pfe_outputs = engine.run(pfe_inputs)end = time.time()print('inference time is : ', (end - start)/1000)print(pfe_outputs)

  Now,看完主要的tensorrt的测试代码,看一下通过onnx_tensorrt优化后的输出与onnx直接加载方式的输出对比吧。

Compare rpn.onnx ONNX with TensorRT

  Ok,我们接下来需要对rpn.onnx来对比tensorrt的加速精度。由于中间涉及pillarscatter网络,我们目前就单独测试rpn.onnx的输出精度与onnx加载rpn.onnx的输出精度。

  rpn.onnx(onnx直接加载的方式同理参考上一篇博客即可)经过tensorrt优化的加速代码如下:

def tensorrt_backend_rpn_onnx():rpn_input_features = np.ones([1, 64, 496, 432], dtype=np.float32)rpn_start_time = time.time()rpn_model = onnx.load("rpn.onnx")engine = backend.prepare(rpn_model, device="CUDA:0", max_batch_size=1)for i in range(1, 1000):rpn_outputs = engine.run(rpn_input_features)rpn_end_time = time.time()print('rpn inference time is : ', (rpn_end_time - rpn_start_time)/1000)print(rpn_outputs)

  我们来对比一下rpn.onnx模型经过onnx直接加载方式与tensorrt优化的对比输出结果:(注:此处的rpn输出与上一篇博客数据不同,主要原因在于这里rpn输入是设置np.ones矩阵,上一篇是直接接PillarScatter网络的输出作为输入。)

ONNX与TensorRT的时间对比如下
Time/spre-processpfe.onnxpillarscatterrpn.onnxpost-processall
onnxN/A0.26035N/A0.198846N/AN/A
tensorrtN/A0.01116N/A0.0187535N/AN/A

  上面表格中可以看出pfe.onnx与rpn.onnx的计算性能提升对比,N/A代表还未进行测试。目前只是单独测试了一下,并没有进行系统测试,数据仅供参考。

onnx_tensorrt的docker镜像源:

docker pull smallmunich/onnx_tensorrt:latest
小结

  由于pfe.onnx与rpn.onnx中间嵌入了一个pillarscatter网络,所以系统测试的话需要对其进行改写,后期可能会将这部分的torch代码修改为纯python版本来进行全程测试吧。目前单独测试pfe.onnx与rpn.onnx精度损失较少,速度优化很大提升。后面,可能系统测试一下整体的速度优化比例,用python代码实现pillarscatter部分网络,具体请等待我的github更新。

参考文献

https://arxiv.org/abs/1812.05784

https://github.com/SmallMunich/nutonomy_pointpillars

https://blog.csdn.net/Small_Munich/article/details/101559424

https://blog.csdn.net/Small_Munich/article/details/102073540

这篇关于pointpillars点云算法TensorRT环境加速系列三的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

linux环境openssl、openssh升级流程

《linux环境openssl、openssh升级流程》该文章详细介绍了在Ubuntu22.04系统上升级OpenSSL和OpenSSH的方法,首先,升级OpenSSL的步骤包括下载最新版本、安装编译... 目录一.升级openssl1.官网下载最新版openssl2.安装编译环境3.下载后解压安装4.备份

golang字符串匹配算法解读

《golang字符串匹配算法解读》文章介绍了字符串匹配算法的原理,特别是Knuth-Morris-Pratt(KMP)算法,该算法通过构建模式串的前缀表来减少匹配时的不必要的字符比较,从而提高效率,在... 目录简介KMP实现代码总结简介字符串匹配算法主要用于在一个较长的文本串中查找一个较短的字符串(称为

通俗易懂的Java常见限流算法具体实现

《通俗易懂的Java常见限流算法具体实现》:本文主要介绍Java常见限流算法具体实现的相关资料,包括漏桶算法、令牌桶算法、Nginx限流和Redis+Lua限流的实现原理和具体步骤,并比较了它们的... 目录一、漏桶算法1.漏桶算法的思想和原理2.具体实现二、令牌桶算法1.令牌桶算法流程:2.具体实现2.1

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

在Mysql环境下对数据进行增删改查的操作方法

《在Mysql环境下对数据进行增删改查的操作方法》本文介绍了在MySQL环境下对数据进行增删改查的基本操作,包括插入数据、修改数据、删除数据、数据查询(基本查询、连接查询、聚合函数查询、子查询)等,并... 目录一、插入数据:二、修改数据:三、删除数据:1、delete from 表名;2、truncate

VScode连接远程Linux服务器环境配置图文教程

《VScode连接远程Linux服务器环境配置图文教程》:本文主要介绍如何安装和配置VSCode,包括安装步骤、环境配置(如汉化包、远程SSH连接)、语言包安装(如C/C++插件)等,文中给出了详... 目录一、安装vscode二、环境配置1.中文汉化包2.安装remote-ssh,用于远程连接2.1安装2

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1

mysql-8.0.30压缩包版安装和配置MySQL环境过程

《mysql-8.0.30压缩包版安装和配置MySQL环境过程》该文章介绍了如何在Windows系统中下载、安装和配置MySQL数据库,包括下载地址、解压文件、创建和配置my.ini文件、设置环境变量... 目录压缩包安装配置下载配置环境变量下载和初始化总结压缩包安装配置下载下载地址:https://d

将Python应用部署到生产环境的小技巧分享

《将Python应用部署到生产环境的小技巧分享》文章主要讲述了在将Python应用程序部署到生产环境之前,需要进行的准备工作和最佳实践,包括心态调整、代码审查、测试覆盖率提升、配置文件优化、日志记录完... 目录部署前夜:从开发到生产的心理准备与检查清单环境搭建:打造稳固的应用运行平台自动化流水线:让部署像