深度学习和目标检测系列教程 23-300 :FasterRCNN和yolov5训练飞机目标识别的小项目
Posted 刘润森!
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了深度学习和目标检测系列教程 23-300 :FasterRCNN和yolov5训练飞机目标识别的小项目相关的知识,希望对你有一定的参考价值。
@Author:Runsen
FasterRCNN和yolov5训练飞机目标识别的项目
目标检测算法主要包括:两类two-stage和one-stage
一类是two-stage,two-stage检测算法将检测问题划分为两个阶段,首先产生候选区域(region proposals),然后对候选区域分类(一般还需要对位置精修),这一类的典型代表是R-CNN, Fast R-CNN, Faster R-CNN,Mask R-CNN家族。他们识别错误率低,漏识别率也较低,但速度较慢,不能满足实时检测场景。
另一类方式称为one-stage检测算法,其不需要region proposal阶段,直接产生物体的类别概率和位置坐标值,经过单次检测即可直接得到最终的检测结果,因此有着更快的检测速度,比较典型的算法如YOLOv5,SSD,RetinaNet等。
FasterRCNN和yolov5可以说是目前最先进的两类算法,本次将使用FasterRCNN和yolov5训练飞机目标识别的项目
数据集来源:从COCO2017 val的图片中随机抽取99张包含飞机类别目标的图片来构成mini-airplane数据集,抽取的代码位于
COCO2017 val 下载地址:https://github.com/ultralytics/yolov5/releases/download/v1.0/coco2017val.zip
generate_mini_airplane.py 从COCO2017 val的图片中随机抽取99张包含飞机类别目标的图片来构成mini-airplane数据集
FasterRCNN
FasterRCNN相关教程:https://work.datafountain.cn/forum?id=4791&type=1&source=2
文件夹中FasterRCNN
- coco 官方的文件
- dataset torch读取数据集
- model FasterRCNN 预训练模型 修改输出
- data_split 生成训练集和测试集
(base) ng@ng-Z390:/home/lrs/demo/fastrcnn$ python ./coco/coco_eval.py ../results/val_results.json --ann ../mini_airplane/annotations/val.json
fastrcnn训练测试结果
results/val_vis中存放了fastrcnn模型测试结果
模型保存到models文件夹中。
yolo
yolo相关教程:https://work.datafountain.cn/forum?id=89&type=2&source=1
上面教程基于yolov3,可以参考github上的v5教程。对数据进行相关的处理
由于coco数据存在相关的yolo数据,只需要划分训练集和测试集即可,脚本是yolo_split_data.py,
mini-airplane.yaml
train: ../mini_airplane/ImageSets/Main/train.txt
val: ../mini_airplane/ImageSets/Main/val.txt
test: ../mini_airplane/ImageSets/Main/test.txt
# number of classes
nc: 1
# class names
names: ['airplane']
对应模型的yaml文件将80设置为1。
在yolo文件夹中,执行各yolov5模型训练代码
python train.py --img 610 --batch 32 --epochs 100 --data data/mini-airplane.yaml --cfg models/yolov5s.yaml --weights weights/yolov5s.pt --name=yolov5s
yolo5s的map非常出乎我的意料,一直保持0.01不动
python train.py --img 610 --batch 16 --epochs 100 --data data/mini-airplane.yaml --cfg models/yolov5m.yaml --weights weights/yolov5m.pt --name=yolov5m
yolo5m的map0.5=0.823
python train.py --img 610 --batch 8 --epochs 100 --data data/mini-airplane.yaml --cfg models/yolov5l.yaml --weights weights/yolov5l.pt --name=yolo5l
yolo5l的map0.5=0.9
python train.py --img 610 --batch 8 --epochs 100 --data data/mini-airplane.yaml --cfg models/yolov5x.yaml --weights weights/yolov5x.pt --name=yolov5x
yolo5x的map0.5=0.78
下面的测试使用yolo5l 90精确度的模型:测试并保存对应的–save-txt
python detect.py --weights runs/train/yolo5l/weights/best.pt --img 610 --conf 0.4 --source ../mini_airplane/images --save-txt
下面是yolo5l模型测试结果
附上Github:https://github.com/MaoliRUNsen/yolov5-fastercnn
训练模型没有任何价值,Github上传数据大小有限,没有对应模型文件
以上是关于深度学习和目标检测系列教程 23-300 :FasterRCNN和yolov5训练飞机目标识别的小项目的主要内容,如果未能解决你的问题,请参考以下文章
深度学习和目标检测系列教程 3-300:了解常见的目标检测的开源数据集
深度学习和目标检测系列教程 2-300:小试牛刀,使用 ImageAI 进行对象检测
深度学习和目标检测系列教程 19-300:关于目标检测APIoU和mAP简介
深度学习和目标检测系列教程 19-300:关于目标检测APIoU和mAP简介