yolov5_reid【附代码,行人重识别,可做跨视频人员检测】

简介: 该项目利用yolov5+reid实现的行人重识别功能,可做跨视频人员检测。应用场景:可根据行人的穿着、体貌等特征在视频中进行检索,可以把这个人在各个不同摄像头出现时检测出来。可应用于犯罪嫌疑人检索、寻找走失儿童等。

支持功能:

       1.reid训练

       2.人员标注

       3.人员查找(可做跨视频人员检测)

Reid训练

ps:Reid理论部分参考:Reid理论学习


项目支持多网络,如resnet50, resnet50_ibn_a, se_resnext50等主干网络。


下载代码后输入:


python tools/train.py --config_file configs/softmax_triplet.yml MODEL.DEVICE_ID "('0')" DATASETS.NAMES "('market1501')" DATASETS.ROOT_DIR "(r'./data')

其中softmax_triple.yml是配置文件(里面包含了训练epochs,学习率,优化器等参数配置)。


训练可选参数 :


参数说明:


--config_file: 配置文件路径,默认configs/softmax_triplet.yml


--weights: pretrained weight path


--neck: If train with BNNeck, options: bnneck or no


--test_neck: BNNeck to be used for test, before or after BNNneck options: before or after


--model_name: Name of backbone.


--pretrain_choice: Imagenet


--IF_WITH_CENTER: us center loss, True or False.


配置文件的修改:


(注意:项目中有两个配置文件,一个是config下的defaults.py配置文件,一个是configs下的yml配置文件,一般配置yml文件即可,当两个配置文件参数名相同的时候以yml文件为主,这个需要注意一下)


configs文件:


以softmax_triplet.yml为例


SOLVER:

 OPTIMIZER_NAME: 'Adam' # 优化器

 MAX_EPOCHS: 120  # 总epochs

 BASE_LR: 0.00035

 IMS_PER_BATCH: 8  # batch


 CHECKPOINT_PERIOD: 1   # 权重保存周期

 LOG_PERIOD: 1 # 日志周期

 EVAL_PERIOD: 1  # 测试周期,测map

TEST:

 IMS_PER_BATCH: 4 # test batch

 RE_RANKING: 'no'

 WEIGHT: "path"  # test weight path

 FEAT_NORM: 'yes'

OUTPUT_DIR: "/logs" # model save path


=> Market1501 loaded

Dataset statistics:

 ----------------------------------------

 subset   | # ids | # images | # cameras

 ----------------------------------------

 train    |   751 |    12936 |         6

 query    |   750 |     3368 |         6

 gallery  |   751 |    15913 |         6

 ----------------------------------------

Loading pretrained ImageNet model......



2023-02-24 21:08:22.121 | INFO     | engine.trainer:log_training_loss:194 - Epoch[1] Iteration[19/1484] Loss: 9.194, Acc: 0.002, Base Lr: 3.82e-05

2023-02-24 21:08:22.315 | INFO     | engine.trainer:log_training_loss:194 - Epoch[1] Iteration[20/1484] Loss: 9.156, Acc: 0.002, Base Lr: 3.82e-05

2023-02-24 21:08:22.537 | INFO     | engine.trainer:log_training_loss:194 - Epoch[1] Iteration[21/1484] Loss: 9.119, Acc: 0.002, Base Lr: 3.82e-05


训练好的权重会自动保存在logs下。


人员标注

可将视频中嫌疑人(特定人员),可以运行person_search/get_query.py,按住鼠标左键不放,拖动进行人员款选标注,标注后的人员会自动保存在query文件中(命名格式为markt1501),按空格键继续播放视频。


也可以直接将图像放在query文件中,但名字也需要按mark1501命名。




人员查找(yolov5+Reid)

参数说明:


--weights: yolov5权重路径


--source: video/file/ path


--data: data/coco128.yaml


--imgsz: 输入图像大小,默认(640,640)


--conf_thres:置信度阈值


--iou_thres:iou阈值


--classes:过滤的类


--half:半精度推理


--dist_thres:reid对比的距离阈值(小于该阈值判断为同一个人)


--save_res:保存视频图像


python search.py --weights yolov5s.pt --source 0 --dist_thres 1.5

如果需要检测视频或者多视频(跨视频检测),需要指定source路径。


代码:


git clone https://github.com/YINYIPENG-EN/yolov5_reid.git

权重下载:


检测:将 ReID_resnet50_ibn_a.pth放在👂person_search/weights文件下,yolov5s.pt放person_search下


训练:将 r50_ibn_2.pth,resnet50-19c8e357.pth放在yolov5_reid/weights下


注意:训练和检测(person_search)是两个独立的项目!!


链接:百度网盘 请输入提取码 提取码:yypn

————————————————


CSDN链接:https://blog.csdn.net/z240626191s/article/details/129221510

目录
相关文章
|
机器学习/深度学习 存储 算法
【轻量化网络】概述网络进行轻量化处理中的:剪枝、蒸馏、量化
【轻量化网络】概述网络进行轻量化处理中的:剪枝、蒸馏、量化
630 0
|
算法 容器
最详细版本|UI2Code智能生成Flutter代码——机器生成代码
作者: 闲鱼技术-上叶,余晏 背景   在《UI2CODE--整体设计》篇中,我们提到UI2Code工程的整体流程。前步图片分析之后,我们可以得到对应的DSL布局描述。利用DSL的资讯,结合IntelliJ Plugin介面工具,面向使用者提供生成对应Flutter代码。
13012 0
|
7月前
|
机器学习/深度学习 人工智能 算法
Python+YOLO v8 实战:手把手教你打造专属 AI 视觉目标检测模型
本文介绍了如何使用 Python 和 YOLO v8 开发专属的 AI 视觉目标检测模型。首先讲解了 YOLO 的基本概念及其高效精准的特点,接着详细说明了环境搭建步骤,包括安装 Python、PyCharm 和 Ultralytics 库。随后引导读者加载预训练模型进行图片验证,并准备数据集以训练自定义模型。最后,展示了如何验证训练好的模型并提供示例代码。通过本文,你将学会从零开始打造自己的目标检测系统,满足实际场景需求。
6217 0
Python+YOLO v8 实战:手把手教你打造专属 AI 视觉目标检测模型
|
机器学习/深度学习 编解码 Java
YOLO11创新改进系列:卷积,主干 注意力,C3k2融合,检测头等创新机制(已更新100+)
《YOLO11目标检测创新改进与实战案例》专栏已更新100+篇文章,涵盖注意力机制、卷积优化、检测头创新、损失与IOU优化、轻量级网络设计等多方面内容。每周更新3-10篇,提供详细代码和实战案例,帮助您掌握最新研究和实用技巧。[专栏链接](https://blog.csdn.net/shangyanaf/category_12810477.html)
YOLO11创新改进系列:卷积,主干 注意力,C3k2融合,检测头等创新机制(已更新100+)
|
机器学习/深度学习 JSON 算法
语义分割笔记(二):DeepLab V3对图像进行分割(自定义数据集从零到一进行训练、验证和测试)
本文介绍了DeepLab V3在语义分割中的应用,包括数据集准备、模型训练、测试和评估,提供了代码和资源链接。
2992 0
语义分割笔记(二):DeepLab V3对图像进行分割(自定义数据集从零到一进行训练、验证和测试)
|
机器学习/深度学习 算法 PyTorch
目标检测实战(五): 使用YOLOv5-7.0版本对图像进行目标检测完整版(从自定义数据集到测试验证的完整流程)
本文详细介绍了使用YOLOv5-7.0版本进行目标检测的完整流程,包括算法介绍、环境搭建、数据集准备、模型训练、验证、测试以及评价指标。YOLOv5以其高精度、快速度和模型小尺寸在计算机视觉领域受到广泛应用。
5892 0
目标检测实战(五): 使用YOLOv5-7.0版本对图像进行目标检测完整版(从自定义数据集到测试验证的完整流程)
|
机器学习/深度学习 人工智能 算法
AI计算机视觉笔记十一:yolo5+Deepsort实现目标检测与跟踪(CPU版)
DeepSORT是一种基于深度学习的计算机视觉跟踪算法,扩展了SORT算法,通过添加外观描述符减少身份切换,提高跟踪效率。本文档提供了DeepSORT环境搭建步骤,包括创建虚拟环境、安装依赖及解决常见错误等,最终实现人员和车辆的跟踪计数功能。适合无GPU设备的学习者参考。
1079 1
|
机器学习/深度学习 存储 算法
基于YOLOv8与ByteTrack的车辆行人多目标检测与追踪系统【python源码+Pyqt5界面+数据集+训练代码】深度学习实战、目标追踪、运动物体追踪
基于YOLOv8与ByteTrack的车辆行人多目标检测与追踪系统【python源码+Pyqt5界面+数据集+训练代码】深度学习实战、目标追踪、运动物体追踪
|
算法 机器人 计算机视觉
boss:整个卡尔曼滤波器的简单案例——估计机器人位置
boss:整个卡尔曼滤波器的简单案例——估计机器人位置
311 0