Project Icon

YOLOv8-TensorRT-CPP

用C++和TensorRT实现高效的YOLOv8模型推理

本文介绍了如何使用TensorRT的C++ API实现YOLOv8模型的推理,支持目标检测、语义分割和身体姿态估计,包括系统要求、安装步骤、模型转换和项目构建方法。内容中强调了在GPU上运行推理的注意事项和性能基准测试,提供了从PyTorch到ONNX模型转换的详细步骤,是开发计算机视觉应用的参考资料。

项目介绍:YOLOv8-TensorRT-CPP

YOLOv8-TensorRT-CPP 是一个基于 C++ 的项目,结合了 TensorRT 技术,旨在高效地实现 YOLOv8 模型的推理。它支持目标检测、语义分割和人体姿态估计等多种功能。该项目展示了如何使用 TensorRT C++ API 在 GPU 上进行高效推理。

项目背景

YOLOv8 是一种先进的物体检测模型,广泛应用于计算机视觉领域。通过与 TensorRT 的结合,YOLOv8-TensorRT-CPP 能够在推理时提供更高的性能和效率,特别是在处理大规模图像数据时。

寻找维护者

此项目正在积极寻找维护者,以帮助其成长和改进。如果您对这个项目充满热情,并有兴趣贡献力量,可以通过项目发起者的 LinkedIn 进行联系和交流。

快速入门

要开始使用 YOLOv8-TensorRT-CPP,用户需具备对 TensorRT C++ API 的基本了解,该项目利用了作者的另一个项目 tensorrt-cpp-api 进行后台推理操作。

系统要求

  • 本项目在 Ubuntu 20.04 和 22.04 上进行了测试。当前不支持 Windows 系统。
  • 需要安装 CUDA(建议版本 >= 12.0)和 cuDNN(建议版本 >= 8)。
  • 安装 CMake 和 OpenCV(建议版本 >= 4.8)。可以通过 build_opencv.sh 脚本编译 OpenCV 源码。
  • 下载并配置 TensorRT 10(要求版本 >= 10.0)。

安装说明

  1. 使用以下命令克隆项目:
    git clone https://github.com/cyrusbehr/YOLOv8-TensorRT-CPP --recursive
    
    注意:务必使用 --recursive 标志以确保子模块正常。

模型转换流程

从 PyTorch 转换至 ONNX 的步骤如下:

  1. 从官方的 YOLOv8 仓库中下载模型,如 YOLOv8x。
  2. 安装 ultralytics 包:pip3 install ultralytics
  3. 使用提供的脚本将 PyTorch 模型转换成 ONNX 格式:
    python3 pytorch2onnx.py --pt_path <path to your pt file>
    

构建项目

  1. 创建并进入构建目录:
    mkdir build
    cd build
    
  2. 使用 CMake 进行构建:
    cmake ..
    make -j
    

运行可执行文件

首次运行时,由于 TensorRT 需要从 ONNX 模型生成一个优化引擎文件,可能需要较长时间(超过 5 分钟)。之后的运行会快速加载该引擎文件。

  • 运行基准测试:
    ./benchmark --model /path/to/your/onnx/model.onnx --input /path/to/your/benchmark/image.png
    
  • 在图像上进行推理并保存注释图像:
    ./detect_object_image --model /path/to/your/onnx/model.onnx --input /path/to/your/image.jpg
    
  • 使用摄像头进行实时推理并显示结果:
    ./detect_object_video --model /path/to/your/onnx/model.onnx --input 0
    

INT8 推理

启用 INT8 精度可进一步加快推理速度,但会略微降低精度。需要提供 1K+ 的校准图像,以便模型的动态范围更好地代表实际数据。

性能基准

在 NVIDIA GeForce RTX 3080 笔记本 GPU 和 Intel Core i7-10870H CPU 上运行基准测试,使用 640x640 的 BGR 图像和 FP16 精度。结果如下:

ModelTotal TimePreprocess TimeInference TimePostprocess Time
yolov8n3.613 ms0.081 ms1.703 ms1.829 ms

如何调试

如果遇到生成 TensorRT 引擎文件的问题,可以在 libs/tensorrt-cpp-api/src/engine.cpp 中将日志级别更改为 kVERBOSE 以获取更多信息。

表达感谢

如果此项目对您有所帮助,为其加星是对作者工作的极大鼓励,有助于保持项目的更新。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号