首页 > 其他分享 >YOLOv10实时端到端目标检测

YOLOv10实时端到端目标检测

时间:2024-07-25 09:56:52浏览次数:14  
标签:__ 置信度 NMS 检测 实时 YOLOv10 边界 端到

文章目录


前言

  距离上次写YOLOv5已经过去了两年,正好最近用YOLOv10重构了项目,总结下YOLOv10。
YOLOv10真正实时端到端目标检测,那么什么是端到端?
  端到端目标检测是一种从原始数据输入到最终结果输出的直接过程,无需分步骤处理或人工干预。在YOLOv10中移除非最大抑制(NMS),从而减少了推理延迟。


一、非极值大抑制(NMS)

  非最大值抑制(NMS)是一种在目标检测中广泛应用的算法,主要用于去除冗余的检测框,只保留最有可能包含目标物体的框。
    在目标检测任务中,通常会有多个候选框同时检测到同一个目标,这些框之间会有不同程度的重叠。为了从这些重叠的框中筛选出最佳检测结果,NMS算法被提出和应用。
在这里插入图片描述

二、NMS算法的具体原理和步骤

  1.置信度排序:根据每个边界框的置信度进行降序排列,置信度最高的边界框被认为是最有可能正确检测到目标的。

  2.选择边界框:从排序后的列表中选择置信度最高的边界框,标记为已选,并将其添加到最终的检测结果列表中。

  3.计算交并比:对于剩余的每个边界框,计算它与已选边界框的交并比(IOU),即交集与并集的比值。

  4.剔除低置信度框:如果某个边界框与已选框的IOU超过了预设的阈值(例如0.5或0.7),则认为这两个框表示的是同一个目标,于是根据置信度较低的原则,剔除这个低置信度的边界框。

  5.重复选择过程:继续选择剩余边界框中置信度最高的,重复计算IOU和剔除过程,直到所有边界框都被检查过。

  6.结束,选出最优框

三、YOLOV10创新点

  YOLOv10通过引入双重标签分配策略和一致匹配度量,成功去除了非最大抑制(NMS)机制。
  双重标签分配策略:其中包括一对多和一对一两种分配模式。这种策略不仅提供了丰富的监督信号,确保了训练过程中的准确性,而且避免了在推理阶段使用NMS,从而提高了整体的效率。这一创新的方法有效地平衡了训练与推理之间的需求。
  一致匹配度量:该策略确保了在训练过程中,不同的预测头产生的预测结果能够保持一致性。这种一致性的优化进一步保证了在去除NMS的情况下,模型仍然能够维持高性能和高准确性。

四、YOLOv10使用教程

  YOLOv10进行了高度封装,使用步骤也很简单,我常规的使用方法是通过OpenCV读取rtsp流进行检测

import cv2
from ultralytics import YOLOv10
detect = YOLOv10("yolov10s.pt")

if __name__ == '__main__':
    cap = cv2.VideoCapture(rtsp)
    while cap.isOpened():
        success, frame = cap.read()
        if success:
            results = detect.predict(frame)
            # 返回json格式的数据,需要不同的格式具体可以查看源码
            print(results[0].tosjon())
        else:
            cap = cv2.VideoCapture(rtsp)

YOLOv10 提供了多种模型:

模型说明
YOLOv10-N用于资源极其有限环境的纳米版本
YOLOv10-S兼顾速度和精度的小型版本
YOLOv10-M通用中型版本
YOLOv10-B平衡型,宽度增加,精度更高
YOLOv10-L大型版本,精度更高,但计算资源增加
YOLOv10-X超大型版本可实现最高精度和性能

五、官方github地址

https://github.com/THU-MIG/yolov10

在这里插入图片描述

标签:__,置信度,NMS,检测,实时,YOLOv10,边界,端到
From: https://blog.csdn.net/weixin_46105038/article/details/140347552

相关文章

  • 机器学习:详解什么是端到端的深度学习?(What is end-to-end deep learning?)
    什么是端到端的深度学习?深度学习中最令人振奋的最新动态之一就是端到端深度学习的兴起,那么端到端学习到底是什么呢?简而言之,以前有一些数据处理系统或者学习系统,它们需要多个阶段的处理。那么端到端深度学习就是忽略所有这些不同的阶段,用单个神经网络代替它。来看一些例子,以语音......
  • SpringBoot整合Flink CDC,实时追踪mysql数据变动
    ❃博主首页:「码到三十五」,同名公众号:「码到三十五」,wx号:「liwu0213」☠博主专栏:<mysql高手><elasticsearch高手><源码解读><java核心><面试攻关>♝博主的话:搬的每块砖,皆为峰峦之基;公众号搜索「码到三十五」关注这个爱发技术干货的coder,......
  • Java中的WebSocket编程:实时通信实现
    Java中的WebSocket编程:实时通信实现大家好,我是微赚淘客系统3.0的小编,是个冬天不穿秋裤,天冷也要风度的程序猿!实时通信在现代应用中变得越来越重要,从即时聊天到实时数据更新,WebSocket提供了一种高效的解决方案。本文将详细讲解如何在Java中使用WebSocket进行实时通信,涵盖基本的WebS......
  • 实时系统中的目标检测:速度与精度的较量
    实时系统中的目标检测:速度与精度的较量目标检测算法是计算机视觉领域的基石之一,广泛应用于实时系统中,如视频监控、自动驾驶汽车、工业自动化等。然而,将目标检测算法应用于实时系统并非易事,它带来了一系列技术挑战。本文将探讨这些挑战,并讨论可能的解决方案,同时提供代码示例......
  • 【YOLOv8】实战一:手把手教你使用YOLOv8实现实时目标检测
    前言从2015年首次发布以来,YouOnlyLookOnce(YOLO)系列计算机视觉模型一直是该领域最受欢迎的模型之一。其中,YOLO架构的核心创新是将目标检测任务视为回归问题,从而使模型同时对所有目标边界框和类别概率生成预测。在过去的八年中,这种架构创新催生了一系列YOLO模型。之......
  • 制造业生产数据实时同步,怎样才能减轻IT人员的压力?
    制造业生产数据是制造业企业运营过程中产生的各种与生产活动相关的数据集合。这些数据对于企业的生产管理、决策制定、成本控制以及质量提升等方面都具有重要意义。制造业生产数据包含多种,如产量数据、生产进度数据、生产效率数据、质量数据、成本数据等。制造业生产数据有数据......
  • 解锁Nginx日志的宝藏:GoAccess——你的实时、交互式Web日志分析神器!
    在当今数字化的时代,网站的流量和用户行为数据就像是一座蕴藏着无尽秘密的宝藏。而如何有效地挖掘和分析这些数据,成为了许多网站管理者和开发者头疼的问题。GoAccess,一款开源的实时Web日志分析工具,或许能为我们提供一扇窥探这些秘密的窗口。GoAccess:你的流量分析好帮手GoAccess......
  • 探索扫描二维码登录的奥秘:从前端到后端的无缝连接
    ......
  • 极速数据共享,超越想象——反射内存卡,您的实时通信卓越之选
    在当今数字化的快节奏世界中,数据的快速、准确和实时传输是成功的关键。反射内存卡,作为一种尖端的数据传输解决方案,正引领着行业的变革,为您开启高速数据共享的新篇章。超高速传输,微秒级延迟反射内存卡以其令人惊叹的传输速度脱颖而出。在瞬息万变的业务环境中,每一刻都至关重要。......
  • 【Remotery】 Remotery-轻量级的远程实时 CPU/GPU 分析器设计浅析
    1.Remotery简介Remotery是一个轻量级的远程实时CPU/GPU分析器,主要用于监控CPU和GPU上多线程的活动。它提供了一个C文件,可以很容易的集成到项目中,并配置一个实时监控的Web界面,可以通过远程观察和分析程序的性能,适用于监控游戏的实时运行性能和分析移动端应用的性能场景。2.Remot......