Project Icon

yolort

简易高效的YOLOv5目标检测工具

yolort项目致力于简化和优化YOLOv5的训练与推理。采用动态形状机制,结合预处理和后处理,支持LibTorch、ONNX Runtime、TVM、TensorRT等多种后端的轻松部署。项目遵循简洁设计理念,安装与使用便捷,支持通过PyPI和源码安装。提供丰富的推理接口示例和详细文档,使目标检测更为轻松,适用于广泛的应用场景。

YOLOv5 Runtime Stack 项目介绍

🤗 项目简介

YOLOv5 Runtime Stack(简称 yolort)是Ultralytics公司YOLOv5的又一个实现版本。yolort旨在让目标检测任务的训练和推理环节更加无缝衔接。目前,yolort采用与官方YOLOv5相同的模型结构,但不同之处在于它采用了动态形状机制,将预处理(如letterbox)和后处理(如nms)嵌入到模型图中,这样可以简化部署策略。因此,yolort可以更轻松地在LibTorch、ONNX Runtime、TVM、TensorRT等平台上部署目标检测任务。

yolort的代码基于detr的设计原则,简单易用,训练和推理不再需要复杂的库。如果你喜欢torchvision的faster-rcnn、retinanet或detr,或者是YOLOv5,那么你一定会喜欢yolort。

🆕 更新动态

  • 2021年12月27日:新增TensorRT C++接口示例。
  • 2021年12月25日:支持导出到TensorRT,并新增TensorRT Python接口推理。
  • 2021年9月24日:新增ONNX Runtime C++接口示例。
  • 2021年2月5日:新增TVM编译与推理笔记。
  • 2020年11月21日:新增图形可视化工具。
  • 2020年11月17日:支持导出到ONNX,并新增ONNX Runtime Python接口推理。
  • 2020年11月16日:改进YOLO模块,支持动态形状/批量推理。
  • 2020年11月4日:新增LibTorch C++推理示例。
  • 2020年10月8日:支持导出到TorchScript模型。

🛠️ 使用方法

yolort没有额外的编译组件,并且软件包依赖关系很少,因此代码非常易于使用。

安装和推理示例

  • 首先,根据官方说明安装PyTorch 1.8.0+和torchvision 0.9.0+。

  • 通过pip安装:

    pip install -U yolort
    
  • 或者从源代码安装:

    git clone https://github.com/zhiqwang/yolort.git
    cd yolort
    pip install -e .
    
  • 安装pycocotools(用于COCO评估):

    pip install -U 'git+https://github.com/ppwwyyxx/cocoapi.git#subdirectory=PythonAPI'
    
  • 图像文件推理示例:

    from yolort.models import yolov5s
    
    model = yolov5s(pretrained=True, score_thresh=0.45)
    model.eval()
    
    predictions = model.predict("bus.jpg")
    

使用torch.hub加载

通过torch hub加载预训练的yolov5s模型:

model = torch.hub.load("zhiqwang/yolort:main", "yolov5s", pretrained=True)

从YOLOv5官方加载检查点

接口如下:

from yolort.models import YOLOv5

ckpt_path_from_ultralytics = "yolov5s.pt"
model = YOLOv5.load_from_yolov5(ckpt_path_from_ultralytics, score_thresh=0.25)

model.eval()
img_path = "test/assets/bus.jpg"
predictions = model.predict(img_path)

🚀 部署

LibTorch后端推理

有一个教程演示如何将模型转换为torchscript,并提供一个C++示例以实现使用序列化的torchscript模型进行推理。

ONNX Runtime后端推理

以下是使用ONNX Runtime进行部署的管道:

from yolort.runtime import PredictorORT

engine_path = "yolov5n6.onnx"
y_runtime = PredictorORT(engine_path, device="cpu")

predictions = y_runtime.predict("bus.jpg")

TensorRT后端推理

以下是TensorRT部署的简单示例:

import torch
from yolort.runtime import PredictorTRT

engine_path = "yolov5n6.engine"
device = torch.device("cuda")
y_runtime = PredictorTRT(engine_path, device=device)

predictions = y_runtime.predict("bus.jpg")

🎨 模型图形可视化

yolort可以直接绘制模型图形,用户可以参考教程了解如何使用及可视化模型图。

👋 撰稿与社区贡献

欢迎社区贡献者提供帮助。用户可以参考我们的贡献指南开始合作。如果喜欢该项目,请考虑为该仓库加星,以支持我们。

📖 引用yolort

如果您在您的出版物中使用yolort,请使用以下BibTeX条目进行引用。

🎓 鸣谢

  • yolov5的实现借用了ultralytics的代码。
  • 本仓库的架构设计及部分代码来自于torchvision
项目侧边栏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号