系列文章目录

目标跟踪——SORT算法原理浅析
目标跟踪——Deep Sort算法原理浅析
基于yolov5与Deep Sort的流量统计与轨迹跟踪


文章目录

  • 系列文章目录
  • 前言
  • 一、整体目录结构
  • 二、Deep Sort代码参数解释
  • 三、代码展示
  • 总结

前言

先来看下实现效果:

上图展示了用yolov5作为检测器,Deep Sort为追踪器实现了对车流量的统计并绘制了每辆车的运行轨迹。


一、整体目录结构

下图展示了项目的整体目录结构:

其中:
deep_sort文件下为目标跟踪相关代码;
weights文件夹下存放yolov5检测模型;
demo.py针对读取的视频进行目标追踪
objdetector.py封装的一个目标检测器,对视频中的物体进行检测
objtracker.py封装了一个目标追踪器,对检测的物体进行追踪

二、Deep Sort代码参数解释

deep_sort/configs/deep_sort.yaml文件里保存了Deep Sort算法的配置参数:


这些参数依次的含义为:

  1. REID_CKPT:特征提取权重的目录路径
  2. MAX_DIST: 最大余弦距离,用于级联匹配,如果大于该阈值,则忽略
  3. MIN_CONFIDENCE:检测结果置信度阈值
  4. NMS_MAX_OVERLAP: 非极大抑制阈值,设置为1代表不进行抑制
  5. MAX_IOU_DISTANCE: 最大IOU阈值
  6. MAX_AGE:最大寿命,也就是经过MAX_AGE帧没有追踪到该物体,就将该轨迹变为删除态
  7. N_INIT: 最高击中次数,如果击中该次数,就由不确定态转为确定态
  8. NN_BUDGET: 最大保存特征帧数,如果超过该帧数,将进行滚动保存

三、代码展示

下面给出demo.py的代码:

import numpy as npimport objtracker
from objdetector import Detector
import cv2VIDEO_PATH = './video/test_traffic.mp4'if __name__ == '__main__':# 根据视频尺寸,填充供撞线计算使用的polygonwidth = 1920height = 1080mask_image_temp = np.zeros((height, width), dtype=np.uint8)# 用于记录轨迹信息pts = {}# 填充第一个撞线polygon(蓝色)list_pts_blue = [[204, 305], [227, 431], [605, 522], [1101, 464], [1900, 601], [1902, 495], [1125, 379], [604, 437],[299, 375], [267, 289]]ndarray_pts_blue = np.array(list_pts_blue, np.int32)polygon_blue_value_1 = cv2.fillPoly(mask_image_temp, [ndarray_pts_blue], color=1)polygon_blue_value_1 = polygon_blue_value_1[:, :, np.newaxis]# 填充第二个撞线polygon(黄色)mask_image_temp = np.zeros((height, width), dtype=np.uint8)list_pts_yellow = [[181, 305], [207, 442], [603, 544], [1107, 485], [1898, 625], [1893, 701], [1101, 568],[594, 637], [118, 483], [109, 303]]ndarray_pts_yellow = np.array(list_pts_yellow, np.int32)polygon_yellow_value_2 = cv2.fillPoly(mask_image_temp, [ndarray_pts_yellow], color=2)polygon_yellow_value_2 = polygon_yellow_value_2[:, :, np.newaxis]# 撞线检测用的mask,包含2个polygon,(值范围 0、1、2),供撞线计算使用polygon_mask_blue_and_yellow = polygon_blue_value_1 + polygon_yellow_value_2# 缩小尺寸,1920x1080->960x540polygon_mask_blue_and_yellow = cv2.resize(polygon_mask_blue_and_yellow, (width // 2, height // 2))# 蓝 色盘 b,g,rblue_color_plate = [255, 0, 0]# 蓝 polygon图片blue_image = np.array(polygon_blue_value_1 * blue_color_plate, np.uint8)# 黄 色盘yellow_color_plate = [0, 255, 255]# 黄 polygon图片yellow_image = np.array(polygon_yellow_value_2 * yellow_color_plate, np.uint8)# 彩色图片(值范围 0-255)color_polygons_image = blue_image + yellow_image# 缩小尺寸,1920x1080->960x540color_polygons_image = cv2.resize(color_polygons_image, (width // 2, height // 2))# list 与蓝色polygon重叠list_overlapping_blue_polygon = []# list 与黄色polygon重叠list_overlapping_yellow_polygon = []# 下行数量down_count = 0# 上行数量up_count = 0font_draw_number = cv2.FONT_HERSHEY_SIMPLEXdraw_text_postion = (int((width / 2) * 0.01), int((height / 2) * 0.05))# 实例化yolov5检测器detector = Detector()# 打开视频capture = cv2.VideoCapture(VIDEO_PATH)while True:# 读取每帧图片_, im = capture.read()if im is None:break# 缩小尺寸,1920x1080->960x540im = cv2.resize(im, (width // 2, height // 2))list_bboxs = []# 更新跟踪器output_image_frame, list_bboxs = objtracker.update(detector, im)# 输出图片output_image_frame = cv2.add(output_image_frame, color_polygons_image)if len(list_bboxs) > 0:# ----------------------判断撞线----------------------for item_bbox in list_bboxs:x1, y1, x2, y2, _, track_id = item_bbox# 撞线检测点,(x1,y1),y方向偏移比例 0.0~1.0y1_offset = int(y1 + ((y2 - y1) * 0.5))x1_offset = int(x1 + ((x2 - x1) * 0.5))# 撞线的点y = y1_offsetx = x1_offset# 然后每检测出一个预测框,就将中心点加入队列center = (x, y)if track_id in pts:pts[track_id].append(center)else:pts[track_id] = []pts[track_id].append(center)thickness = 2cv2.circle(output_image_frame, (center), 1, [255, 255, 255], thickness)for j in range(1, len(pts[track_id])):if pts[track_id][j - 1] is None or pts[track_id][j] is None:continuecv2.line(output_image_frame, (pts[track_id][j - 1]), (pts[track_id][j]), [255, 255, 255], thickness)if polygon_mask_blue_and_yellow[y, x] == 1:# 如果撞 蓝polygonif track_id not in list_overlapping_blue_polygon:list_overlapping_blue_polygon.append(track_id)# 判断 黄polygon list里是否有此 track_id# 有此track_id,则认为是 UP (上行)方向if track_id in list_overlapping_yellow_polygon:# 上行+1up_count += 1print('up count:', up_count, ', up id:', list_overlapping_yellow_polygon)# 删除 黄polygon list 中的此idlist_overlapping_yellow_polygon.remove(track_id)elif polygon_mask_blue_and_yellow[y, x] == 2:# 如果撞 黄polygonif track_id not in list_overlapping_yellow_polygon:list_overlapping_yellow_polygon.append(track_id)# 判断 蓝polygon list 里是否有此 track_id# 有此 track_id,则 认为是 DOWN(下行)方向if track_id in list_overlapping_blue_polygon:# 下行+1down_count += 1print('down count:', down_count, ', down id:', list_overlapping_blue_polygon)# 删除 蓝polygon list 中的此idlist_overlapping_blue_polygon.remove(track_id)# ----------------------清除无用id----------------------list_overlapping_all = list_overlapping_yellow_polygon + list_overlapping_blue_polygonfor id1 in list_overlapping_all:is_found = Falsefor _, _, _, _, _, bbox_id in list_bboxs:if bbox_id == id1:is_found = Trueif not is_found:# 如果没找到,删除idif id1 in list_overlapping_yellow_polygon:list_overlapping_yellow_polygon.remove(id1)if id1 in list_overlapping_blue_polygon:list_overlapping_blue_polygon.remove(id1)list_overlapping_all.clear()# 清空listlist_bboxs.clear()else:# 如果图像中没有任何的bbox,则清空listlist_overlapping_blue_polygon.clear()list_overlapping_yellow_polygon.clear()# 输出计数信息text_draw = 'DOWN: ' + str(down_count) + \' , UP: ' + str(up_count)output_image_frame = cv2.putText(img=output_image_frame, text=text_draw,org=draw_text_postion,fontFace=font_draw_number,fontScale=0.75, color=(0, 0, 255), thickness=2)cv2.imshow('Counting Demo', output_image_frame)cv2.waitKey(1)capture.release()cv2.destroyAllWindows()

若需要更改模型,只需要更改objdetector.py下面的给出的部分:

OBJ_LIST = ['person', 'car', 'bus', 'truck']
DETECTOR_PATH = 'weights/yolov5m.pt'

总结

本篇文章给出了基于yolov5与Deep Sort的流量统计与轨迹跟踪的实例,在项目中有着实际的应用场景。
下面给出源码地址,欢迎star
https://github.com/JulyLi2019/yolov5-deepsort/releases/tag/V1.0,yolov5-deepsort.zip文件
如果阅读本文对你有用,欢迎一键三连呀!!!
2022年4月15日09:59:53

基于yolov5与Deep Sort的流量统计与轨迹跟踪相关推荐

  1. 基于matlab单目视觉焊缝跟踪系统,基于激光线结构光3D视觉的机器人轨迹跟踪方法与应用...

    摘要: 本文利用工控机.图像采集卡.工业相机和激光器,设计了激光线结构光3D视觉系统;利用工控机.运动控制卡.伺服驱动器和六轴串联机器人组成机器人运动系统;两者共同构成基于激光线结构光的机器人轨迹跟踪 ...

  2. 轨迹绕圈算法_基于三次B样条曲线拟合的智能车轨迹跟踪算法

    收稿日期:2017-10-30; 修回日期:2017-12-10; 录用日期:2017-12-19. 基金项目: 国家自然科学基金资助项目( 91420202,61372088) . 作者简介: 张永 ...

  3. 基于模型预测(MPC)的无人驾驶汽车轨迹跟踪

      先推荐下自己的公众号--Joe学习笔记,公众号上会不定期更新一些文章,主要是自己平时学到的知识,内容包括自动驾驶.计算机视觉.人工智能和机器人技术.我会第一时间把文章更新在公众号上,欢迎大家订阅和 ...

  4. 基于yolov5和deepsort的行人车辆的检测、跟踪和计数(课程设计)

    - 实现了行人出入分别计数,沿着图像上下方向检测. - 检测类别:行人.自行车.小汽车.摩托车.公交车.卡车. -支持yolov5s.pt yolov5x.pt yolov5m.pt yolov5l. ...

  5. 自定义ava数据集及训练与测试 完整版 时空动作/行为 视频数据集制作 yolov5, deep sort, VIA MMAction, SlowFast

    前言 这一篇博客应该是我花时间最多的一次了,从2022年1月底至2022年4月底. 我已经将这篇博客的内容写为论文,上传至arxiv:https://arxiv.org/pdf/2204.10160. ...

  6. Jetson 系列——基于yolov5对火源或者烟雾的检测,使用tensorrt、c++和int8加速

    项目简介: 代码地址: github地址:https://github.com/RichardoMrMu/yolov5-fire-smoke-detect gitee地址:https://gitee. ...

  7. 【深度学习】Yolov5_DeepSort_Pytorch:基于 Yolov5 + Deep Sort 的实时多目标跟踪器

    简介 该存储库包含一个两阶段跟踪器.YOLOv5(一系列在 COCO 数据集上预训练的对象检测架构和模型)生成的检测被传递到跟踪对象的 Deep Sort 算法.它可以跟踪Yolov5 模型经过训练可 ...

  8. 基于Yolov5+Aidlux的人流量统计测试

    最近几天跟着AI界的大V江大白体验了一把基于Yolov5框架实现人流统计,觉得现在实现AI真的是触手可及,至少之前没有这么觉得过.个人转行进入教育行业将近4年,在此期间虽然也自娱自乐搞一些AI项目,但 ...

  9. 基于ASP.NET网站流量统计系统的设计与实现

    在这个网络急速发展的时代,网站在日常生活中是必不可少的,网站所产生的付出回报率相对应的就显得尤为重要,一个强大.方便的网络流量统计管理系统能使网站的使用变得更加方便快捷.当前国内在这个方面的研究做的比 ...

  10. 基于java的流量数据检测_java网站流量统计管理系统

    每天记录学习,每天会有好心情.*^_^* 今天将为大家分析一个基于web的java网站流量统计管理系统,基于Web的网站访问流量统计系统在功能上强化了对用户行为的统计和分析,有利于网站管理者.开发者根 ...

最新文章

  1. 深度学习实战_五天入门深度学习,这里有一份PyTorch实战课程
  2. Windows 64位驱动 关闭内存保护
  3. mysql 执行计划不对_关于mysql主从查询执行计划不一致问题的分析
  4. 向上滚动 终端_ubuntu
  5. python单链表实现具体例子_Python实现数据结构线性链表(单链表)算法示例
  6. add_argument函数action参数的store_true==》在运行程序添加参数时直接输入变量名,可以省略对应的默认值True或者False
  7. 广东哪个服务器稳定,稳定服务器地址广东
  8. openlayers属性数据mysql_OpenLayers学习笔记8——使用servlet从mysql获取数据并标注
  9. Android零基础入门第86节:探究Fragment生命周期
  10. unix network programming volume1 sorce code build and get(UNIX網絡編程卷1第三版)
  11. 如何给网站添加支付宝支付功能
  12. 选择checkbox显示隐藏内容
  13. 4种“附近的人”实现方式
  14. 麻将判断胡牌 java_麻将基本胡的算法——Java
  15. 为什么微信转账,对方收款要确认,而支付宝不用?
  16. 联想拯救者安装Ubuntu 16.04 系统时显示WiFi无法连接被禁用
  17. 【DEBUG】mxs-auart mxs-auart.0: Unhandled status 520080
  18. UE4-4.26蓝图功能实现:按键升降电梯
  19. Hive第三天——Hive使用(二)(join语句)
  20. 搭建个人的Leanote云笔记本

热门文章

  1. Android(安卓)手机变砖复活的三种恢复方法
  2. 编写DBUtil及测试
  3. redis复习(参考书籍redis设计与实现)
  4. 研发、运营必备实用工具网站
  5. nexus的下载和安装
  6. Gaussian 安装
  7. 电力用户用电信息采集系统通信协议报文解析示例
  8. 用HTML做一份个人简历
  9. matlab啁啾信号,啁啾信号chirp(扫频余弦信号)
  10. MindMaster Pro 7.2中文版 — 亿图思维导图