使用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这样的深度学习模型,您可以在检测眼睛闭合等细微面部表情时实现高准确性和性能。
热门推荐
新一代信号系统优化方案研究与前瞻技术探索
尾骨疼痛,究竟是哪里的问题?如何缓解?请看此文
被害妄想症的表现有哪些
有氧运动减脂燃脂(有氧运动减脂燃脂吗)
刚入门机器视觉应该怎么规划学习路线
拖欠工资怎么离职?这些步骤和权益你需要知道
螺栓拧紧的控制方法有哪些?
欧国联赛制:新增主客场1/4决赛 西班牙夺冠最热
女孩如何起带琴字的名字 和什么字搭配好听
患难与共的真谛:解读"相濡以沫"的深刻含义
有限元分析从定义到场景到硬件配置详细讲解
南昌市第一医院:一所集医疗、教学、科研于一体的现代化三级甲等医院
承载一代人回忆的6部欧美动漫,全看过的就不再年轻了
中石油长庆油田累计生产油气当量突破10亿吨
博物馆金库门设计原理与技术特点
港媒:自然指数显示,中国物理研究领跑全球,远远超过美国
胃病怎么医好
干货 | 5个常用的深度学习框架
作家李娟:文坛传奇的牧民之女
《北上》以“90后”视角切入,拉近与当代观众的距离
日本传统的正坐,竟是为了故意使人腿脚麻木!?
Excel宏的使用方法与技巧
慢性肾功能衰竭可以喝豆浆吗
什么是公证服务
公证处办理公证需要哪些证件?全流程指南来了
化疗后如何吃?中医视角下的肺癌饮食策略
车规芯片如何打造信息安全新防线
2035年出生人口或不足50万?日本新生儿创历史新低,人口危机全面爆发
如何减轻麻醉后的不适感?
2024年1-12月中国机器人行业投融资情况分析(图)