YOLOv5+DeepSort的汽车流量统计

前言

先来看下实现效果:

在这里插入图片描述

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

一、整体目录结构

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

在这里插入图片描述

其中:

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

二、DeepSort代码参数解释

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

在这里插入图片描述
在这里插入图片描述

这些参数依次的含义为:

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

总结

本篇文章给出了基于yolov5DeepSort的流量统计与轨迹跟踪的实例,源码地址:
https://github.com/JulyLi2019/yolov5-deepsort/releases/tag/V1.0

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/535258.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

面向IoT物联网的时间序列引擎

1、背景 随着近年来业务的发展,尤其是机器产生的数据占比越来越高的趋势下,时序数据因为其业务价值越来越被更多地关注,也因而催生了专用的时间序列数据库,简称时序数据库(TimeSeries Database,TSDB&#x…

在linux上部署yolov5和安装miniconda3

第一步:安装miniconda3 官网:Miniconda — Anaconda documentation 这四个命令快速而安静地安装最新的64位版本的安装程序,然后自行清理。要为Linux安装Miniconda的不同版本或体系结构,请在wget命令中更改.sh安装程序的名称。 …

淘宝客必看:微信公众号如何快速接入抖音本地团购并提高CPS收益

抖音已经成为社交媒体新的流量高地,抖音团购完全复刻了美团的模式,外卖、到店、吃喝玩乐全覆盖。很多淘宝客一直在寻找通过微信公众号实现营销变现的有效途径?是否对于如何将抖音团购转变为自己的佣金收入感到困惑?微信公众号接入…

Elasticsearch:在本地使用 Gemma LLM 对私人数据进行问答

在本笔记本中,我们的目标是利用 Google 的 Gemma 模型开发 RAG 系统。 我们将使用 Elastic 的 ELSER 模型生成向量并将其存储在 Elasticsearch 中。 此外,我们将探索语义检索技术,并将最热门的搜索结果作为 Gemma 模型的上下文窗口呈现。 此外…

19113133262(微信同号)2024年环境能源与全球市场营销国际学术会议(ICEEGM 2024)

2024年环境能源与全球市场营销国际学术会议(ICEEGM 2024) 会议主题: (主题包括但不限于, 更多主题请咨询会务组苏老师) 节能技术 煤矿工程与技术 能源存储技术 可再生能源 热能与动力工程 能源工程与环境工程 可再生能源技术和系统 能源安全和清洁利用 矿…

自动化运维工具 ---------------Ansible

一、Ansible 发展史及功能 作者:Michael DeHaan( Cobbler pxe kikstar 与 Func 作者)ansible 的名称来自科幻小说《安德的游戏》中跨越时空的即时通信工具,使用它可以在相距数光年的距离,远程实时控制前线的舰队战斗2…

ctf_show笔记篇(web入门---sql注入)171-189

sql注入 171:简单的sql注入,尝试万能密码直接过 172:基础联合查询可过 173:过滤flag那就利用substr少取几个flag的名字或者replace 174:两种方法,使用盲注或者利用replace嵌套替换,然后在逆…

Vue.js+SpringBoot开发考研专业课程管理系统

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 数据中心模块2.2 考研高校模块2.3 高校教师管理模块2.4 考研专业模块2.5 考研政策模块 三、系统设计3.1 用例设计3.2 数据库设计3.2.1 考研高校表3.2.2 高校教师表3.2.3 考研专业表3.2.4 考研政策表 四、系统展示五、核…

AI在金融服务行业的现状及发展趋势

在金融服务行业中,AI的融入和应用已经成为推动该行业发展的关键力量。英伟达发布的第四届年度金融服务行业人工智能现状报告,揭示了2024年AI在金融领域的新兴趋势和应用前景。报告中指出,超过91%的金融服务公司正在评估或已经将AI技术应用到企…

企业跨平台传输大文件的重要性

企业运营的核心之一是数据的高效流通。跨平台传输大文件在企业的日常运作中扮演着至关重要的角色。无论是设计图纸、视频、音乐还是数据集,这些大型文件的快速、安全传输对于企业的创新、协作和决策支持都至关重要。本文将探讨企业跨平台传输大文件的重要性。 企业跨…

(Linux学习九)管道、重定向介绍

FD:文件描述符。 0,1,2,3,,,。进程打开文件所用。 0标准输入 1 标准输出 2 标准错误输出 3普通文件 一、管道 | 命令 | tee | xargs | 命令1的输出,作为命令2的输入,命令2的输出作为命令3的输入 | tee 三通&#xff…

STM32输入捕获频率和占空比proteus仿真失败

这次用了两天的时间来验证这个功能,虽然实验没有成功,但是也要记录一下,后面能解决了,回来再写上解决的办法: 这个程序最后的实验结果是读取到的CCR1和CCR2的值都是0,所以没有办法算出来频率和占空比。 还…