news 2026/1/23 5:01:48

opencv实战-人脸检测

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
opencv实战-人脸检测

一 人脸检测

进行获取数据包

1 传入参数

orderDict() 按照循序进行导入字典 拒绝乱序

访问方式

使用命名空间对象

使用字典(args

语法

args.shape_predictor

args["shape_predictor"]

动态访问

不方便

方便:args[key]

与函数集成

需要解包:func(**vars(args))

直接传递:func(**args)

遍历参数

需要vars()辅助

直接遍历

主要优势:字典格式更灵活,特别是当需要将参数传递给其他函数时。

FACIAL_LANDMARKS_68_IDXS = OrderedDict([ ("mouth", (48, 68)), # 嘴巴区域:关键点48-68 ("right_eyebrow", (17, 22)), # 右眉毛:关键点17-22 ("left_eyebrow", (22, 27)), # 左眉毛:关键点22-27 ("right_eye", (36, 42)), # 右眼:关键点36-42 ("left_eye", (42, 48)), # 左眼:关键点42-48 ("nose", (27, 36)), # 鼻子:关键点27-36 ("jaw", (0, 17)) # 下颌线:关键点0-17 ])
FACIAL_LANDMARKS_5_IDXS = OrderedDict([ ('right_eye', (2, 3)), # 右眼:索引2和3 ('left_eye', (0, 1)), # 左眼:索引0和1 ('nose', (4)) # 鼻子:索引4 ])

2 导入人脸检测的工具包并进行预处理

detector = dlib.get_frontal_face_detector() predictor = dlib.shape_predictor(args["shape_predictor"]) • detector:这是您图片中被红框特别标注的核心对象。 它是一个使用方向梯度直方图(HOG)特征和线性SVM分类器的预训练人脸检测器。 它的作用是在图像中找出人脸的位置,返回一个或多个表示人脸位置的矩形框。 • predictor:这是一个预训练的关键点定位器,通常基于回归树集合或深度学习模型训练 。给定一个包含人脸的图像区域,它能精确预测出这个区域内68个 (或5个)​ 预先定义好的面部关键点的坐标。 工作关系:通常先使用 detector找到人脸,然后将每个人脸区域和原图(或灰度图) 传递给 predictor,以获得精细的关键点。

3 进行人脸检测并遍历所有的框

rects = detector(gray, 1) 返回值: rects:包含所有人脸边界框的列表 每个边界框是dlib的rectangle对象,包含人脸的位置 内部原理: detector使用HOG(方向梯度直方图)特征+SVM分类器 在图像上滑动窗口,检测人脸 参数1表示对图像上采样一次,增加检测小脸的能力
shape = predictor(gray, rect) predictor:加载的dlib关键点预测器。 参数:(gray, rect)- 当前帧的灰度图像和当前人脸框。 返回:一个dlib的full_object_detection对象,包含68个(或5个)面部关键点的坐标。 获取坐标值 coords = np.zeros((shape.num_parts, 2), dtype=dtype) shape.num_parts:获取关键点的总数 对于68点模型:68 对于5点模型:5 np.zeros((N, 2), dtype=dtype):创建N行2列的全零数组 示例:68点模型会创建形状为(68, 2)的数组
shape.part(i).x:获取第i个关键点的x坐标 shape.part(i).y:获取第i个关键点的y坐标 coords[i] = (x, y):将坐标赋值给数组的第i行

4 遍历每一个区域

用于提取感兴趣区域(Region of Interest)

(x,y,w,h)=cv2.boundingRect(np.array([shape[i:j]])) shape[i:j]:从关键点数组中提取特定区域的点 shape是关键点数组,形状为(68, 2)或(5, 2) i, j是特定区域的起始和结束索引 np.array([shape[i:j]]):将点列表转换为NumPy数组 cv2.boundingRect():计算能包围这些点的最小外接矩形 返回值: (x, y):矩形左上角坐标 (w, h):矩形的宽度和高度

5 展示所有区域

ull = cv2.convexHull(pts) 什么是凸包? 凸包是包含所有给定点的最小凸多边形。想象在木板上钉钉子, 用橡皮筋套住所有钉子形成的形状就是凸包。 参数详解: pts:关键点数组,形状为(N, 2),其中N是该区域的关键点数量 例如,右眼区域有6个点:pts = shape[36:42] 返回值hull:一个NumPy数组,包含凸包的顶点坐标

二 疲劳检测

1 求距离

dist.euclidean() 计算两点之间的欧几里得距离 EAR公式:(垂直距离1 + 垂直距离2) / (2 × 水平距离) 当眼睛完全睁开时,EAR值最大 当眼睛闭合时,EAR值接近0

2 设置参数

小于0.3的时候开始眨眼 当持续3帧的时候当一次眨眼

当小于0.3的时候counter加1 当counter加到3的时候total加1

3 需要将图像区域调大一些 这样方便检测到人脸 要不然人脸太小的化 人脸检测器检测不到

4 进行绘制

leftEye = shape[lStart:lEnd] lStart和 lEnd:左眼区域的起始和结束索引 对于68点模型,左眼通常是索引42-47 结果:包含6个(x, y)坐标的数组

cv2.putText(frame, "EAR: {:.2f}".format(ear), (300, 30),
cv2.FONT_HERSHEY_SIMPLEX, 0.7, (0, 0, 255), 2)
关键区别:
位置:(300, 30),避免与眨眼计数重叠
格式:{:.2f}保留两位小数
内容:显示当前帧的眼睛纵横比
第6行:显示图像窗口

参数

说明

等待时间

10

等待10毫秒,然后继续

位掩码

& 0xFF

获取低8位,确保跨平台兼容

返回值

key

按键的ASCII码

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/21 1:02:58

MGeo实战案例:企业级地理信息去重系统的搭建步骤

MGeo实战案例:企业级地理信息去重系统的搭建步骤 1. 引言 1.1 业务场景描述 在现代企业数据治理中,地址信息的标准化与去重是构建高质量主数据体系的关键环节。尤其是在物流、电商、金融和城市服务等领域,同一实体(如门店、客户…

作者头像 李华
网站建设 2026/1/21 12:26:12

FSMN VAD批量文件处理功能预告:wav.scp格式使用教程

FSMN VAD批量文件处理功能预告:wav.scp格式使用教程 1. 引言 随着语音技术在会议记录、电话客服、音频质检等场景的广泛应用,高效准确地识别语音活动片段(Voice Activity Detection, VAD)成为关键前置步骤。FSMN VAD 是由阿里达…

作者头像 李华
网站建设 2026/1/18 18:09:34

用Paraformer镜像搭建客服录音分析系统,省时高效

用Paraformer镜像搭建客服录音分析系统,省时高效 1. 引言:客服语音转写需求与挑战 在现代客户服务系统中,大量的通话录音蕴含着宝贵的业务洞察。传统的人工听录方式效率低下、成本高昂,且难以规模化处理。随着语音识别技术的发展…

作者头像 李华
网站建设 2026/1/21 14:35:30

一键启动Qwen3-Reranker:Gradio可视化界面快速体验

一键启动Qwen3-Reranker:Gradio可视化界面快速体验 1. 引言 在检索增强生成(RAG)系统中,重排序(Reranking)是提升检索质量的关键环节。通过将初步召回的候选文档进行精细化排序,能够显著提高最…

作者头像 李华
网站建设 2026/1/20 20:40:22

LangFlow交通运输:路线优化与调度建议系统实战

LangFlow交通运输:路线优化与调度建议系统实战 1. 引言 随着城市化进程加快和物流行业的迅猛发展,交通运输中的路线优化与调度决策成为提升效率、降低成本的关键环节。传统调度系统依赖规则引擎或静态算法,在面对动态交通状况、多目标优化需…

作者头像 李华