使用YOLO11进行驾驶疲劳检测及警报的实战教程
创作时间:
作者:
@小白创作中心
使用YOLO11进行驾驶疲劳检测及警报的实战教程
引用
CSDN
1.
https://blog.csdn.net/qq_42589613/article/details/143956447
本文将研究如何在OpenCV中使用YOLO11对象检测模型来检测视频中的眼睛闭合,并在眼睛闭合超过指定阈值时发出警告。我们还将讨论应用这种方法进行实时检测的可能性。
眼睛闭合检测在许多现实应用中是一个重要的用例,从监测驾驶员疲劳到确保在关键环境中的警觉性。
环境配置
在我们开始之前,请确保您安装了以下库:
- OpenCV:用于视频处理和显示结果。
- Ultralytics YOLO:一种流行且高效的深度学习模型,用于对象检测。
要安装必要的库,可以运行:
pip install opencv-python
pip install ultralytics
闭眼检测基本步骤
- 加载YOLO模型:我们加载一个预先训练好的YOLO模型(
best.pt)进行眼睛检测。这个模型被训练成识别两种状态:“闭”和“开”的眼睛。 - 读取输入视频:使用OpenCV逐帧读取视频。
- 执行对象检测:YOLO用于检测每帧中眼睛的状态,是闭合还是睁开的状态。
- 跟踪眼睛闭合持续时间:如果检测到眼睛“闭合”超过指定阈值,则显示警告。
- 显示结果:结果将写入输出视频文件,如果需要,警告消息将覆盖在帧上。
完整代码
下面是使用YOLO11和OpenCV检测视频中眼睛闭合的完整Python代码:
import cv2
from ultralytics import YOLO
# 加载预训练的YOLO模型
model = YOLO("best.pt")
names = model.names
# 打开视频文件
cap = cv2.VideoCapture("video.mp4")
assert cap.isOpened(), "读取视频文件出错"
w, h, fps = (int(cap.get(x)) for x in (cv2.CAP_PROP_FRAME_WIDTH, cv2.CAP_PROP_FRAME_HEIGHT, cv2.CAP_PROP_FPS))
# 初始化视频写入器以保存输出
video_writer = cv2.VideoWriter("output.avi", cv2.VideoWriter_fourcc(*"mp4v"), fps, (w, h))
# 初始化用于检测眼睛闭合的变量
eye_closed_frames = 0
eye_closed_threshold_seconds = 1 # 阈值(秒)
eye_closed_threshold_frames = eye_closed_threshold_seconds * fps # 将秒转换为帧数
while cap.isOpened():
success, im0 = cap.read()
if not success:
print("视频帧为空或视频处理已成功完成。")
break
# 使用YOLO预测眼睛状态
results = model.predict(im0, show=False)
boxes = results[0].boxes.xyxy.cpu().tolist()
clss = results[0].boxes.cls.cpu().tolist()
annotator = Annotator(im0, line_width=2, example=names)
eye_closed = False # 标记当前帧中眼睛是否闭合
if boxes is not None:
for box, cls in zip(boxes, clss):
clsName = names[int(cls)]
xmax = int(box[0])
ymin = int(box[1])
xmin = int(box[2])
ymax = int(box[3])
# 根据类别名称设置颜色
if clsName == 'closed':
clr = (0, 0, 255)
eye_closed = True # 标记眼睛为闭合
elif clsName == 'opened':
clr = (0, 255, 0)
# 绘制边界框和标签
font = cv2.FONT_HERSHEY_SIMPLEX
font_scale = 1
font_thickness = 2
tw, th = cv2.getTextSize(clsName, font, font_scale, font_thickness)[0]
cv2.rectangle(im0, (xmin, ymin), (xmax, ymax), color=clr, thickness=2)
cv2.putText(im0, clsName, (xmax, ymin - 5), font, font_scale, color=clr, thickness=font_thickness)
# 检查眼睛闭合持续时间
if eye_closed:
eye_closed_frames += 1
else:
# 如果眼睛未闭合,重置计数器
eye_closed_frames = 0
# 如果眼睛闭合时间超过阈值,显示警告
if eye_closed_frames > eye_closed_threshold_frames:
print("警告:眼睛闭合时间超过2秒!")
cv2.putText(im0, "警告:眼睛闭合时间超过2秒!", (50, 50), font, font_scale, (0, 0, 255), font_thickness)
# 将处理后的帧写入输出视频
video_writer.write(im0)
# 释放资源
cap.release()
video_writer.release()
代码详细解释
模型加载:
- 使用来自
ultralytics库的YOLO类加载YOLO模型,并提取类名。
视频处理:
- 使用
cv2.VideoCapture打开输入视频,并初始化视频编写器以保存输出。
逐帧检测:
- 视频是逐帧处理的。对于每一帧,YOLO模型用于检测眼睛并将其分类为“闭合”或“打开”。
闭眼检测:
- 计数器(
eye_closed_frames)跟踪眼睛被检测为“闭合”的连续帧的数量。“如果此计数超过阈值(在本例中为1秒的帧),则会显示警告消息。
警告消息显示:
- 每当眼睛已经闭合超过阈值持续时间时,警告消息被动态地覆盖在视频上。
摄像头实时检测
上面演示的方法可以适用于使用网络摄像头或实时视频源的实时检测。以下是您如何实现这一点:
- 捕获实时视频:通过将
cv2.VideoCapture参数更改为0(默认网络摄像头),将视频文件输入替换为实时视频源。
cap = cv2.VideoCapture(0) # Use 0 for the default camera, or 1, 2, etc. for other cameras
优化实时性能:
- 为了确保流畅的实时性能,您可能需要通过使用较小的模型(如YOLO11n)或在GPU上运行(如果可用)来优化模型推理速度。
实时显示结果:
- 使用
cv2.imshow()实时显示视频源:
cv2.imshow("Eye Closure Detection", im0)
if cv2.waitKey(1) & 0xFF == ord('q'): # Press 'q' to quit
break
通过YOLO和OpenCV的结合,您可以在视频中甚至实时有效地检测眼睛闭合。该技术具有许多实际应用,包括驾驶员监控系统,疲劳检测和各种安全关键领域的警觉性验证。通过利用像YOLO这样的深度学习模型,您可以在检测眼睛闭合等细微面部表情时实现高准确性和性能。
热门推荐
火星的意義解析:從天文學到文化象徵
蛋白粉里有乳糖吗?一文读懂不同类型蛋白粉的乳糖含量
【構圖必學】5 個利用「有趣點」突出相片主角的方法
挑选黄酒,看牌子还是看价格?都不对,17946和13662差别要搞清楚
一些经典的影视台词,它们或深刻、或感人、或幽默,成为了影史中的经典
激光去斑后多久可以吃牛肉?术后护理全攻略
DNF勇者套装全解析:如何选择最适合你的装备,快速提升战斗力
细菌感染皮肤病有哪些
查理二世:快活王的私生子之谜与无嫡子之痛
史上最全新车选号攻略!(干货.收藏)
C语言如何标准命名
从蒸汽机到现代科技:我们仍在“烧开水”吗?
星铁3.0版本顶级配队盘点:大黑塔智识队完全毕业,记忆主成新免费香饽饽
海带丝的多种美味做法与温暖回忆
怎样经营好家庭
支付令申请应具备哪些条件
王勃墓在越南:1300年来的文化传承与纪念
上海“原拆原建”的旧住房改造项目 为什么越来越多了?
打掉牙齿算几级伤残?法律这样规定
清醒思考:如何保持决策的理性与冷静
原来坦克是躺着开的,详细讲解美国M1主战坦克的武器系统
小猫伤口处理指南(为你的宠物提供最佳护理)
金税四期:以数治税!大数据时代下 “ 它 ” 究竟有多强?
“鼓韵奏华章 盛世中国梦”陕西省优秀民间锣鼓展演活动在宝鸡举办
如何计划一次完美的度假:从选择目的地到享受时光
戒酒瘾的最好办法
软件工程24年最新排名 软件工程学校排名
2025年东南大学计算机考研考情分析
针对春季特有的气候和环境特点-湿疹患者如何防护
《流放之路》天赋揭秘:真相揭晓的实际效用分析