使用YOLOv8和ByteTracker进行实时人员跟踪和计数

 
 
 
 

点击上方“小白学视觉”,选择加"星标"或“置顶

重磅干货,第一时间送达

在计算机视觉领域,实时跟踪和统计人数对于各种应用至关重要,从监控到事件管理。在这篇博客文章中,我们将探讨如何利用YOLOv8和ByteTracker实现准确的人数统计。

5a54c4302ddfa8b97f9704ef81838c51.png

引言

  1. YOLOv8(You Only Look Once,第八版)是一种以其速度和准确性而闻名的最新对象检测模型。

  2. ByteTracker是一种先进的跟踪算法,旨在维持对象在帧之间的身份,使其成为执行人数统计等任务的理想选择。

这种组合不仅允许我们在帧中检测到人,而且还能够跟踪他们在帧之间的移动,为实时人数统计提供了强大的解决方案。

先决条件

在深入实现之前,请确保您具备以下条件:

  • Python 3.10

  • Ultralytics

设置环境

首先,创建并激活虚拟环境以管理依赖项:

conda create -n person-tracker python==3.10
conda activate person-tracker

安装必要的库:

pip install ultralytics

实现人数统计

1. 导入库从导入所需的库开始:

from ultralytics import YOLO
from datetime import datetime
import os

2. 定义PersonTracker类

创建一个PersonTracker类,该类集成了用于检测的YOLOv8和用于跟踪的ByteTracker:

class PersonTracker:
    def __init__(self, model_path, result_dir='results/', tracker_config="bytetrack.yaml", conf=0.5, device='cuda:0',
                 iou=0.5, img_size=(720, 1080)):
        self.model = YOLO(model_path)
        self.result_dir = result_dir
        self.tracker_config = tracker_config
        self.conf = conf
        self.device = device
        self.iou = iou
        self.img_size = img_size


    def create_result_file(self):
        folder_name = datetime.now().strftime("%Y-%m-%d-%H-%M-%S")
        result_file_path = os.path.join(self.result_dir, folder_name + ".txt")
        os.makedirs(self.result_dir, exist_ok=True)
        with open(result_file_path, 'w') as file:
            file.write(folder_name + "\n")
        return result_file_path


    def detect_and_track(self, source, show=True, logger=None):
        result_file = self.create_result_file()
        person_count = 0
        previous_person_count = 0


        results = self.model.track(
            source, show=show, stream=True, tracker=self.tracker_config, conf=self.conf,
            device=self.device, iou=self.iou, stream_buffer=True, classes=[0], imgsz=self.img_size
        )


        for i, result in enumerate(results):
            boxes = result.boxes
            try:
                id_count = boxes.id.int().tolist()
                max_id = max(id_count)


                if max_id > person_count:
                    person_count = max_id


                if person_count != previous_person_count:
                    previous_person_count = person_count
                    with open(result_file, 'a') as filewrite:
                        filewrite.write(f"Person count: {person_count}\n")


                    if logger:
                        logger.info(f"Person count: {person_count}")


            except Exception as e:
                pass

3. 运行人员跟踪器

  • 视频文件跟踪

if __name__ == '__main__':
    source = "path/to/your/video.mp4"
    tracker = PersonTracker(model_path='path/to/yolov8_model.pt')
    tracker.detect_and_track(source=source)
  • 网络摄像头跟踪

if __name__ == '__main__':
    source = 0  # Use 0 for the default webcam
    tracker = PersonTracker(model_path='path/to/yolov8_model.pt')
    tracker.detect_and_track(source=source)
  • RTSP流跟踪

if __name__ == '__main__':
    source = 'rtsp://username:password@ip_address:port/path'
    tracker = PersonTracker(model_path='path/to/yolov8_model.pt')
    tracker.detect_and_track(source=source)

支持的模型

对于YOLOv8,模型通常根据它们的准确性和速度权衡进行分类。通常支持以下模型:

  • YOLOv8n(Nano):提供高速度和较低的准确性。非常适合处理速度的实时应用

  • YOLOv8s(Small):平衡速度和准确性。适用于许多实际应用。

  • YOLOv8m(Medium):在速度和准确性之间提供良好的权衡。适用于更苛刻的应用。

  • YOLOv8l(Large):高准确性,速度较低。最适合准确性为优先考虑的场景。

结论

通过结合YOLOv8和ByteTracker,您可以有效地在帧之间检测和跟踪人员,提供准确的计数和有价值的洞察。这个解决方案可以扩展到需要实时个人监控和分析的各种应用。

参考文献

  • YOLOv8文档:https://docs.ultralytics.com/

  • ByteTracker论文:https://arxiv.org/abs/2005.03659

  • 源码:https://github.com/ishworrsubedii/person_tracker

下载1:OpenCV-Contrib扩展模块中文版教程

在「小白学视觉」公众号后台回复:扩展模块中文教程,即可下载全网第一份OpenCV扩展模块教程中文版,涵盖扩展模块安装、SFM算法、立体视觉、目标跟踪、生物视觉、超分辨率处理等二十多章内容。


下载2:Python视觉实战项目52讲
在「小白学视觉」公众号后台回复:Python视觉实战项目,即可下载包括图像分割、口罩检测、车道线检测、车辆计数、添加眼线、车牌识别、字符识别、情绪检测、文本内容提取、面部识别等31个视觉实战项目,助力快速学校计算机视觉。


下载3:OpenCV实战项目20讲
在「小白学视觉」公众号后台回复:OpenCV实战项目20讲,即可下载含有20个基于OpenCV实现20个实战项目,实现OpenCV学习进阶。


交流群

欢迎加入公众号读者群一起和同行交流,目前有SLAM、三维视觉、传感器、自动驾驶、计算摄影、检测、分割、识别、医学影像、GAN、算法竞赛等微信群(以后会逐渐细分),请扫描下面微信号加群,备注:”昵称+学校/公司+研究方向“,例如:”张三 + 上海交大 + 视觉SLAM“。请按照格式备注,否则不予通过。添加成功后会根据研究方向邀请进入相关微信群。请勿在群内发送广告,否则会请出群,谢谢理解~
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值