YoloV5对水域中游泳者进行检测
一、说明
1.1 项目说明
完整代码下载地址:YOLOv5进行水域游泳者检测系统源码+标注好的数据集
本项目是使用 YoloV5 来训练自己的数据集,所以仅仅展示训练自定义数据集的过程。
本次视频检测的结果已经上传至B站:https://www.bilibili.com/video/BV1zf4y1h717
如果想要训练自己的数据集,强烈推荐去 github 下载最新的代码,因为最新的代码目录结构可能发生改变,以最新的代码为准。
1.2 数据集说明
数据集存放在项目根路径的 myDataSet
文件夹内,但是在实际训练时,请按照作者要求的目录机构组织数据集的位置,即让数据集和项目位于同级目录下。
swimmer_img
这个数据集是本人自己标注的水域游泳者的数据集,共有118张图片。
coco128
这个是从官网下的 coco128 数据集,已经标注好了的。
BCCD.v1-resize-416x416.yolov5pytorch
这是是血细胞的数据集,可以用来检测血细胞,同样也是标注好了的数据集,数据集来源于 B 站。
二、检测效果截图
- 检测水域游泳者
- 检测血细胞
- 数据集的标注
三、训练步骤
3.1 组织目录结构
项目工程代码位于 yolov5-develp
目录项目,标注好的数据集位于 swimmer_img
里面
3.2 编写数据集配置文件
修改位于 models/yolov5s_swimmer.yaml
的文件内容。
主要是修改 nc 参数的值,这里我们有 person 和 swimmer 两种类型的目标,所以 nc 设置为 2。
# parameters
nc: 2 # number of classes
depth_multiple: 0.33 # model depth multiple
width_multiple: 0.50 # layer channel multiple
# anchors
anchors:
- [10,13, 16,30, 33,23] # P3/8
- [30,61, 62,45, 59,119] # P4/16
- [116,90, 156,198, 373,326] # P5/32
# YOLOv5 backbone
backbone:
# [from, number, module, args]
[[-1, 1, Focus, [64, 3]], # 0-P1/2
[-1, 1, Conv, [128, 3, 2]], # 1-P2/4
[-1, 3, C3, [128]],
[-1, 1, Conv, [256, 3, 2]], # 3-P3/8
[-1, 9, C3, [256]],
[-1, 1, Conv, [512, 3, 2]], # 5-P4/16
[-1, 9, C3, [512]],
[-1, 1, Conv, [1024, 3, 2]], # 7-P5/32
[-1, 1, SPP, [1024, [5, 9, 13]]],
[-1, 3, C3, [1024, False]], # 9
]
# YOLOv5 head
head:
[[-1, 1, Conv, [512, 1, 1]],
[-1, 1, nn.Upsample, [None, 2, 'nearest']],
[[-1, 6], 1, Concat, [1]], # cat backbone P4
[-1, 3, C3, [512, False]], # 13
[-1, 1, Conv, [256, 1, 1]],
[-1, 1, nn.Upsample, [None, 2, 'nearest']],
[[-1, 4], 1, Concat, [1]], # cat backbone P3
[-1, 3, C3, [256, False]], # 17 (P3/8-small)
[-1, 1, Conv, [256, 3, 2]],
[[-1, 14], 1, Concat, [1]], # cat head P4
[-1, 3, C3, [512, False]], # 20 (P4/16-medium)
[-1, 1, Conv, [512, 3, 2]],
[[-1, 10], 1, Concat, [1]], # cat head P5
[-1, 3, C3, [1024, False]], # 23 (P5/32-large)
[[17, 20, 23], 1, Detect, [nc, anchors]], # Detect(P3, P4, P5)
]
3.3 编写模型配置文件
编辑 /data/swimmer.yaml
文件。
修改 train 参数和 val 参数,这 2 个参数设置用来指定数据集的路径。
修改 nc 参数为识别的目标类别个数。
修改 names 参数为类别名称,名称要和标注图片时的下标对应起来。
# COCO 2017 dataset http://cocodataset.org - first 128 training images
# Train command: python train.py --data coco128.yaml
# Default dataset location is next to YOLOv5:
# /parent_folder
# /coco128
# /yolov5
# download command/URL (optional)
# download: https://github.com/ultralytics/yolov5/releases/download/v1.0/coco128.zip
# train and val data as 1) directory: path/images/, 2) file: path/images.txt, or 3) list: [path1/images/, path2/images/]
train: ../swimmer_img/images/ # 128 images
val: ../swimmer_img/images/ # 128 images
# number of classes
nc: 2
# class names
names: ['swimmer', 'water' ]
3.4 开始训练
具体的各个参数可以看 train.py 里面有具体的解释
python train.py --img 640 --batch 16 --epochs 100 --data ./data/swimmer.yaml --cfg ./models/yolov5s_swimmer.yaml --weights weights/yolov5s.pt --name yolov5s_swimmer
可以去官网下载对应的预训练模型,我下载的预训练模型放在 weights/yolov5s.pt
。
预训练模型的尽量和项目的版本一致,否则会导致训练失败。
四、查看结果
在 /runs/train
文件夹下存放每次训练的结果,最后一层训练成功的结果位于 yolov5s_swimmer2
文件夹下。
在 /runs/detect
文件夹下存放检测的结果,exp10
,exp11
,exp12
存放的是对图片检测的结果, swimmer_video2
存放的是对视频检测到的结果。
完整代码下载地址:YOLOv5进行水域游泳者检测系统源码+标注好的数据集