iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >python疲劳驾驶困倦低头检测功能怎么实现
  • 641
分享到

python疲劳驾驶困倦低头检测功能怎么实现

2023-06-29 20:06:37 641人浏览 泡泡鱼

Python 官方文档:入门教程 => 点击学习

摘要

本篇内容主要讲解“python疲劳驾驶困倦低头检测功能怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python疲劳驾驶困倦低头检测功能怎么实现”吧!python疲劳驾驶困倦低头检测,代

本篇内容主要讲解“python疲劳驾驶困倦低头检测功能怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习Python疲劳驾驶困倦低头检测功能怎么实现”吧!

python疲劳驾驶困倦低头检测,代码如下所示:

def get_head_pose(shape):  # 头部姿态估计    # (像素坐标集合)填写2D参考点    # 17左眉左上角/21左眉右角/22右眉左上角/26右眉右上角/36左眼左上角/39左眼右上角/42右眼左上角/    # 45右眼右上角/31鼻子左上角/35鼻子右上角/48左上角/54嘴右上角/57嘴中央下角/8下巴角    image_pts = np.float32([shape[17], shape[21], shape[22], shape[26], shape[36],                            shape[39], shape[42], shape[45], shape[31], shape[35],                            shape[48], shape[54], shape[57], shape[8]])    # solvePnP计算姿势——求解旋转和平移矩阵:    # rotation_vec表示旋转矩阵,translation_vec表示平移矩阵,cam_matrix与K矩阵对应,dist_coeffs与D矩阵对应。    _, rotation_vec, translation_vec = cv2.solvePnP(object_pts, image_pts, cam_matrix, dist_coeffs)    # projectPoints重新投影误差:原2d点和重投影2d点的距离(输入3D点、相机内参、相机畸变、r、t,输出重投影2d点)    reprojectdst, _ = cv2.projectPoints(reprojectsrc, rotation_vec, translation_vec, cam_matrix, dist_coeffs)    reprojectdst = tuple(map(tuple, reprojectdst.reshape(8, 2)))  # 以8行2列显示     # 计算欧拉角calc euler angle    rotation_mat, _ = cv2.Rodrigues(rotation_vec)  # 罗德里格斯公式(将旋转矩阵转换为旋转向量)    pose_mat = cv2.hconcat((rotation_mat, translation_vec))  # 水平拼接,vconcat垂直拼接    # decomposeProjectionMatrix将投影矩阵分解为旋转矩阵和相机矩阵    _, _, _, _, _, _, euler_angle = cv2.decomposeProjectionMatrix(pose_mat)    pitch, yaw, roll = [math.radians(_) for _ in euler_angle]    pitch = math.degrees(math.asin(math.sin(pitch)))    roll = -math.degrees(math.asin(math.sin(roll)))    yaw = math.degrees(math.asin(math.sin(yaw)))    print('pitch:{}, yaw:{}, roll:{}'.fORMat(pitch, yaw, roll))    return reprojectdst, euler_angle  # 投影误差,欧拉角def eye_aspect_ratio(eye):    # 垂直眼标志(X,Y)坐标    A = dist.euclidean(eye[1], eye[5])  # 计算两个集合之间的欧式距离    B = dist.euclidean(eye[2], eye[4])    # 计算水平之间的欧几里得距离    # 水平眼标志(X,Y)坐标    C = dist.euclidean(eye[0], eye[3])    # 眼睛长宽比的计算    ear = (A + B) / (2.0 * C)    # 返回眼睛的长宽比    return eardef mouth_aspect_ratio(mouth):  # 嘴部    A = np.linalg.norm(mouth[2] - mouth[9])  # 51, 59    B = np.linalg.norm(mouth[4] - mouth[7])  # 53, 57    C = np.linalg.norm(mouth[0] - mouth[6])  # 49, 55    mar = (A + B) / (2.0 * C)    return mar

python疲劳驾驶困倦低头检测功能怎么实现

到此,相信大家对“python疲劳驾驶困倦低头检测功能怎么实现”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: python疲劳驾驶困倦低头检测功能怎么实现

本文链接: https://www.lsjlt.com/news/326327.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • python疲劳驾驶困倦低头检测功能怎么实现
    本篇内容主要讲解“python疲劳驾驶困倦低头检测功能怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“python疲劳驾驶困倦低头检测功能怎么实现”吧!python疲劳驾驶困倦低头检测,代...
    99+
    2023-06-29
  • python疲劳驾驶困倦低头检测功能的实现
    python疲劳驾驶困倦低头检测,代码如下所示: def get_head_pose(shape): # 头部姿态估计 # (像素坐标集合)填写2D参考点 # 17...
    99+
    2024-04-02
  • 怎么用Python实现驾驶员疲劳检测
    这篇文章主要讲解了“怎么用Python实现驾驶员疲劳检测”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用Python实现驾驶员疲劳检测”吧!先决条件该Python项目需要一个网络摄像头,...
    99+
    2023-06-16
  • 【OpenAI】Python:基于 Gym-CarRacing 的自动驾驶项目(2)| 车道检测功能的实现 | 边缘检测与分配 | 样条拟合
        猛戳,跟哥们一起玩蛇啊! 👉 《一起玩蛇》🐍 💭 写在前面: 本篇是关于多伦多大学自动驾驶专业项目的博客。GYM-Box2D CarRacing 是一种在 OpenAI Gym 平台上开发和比较强化学习算法的模拟环境。它是流行的 ...
    99+
    2023-09-03
    自动驾驶 人工智能 OpenAI 图像处理
  • 怎么用Python+MediaPipe实现检测人脸功能
    这篇文章主要介绍“怎么用Python+MediaPipe实现检测人脸功能”,在日常操作中,相信很多人在怎么用Python+MediaPipe实现检测人脸功能问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用...
    99+
    2023-06-29
  • Python中怎么实现人体肤色检测功能
    这期内容当中小编将会给大家带来有关Python中怎么实现人体肤色检测功能,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。安装 Python-OpenCV 库pip install ope...
    99+
    2023-06-16
  • 怎么用YOLOv5实现多路摄像头实时目标检测功能
    这篇文章将为大家详细讲解有关怎么用YOLOv5实现多路摄像头实时目标检测功能,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。前言YOLOV5模型从发布到现在都是炙手可热的目标检测模型,被广泛运用于各大场景之...
    99+
    2023-06-29
  • JavaScript中怎么实现人脸检测功能
    今天就跟大家聊聊有关JavaScript中怎么实现人脸检测功能,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。文件夹结构Project Fo...
    99+
    2024-04-02
  • 使用python与opencv怎么实现一个运动检测器功能
    使用python与opencv怎么实现一个运动检测器功能?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Python主要用来做什么Python主要应用于:1、We...
    99+
    2023-06-06
  • 基于Flask和PaddleHub怎么实现人脸检测功能
    这篇文章主要介绍“基于Flask和PaddleHub怎么实现人脸检测功能”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“基于Flask和PaddleHub怎么实现人脸检测功能”文章能帮助大家解决问题。...
    99+
    2023-07-05
  • AjaxPro中怎么实现无刷新数据检测功能
    本篇文章给大家分享的是有关AjaxPro中怎么实现无刷新数据检测功能,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。使用AjaxPro实现无刷新数据检测Ajax(Asynchro...
    99+
    2023-06-17
  • 怎么在python中利用opencv实现一个车道线检测功能
    这篇文章将为大家详细讲解有关怎么在python中利用opencv实现一个车道线检测功能,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。实现思路:canny边缘检测获取图中的边缘信息;2、霍夫变...
    99+
    2023-06-06
  • 使用opencv怎么实现一个车道线检测功能
    这篇文章给大家介绍使用opencv怎么实现一个车道线检测功能,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。原理:算法基本思想说明:传统的车道线检测,多数是基于霍夫直线检测,其实这个里面有个很大的误区,霍夫直线拟合容易受...
    99+
    2023-06-06
  • 怎么在Html5中使用Canvas实现动画碰撞检测功能
    本篇文章为大家展示了怎么在Html5中使用Canvas实现动画碰撞检测功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。html有什么特点1、简易性:超级文本标记语言版本升级采用超集方式,从而更加灵...
    99+
    2023-06-09
  • Python怎么实现低通滤波器模糊图像功能
    使用低通滤波器模糊图像0. 前言低通滤波器 (Low Pass Filter, LPF) 过滤了图像中的高频部分,并仅允许低频部分通过。因此,在图像上应用 LPF 会删除图像中的细节/边缘和噪声/离群值,此过程也称为图像模糊(或平滑),图像...
    99+
    2023-05-14
    Python
  • Python基于HOG+SVM/RF/DT等模型怎么实现目标人行检测功能
    本篇内容主要讲解“Python基于HOG+SVM/RF/DT等模型怎么实现目标人行检测功能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python基于HOG+SVM/RF/DT等模型怎么实现目...
    99+
    2023-06-30
  • 怎么用Python中从头开始的实现完整的异常检测算法
    这篇文章主要介绍“怎么用Python中从头开始的实现完整的异常检测算法”,在日常操作中,相信很多人在怎么用Python中从头开始的实现完整的异常检测算法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用Py...
    99+
    2023-06-16
  • C语言怎么利用栈和队列实现回文检测功能
    本文小编为大家详细介绍“C语言怎么利用栈和队列实现回文检测功能”,内容详细,步骤清晰,细节处理妥当,希望这篇“C语言怎么利用栈和队列实现回文检测功能”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。具体代码如下:#i...
    99+
    2023-06-16
  • Android应用开发的版本更新检测升级功能怎么实现
    这篇文章主要介绍“Android应用开发的版本更新检测升级功能怎么实现”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Android应用开发的版本更新检测升级功能怎么实现”文章能帮助大家解决问题。一....
    99+
    2023-06-30
  • 怎么在c#中利用socket实现一个心跳超时检测的功能
    怎么在c#中利用socket实现一个心跳超时检测的功能?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1 内存布局图假设socket3有新的数据到达,需要更新socket3所在的...
    99+
    2023-06-07
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作