Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单人脸检测/识别实战案例 之十二 简单人脸识别

Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单人脸检测/识别实战案例 之十二 简单人脸识别

目录

Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单人脸检测/识别实战案例 之十二 简单人脸识别

一、简单介绍

二、简单人脸识别实现原理

三、简单人脸识别案例实现简单步骤

四、注意事项

附录:

一、cv2.data.haarcascades 目录下,一些文件的详细说明


一、简单介绍

Python是一种跨平台的计算机程序设计语言。是一种面向对象的动态类型语言,最初被设计用于编写自动化脚本(shell),随着版本的不断更新和语言新功能的添加,越多被用于独立的、大型项目的开发。Python是一种解释型脚本语言,可以应用于以下领域: Web 和 Internet开发、科学计算和统计、人工智能、教育、桌面界面开发、软件开发、后端开发、网络爬虫。

这里使用 Python  基于 OpenCV 进行视觉图像处理,......

人脸检测的两个重要概念:哈尔特征分类器(Haar Feature Classifier)和级联分类器(Cascade Classifier)是用于。

哈尔特征分类器

  • 定义:哈尔特征分类器是一种基于哈尔特征的机器学习算法,用于检测图像中的对象或特定区域。

  • 原理:哈尔特征是一种基于图像局部特征的数学描述方法,通过对图像中不同区域像素值的差异进行计算,提取出具有区分度的特征。这些特征可以是边缘、线段、角点等。哈尔特征分类器通过训练过程学习到一组有效的特征模式,用于区分目标和非目标区域。

  • 应用:哈尔特征分类器常用于对象检测任务,如人脸检测、眼睛检测等。在训练过程中,通常需要提供正样本(包含目标的图像)和负样本(不包含目标的图像),让分类器学习区分目标和非目标的特征模式。

级联分类器

  • 定义:级联分类器是一种多级联组成的分类器结构,由多个弱分类器组成,通过级联方式实现目标检测。

  • 原理:级联分类器将多个简单的分类器组合成一个复杂的分类器,每个简单分类器都是一个弱分类器,对目标区域进行初步筛选或过滤。级联分类器通过级联多个弱分类器,每个分类器都负责判断一组特征是否满足条件,通过级联的方式实现高效的目标检测。

  • 应用:级联分类器常用于实时目标检测任务,如人脸检测、车辆检测等。OpenCV 中的 Haar 级联分类器是基于哈尔特征的级联分类器,通过级联多个分类阶段来实现高效的人脸检测。级联分类器的优势在于其高速、高效的检测性能,适用于实时应用场景。

OpenCV 提供了一些已经训练好的级联分类器,这些级联分类器以XML文件的方式保存在以下路径中:

 ...\Python\Lib\site-packages\cv2\data\

路径说明:

  •  “...\Python\”:Python虚拟机的本地目录。
  •  “\Lib\site-packages\”:pip安装扩展包的默认目录。
  •  “\cv2\data\”:OpenCV库的data文件夹。

OpenCV提供了一些经过预训练的人脸检测器模型文件,这些文件通常包含在OpenCV的安装包中。你可以在OpenCV的官方GitHub页面或者OpenCV官方网站的下载页面找到这些模型文件的下载链接。

一般来说,你可以从以下位置获取OpenCV的预训练模型文件:

  1. OpenCV GitHub Release 页面:在 Releases · opencv/opencv · GitHub 找到你需要的版本,然后在下载的压缩包中找到位于 opencv\data 目录下的人脸检测器模型文件。

  2. OpenCV 官方网站下载页面:访问 OpenCV 官方网站 https://opencv.org/releases/ ,下载你需要的版本,并在相应的压缩包中查找人脸检测器模型文件。

请确保下载与你使用的OpenCV版本兼容的模型文件。

1、Github 下载

Releases · opencv/opencv · GitHub

2、Opencv 官网下载

Releases - OpenCV

二、简单人脸识别实现原理

人脸检测是计算机视觉中的一项任务,旨在自动识别图像或视频中的人脸区域。其主要目标是从复杂的图像中准确地定位和识别出人脸,通常通过以下步骤实现:

  1. 特征提取:使用图像处理和特征工程技术,提取图像中可能代表人脸的特征,如边缘、纹理等。

  2. 分类器训练:利用机器学习或深度学习算法,基于提取的特征训练分类器模型。这些模型能够区分人脸和非人脸区域。

  3. 人脸检测:将训练好的分类器应用于图像或视频数据,通过在不同位置、尺度和方向上滑动窗口,并利用分类器识别可能包含人脸的区域,从而完成人脸检测任务。

  4. 人脸定位:对检测到的人脸区域进行定位,通常是用矩形框标注人脸位置。

  5. 后处理:根据实际需求对检测结果进行进一步处理,如去除重叠框、合并相邻框等。

人脸检测在计算机视觉和人工智能领域有着广泛的应用,包括人脸识别、表情分析、人脸跟踪、人脸融合等方面。

人脸检测的实现原理主要基于哈尔特征分类器和级联分类器(Cascade Classifier)的概念。这些分类器基于机器学习算法,通过训练从大量正样本(包含人脸的图像)和负样本(不包含人脸的图像)中学习人脸特征,并能够在新图像中快速准确地检测人脸。

具体方法如下:

  1. 加载分类器模型:首先,需要加载已经训练好的人脸分类器模型。OpenCV提供了训练好的分类器文件,例如haarcascade_frontalface_default.xml,用于人脸检测。

  2. 读取图像:将待检测的图像读取为OpenCV的图像对象。

  3. 转换为灰度图像:由于人脸检测通常不需要颜色信息,因此将图像转换为灰度图像可以加快处理速度。

  4. 人脸检测:利用detectMultiScale函数进行人脸检测。该函数会返回一个矩形列表,每个矩形表示一个检测到的人脸区域的位置和大小。

  5. 绘制人脸框:遍历检测到的人脸区域,利用OpenCV提供的绘制函数在原始图像上绘制矩形框,标注出人脸位置。

  6. 显示结果:将绘制了人脸框的图像显示出来,或者保存到文件中。

人脸检测过程中,涉及了以下几个关键函数:

  • cv2.CascadeClassifier()

    • 功能:加载级联分类器模型。
    • 参数:需要传入训练好的分类器模型的路径。
    • 返回值:返回一个CascadeClassifier对象,用于后续的人脸检测。
  • detectMultiScale()

    • 功能:对图像进行多尺度目标检测。
    • 参数
      • image:待检测的图像。
      • scaleFactor:用于缩放图像大小的比例因子,用于在不同尺度下搜索目标。
      • minNeighbors:指定每个目标至少要被检测到多少次才算是真正的目标。
      • minSize:目标的最小尺寸。
      • flags:检测模式。
      • minSize:目标的最小尺寸。
    • 返回值:返回一个矩形列表,每个矩形表示一个检测到的目标的位置和大小。
  • cv2.rectangle()

    • 功能:在图像上绘制矩形框。
    • 参数
      • image:要绘制矩形框的图像。
      • pt1:矩形左上角的坐标。
      • pt2:矩形右下角的坐标。
      • color:矩形框的颜色。
      • thickness:矩形框的线条粗细。
    • 返回值:无。
  • cv2.putText()

    • 功能:在图像上绘制文本。
    • 参数
      • image:要绘制文本的图像。
      • text:要绘制的文本内容。
      • org:文本左下角的坐标。
      • fontFace:字体类型。
      • fontScale:字体大小的缩放因子。
      • color:文本颜色。
      • thickness:文本线条粗细。
      • lineType:文本线条类型。
    • 返回值:无。

这些函数是实现人脸检测和在图像上标注人脸框的关键函数,通过它们可以完成人脸检测任务并将结果可视化。

三、简单人脸识别案例实现简单步骤

1、编写代码

2、运行效果

3、具体代码

"""
简单人脸识别1、加载分类器模型:首先,需要加载已经训练好的人脸分类器模型。OpenCV提供了训练好的分类器文件,例如haarcascade_frontalface_default.xml,用于人脸检测。2、读取图像:将待检测的图像读取为OpenCV的图像对象。3、转换为灰度图像:由于人脸检测通常不需要颜色信息,因此将图像转换为灰度图像可以加快处理速度。4、人脸检测:利用detectMultiScale函数进行人脸检测。该函数会返回一个矩形列表,每个矩形表示一个检测到的人脸区域的位置和大小。5、绘制人脸框:遍历检测到的人脸区域,利用OpenCV提供的绘制函数在原始图像上绘制矩形框,标注出人脸位置。6、显示结果:将绘制了人脸框的图像显示出来,或者保存到文件中。
"""import os
import cv2def detect_faces(image_path, scaleFactor=1.1, minNeighbors=5, minSize=(30, 30)):"""识别图像中的人脸,并绘制人脸轮廓:param image_path:(str)输入图像的文件路径:param scaleFactor:(float)用于图像尺度补偿的比例因子:param minNeighbors:(int)每个候选矩形应该保留的邻近数量:param minSize:(tuple)人脸的最小尺寸。:return: numpy.ndarray 绘制了人脸轮廓的图像数据;int 检测到的人脸数量"""# 检查图像文件路径是否存在if not os.path.isfile(image_path):raise FileNotFoundError("Input image file not found.")# 加载人脸分类器face_cascade = cv2.CascadeClassifier(r'YourPath\opencv-4.8.0\data\haarcascades\haarcascade_frontalface_default.xml')# 读取图像image = cv2.imread(image_path)# 将图像转换为灰度图像gray_image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)# 检测人脸faces = face_cascade.detectMultiScale(gray_image, scaleFactor=scaleFactor, minNeighbors=minNeighbors,minSize=minSize)# 人脸标签计数num = 0# 绘制人脸轮廓for (x, y, w, h) in faces:num += 1cv2.rectangle(image, (x, y), (x + w, y + h), (255, 0, 0), 2)cv2.putText(image, f'Face {num}', (x, y - 10), cv2.FONT_HERSHEY_SIMPLEX, 0.5, (0, 0, 255), 2)# 返回带有绘制的人脸轮廓的图像和检测到的人脸数量return image, len(faces)def main():# 调用函数并指定输入图像文件路径input_image_path = 'Images/FourPeopleFace.jpg'detected_image, num_faces = detect_faces(input_image_path)# 显示检测到的人脸数量print("Number of faces detected:", num_faces)# 显示绘制了人脸轮廓的图像cv2.imshow('Detected Faces', detected_image)cv2.waitKey(0)cv2.destroyAllWindows()if __name__ == "__main__":main()

四、注意事项

  1. 分类器选择:选择合适的分类器对于人脸检测的准确性至关重要。OpenCV提供了多个预训练好的分类器,可以根据需要选择合适的分类器。

  2. 参数调优detectMultiScale函数接受一些参数,例如scaleFactorminNeighborsminSize等,这些参数会影响检测结果的准确性和速度。需要根据实际情况进行调优。

  3. 图像预处理:有时候在进行人脸检测之前可能需要对图像进行一些预处理,例如去噪、直方图均衡化等,以提高检测的准确性。

  4. 性能优化:人脸检测是一个计算密集型任务,特别是在大型图像上或者实时视频流中。可以通过降低图像分辨率、使用多线程等方法来提高性能。

  5. 结果处理:在使用检测结果时,需要注意处理可能出现的错误和异常情况,例如检测不到人脸时的处理方式。

综上所述,人脸检测的实现方法基于分类器模型和图像处理技术,通过识别人脸的特征并在图像中标注出人脸位置来实现。在实现过程中需要注意选择合适的分类器、调优参数、进行必要的图像预处理以及处理检测结果。

附录:

一、cv2.data.haarcascades 目录下,一些文件的详细说明

  1. haarcascade_eye.xml

    • 功能:用于检测眼睛的分类器。
    • 文件名:haarcascade_eye.xml
    • 用途:检测图像或视频中的眼睛区域。
  2. haarcascade_eye_tree_eyeglasses.xml

    • 功能:用于检测佩戴眼镜的眼睛的分类器。
    • 文件名:haarcascade_eye_tree_eyeglasses.xml
    • 用途:类似于 haarcascade_eye.xml,但更适用于佩戴眼镜的人群。
  3. haarcascade_frontalface_alt.xml

    • 功能:用于检测正面人脸的分类器。
    • 文件名:haarcascade_frontalface_alt.xml
    • 用途:检测图像或视频中的正面人脸区域。
  4. haarcascade_frontalface_alt2.xml

    • 功能:用于检测正面人脸的分类器,改进版本。
    • 文件名:haarcascade_frontalface_alt2.xml
    • 用途:与 haarcascade_frontalface_alt.xml 类似,但改进了性能和准确性。
  5. haarcascade_frontalface_alt_tree.xml

    • 功能:用于检测正面人脸的分类器,基于 Haar 特征的树形结构。
    • 文件名:haarcascade_frontalface_alt_tree.xml
    • 用途:与 haarcascade_frontalface_alt.xml 类似,但使用了不同的检测算法。
  6. haarcascade_frontalface_default.xml

    • 功能:用于检测正面人脸的分类器,默认版本。
    • 文件名:haarcascade_frontalface_default.xml
    • 用途:与 haarcascade_frontalface_alt.xml 类似,是默认的人脸检测模型。
  7. haarcascade_profileface.xml

    • 功能:用于检测侧面人脸的分类器。
    • 文件名:haarcascade_profileface.xml
    • 用途:检测图像或视频中的侧面人脸区域。

这些 XML 文件包含了在大量正样本(带有目标)和负样本(不带目标)上进行训练后得到的分类器模型。加载这些模型后,可以用于检测图像或视频中的目标区域。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/821862.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数据密集型应用系统设计 PDF 电子书(Martin Kleppmann 著)

简介 《数据密集型应用系统设计》全书分为三大部分: 第一部分,主要讨论有关增强数据密集型应用系统所需的若干基本原则。首先开篇第 1 章即瞄准目标:可靠性、可扩展性与可维护性,如何认识这些问题以及如何达成目标。第 2 章我们比…

MongoDB的安装配置及使用

文章目录 前言一、MongoDB的下载、安装、配置二、检验MongoDB是否安装成功三、Navicat 操作MongoDB四、创建一个集合,存放三个文档总结 前言 本文内容: 💫 MongoDB的下载、安装、配置 💫 检验MongoDB是否安装成功 ❤️ Navicat 操…

【单例模式】饿汉式、懒汉式、静态内部类--简单例子

单例模式是⼀个单例类在任何情况下都只存在⼀个实例,构造⽅法必须是私有的、由⾃⼰创建⼀个静态变量存储实例,对外提供⼀个静态公有⽅法获取实例。 目录 一、单例模式 饿汉式 静态内部类 懒汉式 反射可以破坏单例 道高一尺魔高一丈 枚举 一、单例…

[html]一个动态js倒计时小组件

先看效果 代码 <style>.alert-sec-circle {stroke-dasharray: 735;transition: stroke-dashoffset 1s linear;} </style><div style"width: 110px; height: 110px; float: left;"><svg style"width:110px;height:110px;"><cir…

【GD32】_时钟架构及系统时钟频率配置

文章目录 一、有关时钟源二、系统时钟架构三、时钟树分析四、修改参数步骤1、设置外部晶振2、选择外部时钟源。3、 设置系统主频率大小4、修改PLL分频倍频系数 学习系统时钟架构和时钟树&#xff0c;验证及学习笔记如下&#xff0c;如有错误&#xff0c;欢迎指正。主要记录了总…

力扣152. 乘积最大子数组

Problem: 152. 乘积最大子数组 文章目录 题目描述思路复杂度Code 题目描述 思路 1.初始化&#xff1a;首先&#xff0c;我们创建两个数组maxNum和minNum&#xff0c;并将它们初始化为输入数组nums。这两个数组用于存储到当前位置的最大和最小乘积。我们还需要一个变量maxProduc…

python 一个点运算符操作的字典库:DottedDict

DottedDict 是一种特殊的数据结构&#xff0c;它结合了字典&#xff08;Dictionary&#xff09;和点符号&#xff08;Dot Notation&#xff09;访问的优点&#xff0c;为用户提供了一种更加直观和方便的方式来处理和访问嵌套的数据。在这篇文章中&#xff0c;我们将深入探讨 Do…

Java复习第二十天学习笔记(过滤器Filter),附有道云笔记链接

【有道云笔记】二十 4.8 过滤器Filter https://note.youdao.com/s/dSofip3f 一、为什么要使用过滤器 项目开发中&#xff0c;经常会用到重复代码的实现。 1、请求每个servlet都要设置编码 2、判断用户是否登录&#xff0c;只有登录了才有操作权限。 二、过滤器相关Api int…

从汇编代码理解数组越界访问漏洞

数组越界访问漏洞是 C/C 语言中常见的缺陷&#xff0c;它发生在程序尝试访问数组元素时未正确验证索引是否在有效范围内。通常情况下&#xff0c;数组的索引从0开始&#xff0c;到数组长度减1结束。如果程序尝试访问小于0或大于等于数组长度的索引位置&#xff0c;就会导致数组…

windows关闭Windows Search功能

我发现windows最恶心的功能就是自动更新和搜索。自动更新就是个毒瘤&#xff0c;得到了全世界的人讨厌。 而搜索功能难用、慢和造成卡死&#xff0c;根本没有存在的必要。并且他的windows search filter服务会在每次移动大量文件后建立索引&#xff0c;持续的占用cpu和硬盘的资…

python解释器安装路径查询以及版本查询

查询安装路径 1、利用脚本&#xff1a; 路径: import sys import osprint(当前 Python 解释器路径&#xff1a;) print(sys.executable)运行结果&#xff1a; 目录: print(当前 Python 解释器目录&#xff1a;) print(os.path.dirname(sys.executable))运行结果&#xff1a…

static+单例模式+类的复合继承

汇编语言 汇编语言是最靠谱的验证“编程语言相关知识点”正确性的方式 汇编语言与机器语言一一对应&#xff0c;每一条机器语言都有与之对应的汇编指令 机器语言是计算机使用的语言&#xff0c;它是一串二进制数字 汇编语言可以通过汇编得到机器语言机器语言可以通过反汇编得到…

设计模式—门面模式

定义: 门面模式,也称为外观模式&#xff0c;是一种结构型设计模式。它的主要目的是提供统一的接口来访问子系统中的多个接口&#xff0c;从而简化客户端与复杂子系统之间的交互。 在门面模式中&#xff0c;一个门面类充当中介&#xff0c;为客户端提供一个简化了的访问方式&…

基于Adaboost模型的数据预测和分类matlab仿真

目录 1.程序功能描述 2.测试软件版本以及运行结果展示 3.核心程序 4.本算法原理 5.完整程序 1.程序功能描述 AdaBoost&#xff08;Adaptive Boosting&#xff09;是一种集成学习方法&#xff0c;由Yoav Freund和Robert Schapire于1995年提出&#xff0c;主要用于提高弱分类…

【echarts】使用 ECharts 绘制3D饼图

使用 ECharts 绘制3D饼图 在数据可视化中&#xff0c;饼图是表达数据占比信息的常见方式。ECharts 作为一个强大的数据可视化库&#xff0c;除了标准的二维饼图&#xff0c;也支持更加生动的三维饼图绘制。本文将指导你如何使用 ECharts 来创建一个3D饼图&#xff0c;提升你的…

VScode配置launch+tasks[自己备用]

VScode配置launchtasks[自己备用]&#xff0c;配置文件详解 launch.json 字段 name &#xff1a;启动配置的名称&#xff0c;也就是显示在调试配置下拉菜单中的名字&#xff0c;如果添加了多个配置可以用此作为区分 字段 program &#xff1a;可执行文件完整路径。 ① 由于 C…

ARP代理

10.1.0.1/8 和10.2.0.1/8是在同一个网段 10.1.0.2/16 和10.2.0.2/16 不在同一个网段 10.1.0.1/8 和10.1.0.2/16 是可以ping通的 包发出来了&#xff0c;报文有发出来&#xff0c;目的地址是广播包 广播请求&#xff0c;发到路由器的接口G 0/0/0 target不是本接口&#xff0…

利用redis和fastapi实现本地与平台策略进行交互

redis在pandas一文有详细使用方法(一文教会pandas-CSDN博客)&#xff0c;具体可视化软件有redisstudio等。它是一个由 Salvatore Sanfilippo 写的 key-value 存储系统&#xff0c;是跨平台的非关系型数据库。 Redis 是一个开源的使用 ANSI C 语言编写、遵守 BSD 协议、支持网络…

【教程】ubuntu20.04 下配置 Charm-crypto 0.5 实验环境

目录 前言先决条件基本依赖安装准备好 gcc&#xff0c;make 和 perl准备好 m4&#xff0c;flex&#xff0c;bison 和 libssl-dev安装 Python3.x&#xff0c;pip3 和 pyparsing 安装 OpenSSL安装 GMP5.x安装 PBC安装 Charm-crypto5.0安装开发环境检验 Charm-crypto5.0 安装成功参…

【【相机运动】_Camera_shake镜头晃动动画】

【相机运动】:Camera shake镜头晃动动画 2022-07-20 20:28 评论(0)