赞
踩
【简单介绍】
使用Python将YOLOv10模型从PyTorch格式(.pt)转换为TensorRT格式,并通过封装成类来实现目标检测加速任务,是一个高效且实用的流程。以下是该过程的简要介绍:
通过上述流程,我们可以将YOLOv10模型高效地部署到NVIDIA GPU上,实现快速且准确的目标检测任务。
【实现流程】
1、首先安装好anaconda环境然后开始安装yolov10环境
- conda create -n yolov10 python=3.9
- conda activate yolov10
- pip install -r requirements.txt
- pip install -e .
2、下载好tensorrt8.6.1.6版本安装包进行安装,并将tensorrt安装到yolov10环境中
3、导出模型
- yolo export model=jameslahm/yolov10{n/s/m/b/l/x} format=engine half=True simplify opset=13 workspace=16
- # or
- trtexec --onnx=yolov10n/s/m/b/l/x.onnx --saveEngine=yolov10n/s/m/b/l/x.engine --fp16
- # Predict with TensorRT
- yolo predict model=yolov10n/s/m/b/l/x.engine
您也可以直接使用我封装的转换接口:
- #pt转tensorrt
- detector = Yolov10Detector(weights='weights/yolov10n.pt')
- detector.pt_to_engine()
转换注意:由于tensorrt依赖于硬件,也就是不同电脑可能无法使用同一个tensorrt模型,因此需要在自己电脑本地首先转换pytorch模型为tensorrt模型,而不是直接拿别人转换好的tensorrt模型,否则可能会出现检测不到目标或者无法加载模型情况。
【封装调用】
推理图片:
- #推理图片
- detector = Yolov10Detector(weights='weights/yolov10n.engine')
- frame = cv2.imread('E:\person.jpg')
- result_list = detector.inference_image(frame)
- result_img = detector.draw_image(result_list, frame)
- cv2.imshow('frame', result_img)
- cv2.waitKey(0)
推理视频:
- #推理视频
- detector = Yolov10Detector(weights='weights/yolov10n.engine')
- detector.start_video(r'D:\car.mp4')
推理摄像头:
- #推理视频
- detector = Yolov10Detector(weights='weights/yolov10n.engine')
- detector.start_camera()
【效果展示】
【视频演示】
【测试环境】
torch==2.0.1 tensorrt==8.6.1.6 cuda==11.7.1 cudnn==8.8.0
【源码下载】 https://download.csdn.net/download/FL1623863129/89426162
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。