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

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

Project Cover

Kimi

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

Project Cover

阿里绘蛙

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

Project Cover

吐司

探索Tensor.Art平台的独特AI模型,免费访问各种图像生成与AI训练工具,从Stable Diffusion等基础模型开始,轻松实现创新图像生成。体验前沿的AI技术,推动个人和企业的创新发展。

Project Cover

SubCat字幕猫

SubCat字幕猫APP是一款创新的视频播放器,它将改变您观看视频的方式!SubCat结合了先进的人工智能技术,为您提供即时视频字幕翻译,无论是本地视频还是网络流媒体,让您轻松享受各种语言的内容。

Project Cover

美间AI

美间AI创意设计平台,利用前沿AI技术,为设计师和营销人员提供一站式设计解决方案。从智能海报到3D效果图,再到文案生成,美间让创意设计更简单、更高效。

Project Cover

稿定AI

稿定设计 是一个多功能的在线设计和创意平台,提供广泛的设计工具和资源,以满足不同用户的需求。从专业的图形设计师到普通用户,无论是进行图片处理、智能抠图、H5页面制作还是视频剪辑,稿定设计都能提供简单、高效的解决方案。该平台以其用户友好的界面和强大的功能集合,帮助用户轻松实现创意设计。

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