基于YOLOv5的驾驶员疲劳驾驶行为检测系统
创作时间:
作者:
@小白创作中心
基于YOLOv5的驾驶员疲劳驾驶行为检测系统
引用
CSDN
1.
https://blog.csdn.net/m0_63774211/article/details/136547398
疲劳驾驶是导致交通事故的重要原因之一,每年都会造成大量人员伤亡和财产损失。随着信息技术的发展,现在可以通过驾驶员的眼部和嘴部动作来实时监测其疲劳状态,从而及时提醒驾驶员避免疲劳驾驶。
数据集介绍
本文使用的数据集包含2914张图像,主要关注驾驶员的疲劳状态,具体分为四个类别:闭眼(closed_eye)、闭嘴(closed_mouth)、睁眼(open_eye)和张嘴(open_mouth)。
基于YOLOv5的疲劳驾驶行为检测
修改配置文件fatigue.yaml
为了使用YOLOv5进行疲劳驾驶行为检测,需要对配置文件进行相应的修改。以下是修改后的配置文件内容:
# PASCAL VOC dataset http://host.robots.ox.ac.uk/pascal/VOC/
# Download command: bash ./data/get_voc.sh
# Train command: python train.py --data voc.yaml
# Dataset should be placed next to yolov5 folder:
# /parent_folder
# /VOC
# /yolov5
# train and val datasets (image directory or *.txt file with image paths)
train: ./data/fatigue/train.txt # 16551 images
val: ./data/fatigue/val.txt # 4952 images
# number of classes
nc: 4
# class names
names: ['closed_eye','closed_mouth','open_eye','open_mouth']
修改训练脚本train.py
为了适应疲劳驾驶检测任务,还需要对训练脚本进行一些调整。以下是修改后的部分代码:
def parse_opt(known=False):
"""Parses command-line arguments for YOLOv5 training, validation, and testing."""
parser = argparse.ArgumentParser()
parser.add_argument("--weights", type=str, default=ROOT / "weights/yolov5s.pt", help="initial weights path")
parser.add_argument("--cfg", type=str, default="models/yolov5s.yaml", help="model.yaml path")
parser.add_argument("--data", type=str, default=ROOT / "data/fatigue.yaml", help="dataset.yaml path")
parser.add_argument("--hyp", type=str, default=ROOT / "data/hyps/hyp.scratch-low.yaml", help="hyperparameters path")
parser.add_argument("--epochs", type=int, default=50, help="total training epochs")
parser.add_argument("--batch-size", type=int, default=16, help="total batch size for all GPUs, -1 for autobatch")
parser.add_argument("--imgsz", "--img", "--img-size", type=int, default=640, help="train, val image size (pixels)")
parser.add_argument("--rect", action="store_true", help="rectangular training")
parser.add_argument("--resume", nargs="?", const=True, default=False, help="resume most recent training")
parser.add_argument("--nosave", action="store_true", help="only save final checkpoint")
parser.add_argument("--noval", action="store_true", help="only validate final epoch")
parser.add_argument("--noautoanchor", action="store_true", help="disable AutoAnchor")
parser.add_argument("--noplots", action="store_true", help="save no plot files")
parser.add_argument("--evolve", type=int, nargs="?", const=300, help="evolve hyperparameters for x generations")
parser.add_argument(
"--evolve_population", type=str, default=ROOT / "data/hyps", help="location for loading population"
)
结果可视化分析
经过训练和测试,模型在疲劳驾驶行为检测任务上取得了较好的效果。以下是模型的性能指标:
YOLOv5s summary: 157 layers, 7020913 parameters, 0 gradients, 15.8 GFLOPs
Class Images Instances P R mAP50 mAP50-95: 100%|██████████| 25/25 [00:10<00:00, 2.38it/s]
all 787 2109 0.97 0.982 0.99 0.611
closed_eye 787 566 0.953 0.979 0.988 0.54
closed_mouth 787 701 0.986 0.997 0.989 0.622
open_eye 787 774 0.955 0.967 0.988 0.545
open_mouth 787 68 0.985 0.985 0.995 0.736
混淆矩阵
混淆矩阵是一个n×n的矩阵,其中n为分类数目,矩阵的每一行代表一个真实类别,每一列代表一个预测类别,矩阵中的每一个元素表示真实类别为行对应的类别,而预测类别为列对应的类别的样本数。
PR曲线
PR曲线中的P代表的是precision(精准率),R代表的是recall(召回率),其代表的是精准率与召回率的关系,一般情况下,将recall设置为横坐标,precision设置为纵坐标。PR曲线下围成的面积即AP,所有类别AP平均值即Map。
预测结果
热门推荐
中国十大特色小米:从历史到风味的完美传承
拐卖儿童案件关注度上升,警方加强打击力度
摩羯座和射手座挺像的吗
香砂养胃丸的功效与作用及副作用、禁忌是什么
三文鱼做法大揭秘,你真的会吃吗?
闲鱼怎么交易最安全?注意事项有哪些?
物理学四大神兽:从拉普拉斯兽到薛定谔的猫
法师多肉好养吗?养殖方法和养护要点是什么?
他才是中国历史上第一位一夫一妻的皇帝!
二叉树知识点最详细最全讲解
医生解答:喝脱脂牛奶真的能减肥吗?
脱脂牛奶是什么,有什么作用
甘肃分成河西、陇西、陇南、甘南,是怎么划分的?
武曲破军命格:解析其性格与命运影响
2025重庆高考时间安排及科目设置详解
经典动作片《第一滴血》,一举奠定史泰龙巨星地位
一晚起夜几次就算夜尿增多?要治吗
紫微斗数夫妻宫天相星好吗?天相星在十二宫详解
施肇基与伊藤博文被刺案
期货交易入门:基本概念与核心规则详解
汽车导航怎样开启才能精准导航?精准导航的实现需要哪些技术支持?
矾肥水的制作方法、配制比例和使用技巧详解
轰20曝光:搭载涡扇15,中国首创可变垂尾设计,具备跨洋打击能力
牛!中航西飞的亮眼之作
总分公司涉税那些事儿
《中国法律与中国社会》:历史镜鉴下的法律智慧
急性白血病患者如何预防复发?复发了怎么办?
感冒期间维生素C怎么补?医生建议来了
调养身体,一定要搞清楚扶正与祛邪的关系
如何在澳洲留学中快速提升英语水平