转trt步骤记录

tensorflow转trt:
# 替换不可行的算子

# 在pb代码目录,运行 CUDA_VISIBLE_DEVICES=-1 python eval_png.py 得到.pb
(在CUDA11环境下,tensorflow要在cpu上验证结果)

# 查看.pb最后一个节点

# 下载tf2onnx包:https://github.com/onnx/tensorflow-onnx

# 替换目录下tf2onnx/onnx_opset/tensor.py的内容
 

# 如果要引入自定义算子,添加目录下tf2onnx/convert.py的内容
 

# 在目录下运行 python setup.py install

# 回到pb代码目录下,修改最后一个节点(如下是Reshape_1),运行如下,生成.onnx  (有错误信息没关系,只是注册onnx算子)
python -m tf2onnx.convert --input ./FRC_1920x1080_bs1.pb --inputs "f1:0,f2:0,f1_o:0,f2_o:0,m_f1:0,m_f2:0,s_f1:0,s_f2:0" --outputs "Reshape_1:0" --output FRC_1920x1080_bs1.onnx --opset 10

# 根据CUDA版本, Ubuntu版本, 内核下载对应的TensorRT 7.2.1开源库

# 添加环境变量 export LD_LIBRARY_PATH=/home/c00443756/0result/TensorRT-7.2.1.6/lib:$LD_LIBRARY_PATH

# 在trt-C代码目录,如果有自定义算子,需要写.cpp/.cu文件,主要是写接口函数
或在trt-python代码目录,如果有自定义算子,需要写.cpp/.cu/.h文件,主要是写接口函数

# 从pb代码目录拷贝.onnx到trt-C代码目录,修改Makefile里的tensorRT路径,mkdir bin && make

问题:
Makefile.config:11: CUDA_INSTALL_DIR variable is not specified, using /usr/local/cuda by default, use CUDA_INSTALL_DIR=<cuda_directory> to change
解决:
sudo make clean
sudo make CUDA_INSTALL_DIR=/usr/local/cuda
https://blog.csdn.net/zhw864680355/article/details/80976903

或从pb代码目录拷贝.onnx到trt-python代码目录,修改CMakeLists.txt里的tensorRT路径和.cpp/.cu/.h文件路径,mkdir build && cd build && cmake .. && make ,生成.so文件

# 在trt-C代码目录,cd bin , 运行生成的可执行文件,生成trt模型(记得先删除之前的trt模型)(该步骤在V100显卡需要半小时左右)
或在trt-python代码目录,cd ..,运行CUDA_VISIBLE_DEVICES=1 python test.py,生成trt模型(记得先删除之前的trt模型)(该步骤在V100显卡需要半小时左右)

===========================================================================================
pytorch转trt:
# 固定输入尺寸,如(1,8,1080,1920)

# 直接调用torch中的onnx.export生成.onnx,有些算子可能需要opset10支持(pytorch1.1及以下没有opset_version参数)
 

# .onnx转.trt (onnx转trt叫做序列化,解析trt叫做反序列化)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

WX Chen

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值