Project Icon

yolov10

实现实时端到端目标检测新突破

YOLOv10是新一代实时端到端目标检测模型,通过创新的无NMS训练策略和全面的效率-准确度优化设计,在推理速度和计算效率方面实现显著提升。COCO数据集实验结果表明,YOLOv10在不同模型规模下均达到了业界领先的性能和效率水平,为实时目标检测领域带来新的发展方向。

YOLOv10:实时端到端目标检测

YOLOv10的官方PyTorch实现。


与其他方法在延迟-精度(左)和大小-精度(右)权衡方面的比较。

YOLOv10:实时端到端目标检测
王奥、陈辉、刘立浩、陈凯、林子嘉、韩军功和丁贵广
arXiv 在Colab中打开 Hugging Face Spaces Hugging Face Spaces Hugging Face Spaces Transformers.js 演示 LearnOpenCV Openbayes 演示

摘要 近年来,由于YOLO系列在计算成本和检测性能之间取得了有效平衡,它们已成为实时目标检测领域的主导范式。研究人员探索了YOLO的架构设计、优化目标、数据增强策略等方面,取得了显著进展。然而,对非极大值抑制(NMS)进行后处理的依赖阻碍了YOLO的端到端部署,并对推理延迟产生不利影响。此外,YOLO中各个组件的设计缺乏全面和深入的检查,导致明显的计算冗余并限制了模型的能力。这造成了次优的效率,同时存在相当大的性能改进潜力。在本工作中,我们旨在从后处理和模型架构两个方面进一步推进YOLO的性能效率边界。为此,我们首先提出了用于YOLO无NMS训练的一致双重分配,同时实现了具有竞争力的性能和低推理延迟。此外,我们引入了YOLO的整体效率-精度驱动的模型设计策略。我们从效率和精度两个角度全面优化了YOLO的各个组件,大大减少了计算开销并增强了能力。我们努力的成果是一个用于实时端到端目标检测的新一代YOLO系列,称为YOLOv10。大量实验表明,YOLOv10在各种模型规模上实现了最先进的性能和效率。例如,我们的YOLOv10-S在COCO上与RT-DETR-R18达到相似的AP的情况下速度提高了1.8倍,同时参数数量和FLOPs减少了2.8倍。与YOLOv9-C相比,YOLOv10-B在相同性能下延迟减少了46%,参数减少了25%。
## 注意事项 - 2024/05/31:请使用[导出格式](https://github.com/THU-MIG/yolov10?tab=readme-ov-file#export)进行基准测试。在非导出格式下,如PyTorch格式,YOLOv10的速度存在偏差,因为`v10Detect`中不必要的`cv2`和`cv3`操作在推理过程中被执行。 - 2024/05/30:我们提供了[一些说明和建议](https://github.com/THU-MIG/yolov10/issues/136),用于使用YOLOv10检测较小或远处物体。感谢[SkalskiP](https://github.com/SkalskiP)! - 2024/05/27:我们已更新[检查点](https://huggingface.co/collections/jameslahm/yolov10-665b0d90b0b5bb85129460c2),添加了类别名称,以便使用。

更新 🔥

性能

COCO

模型测试尺寸参数量浮点运算次数APval延迟
YOLOv10-N6402.3M6.7G38.5%1.84ms
YOLOv10-S6407.2M21.6G46.3%2.49ms
YOLOv10-M64015.4M59.1G51.1%4.74ms
YOLOv10-B64019.1M92.0G52.5%5.74ms
YOLOv10-L64024.4M120.3G53.2%7.28ms
YOLOv10-X64029.5M160.4G54.4%10.70ms

安装

推荐使用conda虚拟环境。

conda create -n yolov10 python=3.9
conda activate yolov10
pip install -r requirements.txt
pip install -e .

演示

python app.py
# 请访问 http://127.0.0.1:7860

验证

yolov10n yolov10s yolov10m yolov10b yolov10l yolov10x

yolo val model=jameslahm/yolov10{n/s/m/b/l/x} data=coco.yaml batch=256

或者

from ultralytics import YOLOv10

model = YOLOv10.from_pretrained('jameslahm/yolov10{n/s/m/b/l/x}')
# 或者
# wget https://github.com/THU-MIG/yolov10/releases/download/v1.1/yolov10{n/s/m/b/l/x}.pt
model = YOLOv10('yolov10{n/s/m/b/l/x}.pt')

model.val(data='coco.yaml', batch=256)

训练

yolo detect train data=coco.yaml model=yolov10n/s/m/b/l/x.yaml epochs=500 batch=256 imgsz=640 device=0,1,2,3,4,5,6,7

或者

from ultralytics import YOLOv10

model = YOLOv10()
# 如果你想使用预训练权重进行微调,可以像下面这样加载预训练权重
# model = YOLOv10.from_pretrained('jameslahm/yolov10{n/s/m/b/l/x}')
# 或者
# wget https://github.com/THU-MIG/yolov10/releases/download/v1.1/yolov10{n/s/m/b/l/x}.pt
# model = YOLOv10('yolov10{n/s/m/b/l/x}.pt')

model.train(data='coco.yaml', epochs=500, batch=256, imgsz=640)

推送到 🤗 Hub

你可以选择将微调后的模型推送到 Hugging Face hub 作为公开或私有模型:

# 假设你已经为作物检测微调了一个模型
model.push_to_hub("<你的-hf-用户名-或-组织/yolov10-finetuned-crop-detection")

# 如果你不想让所有人都看到你的模型,你也可以传入 `private=True`
model.push_to_hub("<你的-hf-用户名-或-组织/yolov10-finetuned-crop-detection", private=True)

预测

注意,可以设置较小的置信度阈值来检测较小的物体或远处的物体。详情请参考这里

yolo predict model=jameslahm/yolov10{n/s/m/b/l/x}

或者

from ultralytics import YOLOv10

model = YOLOv10.from_pretrained('jameslahm/yolov10{n/s/m/b/l/x}')
# 或者
# wget https://github.com/THU-MIG/yolov10/releases/download/v1.1/yolov10{n/s/m/b/l/x}.pt
model = YOLOv10('yolov10{n/s/m/b/l/x}.pt')

model.predict()

导出

# 端到端 ONNX
yolo export model=jameslahm/yolov10{n/s/m/b/l/x} format=onnx opset=13 simplify
# 使用 ONNX 进行预测
yolo predict model=yolov10n/s/m/b/l/x.onnx

# 端到端 TensorRT
yolo export model=jameslahm/yolov10{n/s/m/b/l/x} format=engine half=True simplify opset=13 workspace=16
# 或者
trtexec --onnx=yolov10n/s/m/b/l/x.onnx --saveEngine=yolov10n/s/m/b/l/x.engine --fp16
# 使用 TensorRT 进行预测
yolo predict model=yolov10n/s/m/b/l/x.engine

或者

from ultralytics import YOLOv10
model = YOLOv10.from_pretrained('jameslahm/yolov10{n/s/m/b/l/x}')
# 或者
# wget https://github.com/THU-MIG/yolov10/releases/download/v1.1/yolov10{n/s/m/b/l/x}.pt
model = YOLOv10('yolov10{n/s/m/b/l/x}.pt')

model.export(...)

致谢

代码库基于ultralyticsRT-DETR构建。

感谢这些出色的实现!

引用

如果我们的代码或模型对您的工作有所帮助,请引用我们的论文:

@article{wang2024yolov10,
  title={YOLOv10: Real-Time End-to-End Object Detection},
  author={Wang, Ao and Chen, Hui and Liu, Lihao and Chen, Kai and Lin, Zijia and Han, Jungong and Ding, Guiguang},
  journal={arXiv preprint arXiv:2405.14458},
  year={2024}
}
项目侧边栏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号