《深度学习》OpenCV EigenFaces算法 人脸识别

devtools/2024/10/20 14:18:32/

目录

一、EigenFaces算法

1、什么是EigenFaces算法

2、原理

3、实现步骤

1)数据预处理

2)特征提取

3)构建模型

4)识别

4、优缺点

1)优点

2)缺点

二、案例实现

1、完整代码

运行结果:


一、EigenFaces算法

1、什么是EigenFaces算法

        EigenFaces算法,又称为基于主成分分析(Principal Component Analysis,PCA)的人脸识别方法,是一种在人脸识别领域具有重要地位的经典算法。

        主成分分析(PCA)是一种矩阵的压缩算法,在减少矩阵维数的同时尽可能的保留原矩阵的信息,简单来说就是将 n×m的矩阵转换成n×k的矩阵,仅保留矩阵中所存在的主要特性,从而可以大大节省空间和数据量。

2、原理

        EigenFaces算法的核心思想是从统计的角度,寻找人脸图像分布的基本元素,即人脸图像样本集协方差矩阵的特征向量,以此近似地表征人脸图像。这些特征向量被称为特征脸(Eigenfaces),它们反映了隐含在人脸样本集合内部的信息和人脸的结构关系。

        EigenFaces算法首先将输入的人脸图像看作高维空间中的向量,然后对这些向量进行统计分析,计算其协方差矩阵,并提取出该矩阵的特征向量和特征值。这些特征向量就是用于表征人脸的特征脸。

3、实现步骤

        1)数据预处理

                对人脸图像进行灰度化、归一化、去噪等操作,以消除图像中的噪声和差异,提高识别准确性。

        2)特征提取

                将预处理后的人脸图像看作高维空间中的向量,通过统计分析这些向量的协方差矩阵,提取出人脸的主要特征向量(即特征脸)。

        3)构建模型

                将提取出的特征脸用于构建人脸识别模型。该模型可以是一个分类器、神经网络或其他机器学习模型。

        4)识别

                将待识别的人脸图像输入到模型中,通过比对特征脸,实现人脸识别。

4、优缺点

        1)优点

                • 简单直观:基于统计分析,可以直观地理解人脸特征的提取和识别过程。

                • 高效性:能够快速处理大量的人脸图像,实现高效的人脸识别。

        2)缺点

                • 对光照和表情变化的敏感性:在复杂环境下,光照和表情变化可能导致识别效果不佳。

                •​​​​​​​ 对训练样本数量的依赖:需要大量的训练样本才能提取出有效的特征,限制了其在小样本情况下的应用。

                •​​​​​​​ 计算复杂度较高:对于实时性要求高的应用场景可能不太适合。

二、案例实现

1、完整代码

import cv2
import numpy as npimages = []
a = cv2.imread('pyy1.png',0)   # 读取图像,改变其尺寸,将图像存入列表
a = cv2.resize(a,(170,180))
b = cv2.imread('pyy2.png',0)
b = cv2.resize(b,(170,180))
c = cv2.imread('zly1.png',0)
c = cv2.resize(c,(170,180),)
d = cv2.imread('zly2.png',0)
d = cv2.resize(d,(170,180))
images.append(a)
images.append(b)
images.append(c)
images.append(d)labels = [0,0,1,1]   # 设置列表中图像标签pre_image = cv2.imread('zly3.png',0)
pre_image = cv2.resize(pre_image,(170,180))"""创建EigenFace人脸识别器"""
# cv2.face.EigenFaceRecognizer_create(num_components=None, threshold=None)
# num_components:指定在特征脸分解过程中要保留的特征向量(即主成分)的数量,特征向量的数量决定了识别器的复杂度和准确性,如果不指定,则默认使用所有可用的特征向量。
# threshold:进行人验识别所采用的阈值,识别是通过计算待识别图像与每个已知人脸之间的欧氏距离来实现的。如果最小距离小于指定的阈值,则认为识别成功,并返回对应的标签;否则,返回-1表示未识别
recognizer = cv2.face.EigenFaceRecognizer_create()recognizer.train(images,np.array(labels))# 对预测图像(pre_image)进行人验识别预测
# confidence:大小介于0到20000,只要低于5000都被认为是可的结果。
label,confidence = recognizer.predict(pre_image)
dic= {0:'pyy',1:'zly'}
print("这人是:",dic[label])
print('置信度为:',confidence)"""在图像上写上标签内容"""
aa = cv2.putText(cv2.imread('zly3.png').copy(),dic[label], (10,30),cv2.FONT_HERSHEY_SIMPLEX, 0.9,  (0,0,255), 2)
cv2.imshow("xx",aa)
cv2.waitKey(0)
        运行结果:


http://www.ppmy.cn/devtools/127306.html

相关文章

【星闪开发连载】WS63E模组的速度测试

目录 ​编辑 引言 程序工作原理 客户端 服务器端 测试记录 近距离测试 相邻两个房间之间的测试 相隔一个房间的两个房间之间的测试 结语 引言 今天终于又有点时间了,来测试一下星闪的数据传输速度。前面的博文已经分析了星闪的传输示例sle_uuid_client和…

Redis高可用与分布式方案实战指南

Redis作为一种高性能的内存数据库,在实际应用中常常需要考虑高可用性和分布式架构。本文将详细介绍Redis的高可用解决方案(如Redis Sentinel)和分布式方案(如Redis Cluster),帮助您构建可靠且高效的Redis系…

【CTF刷题9】2024.10.19

[MoeCTF 2021]babyRCE 考点&#xff1a;关键词过滤&#xff08;绕过方法参考往期博客&#xff09; 来源&#xff1a;nssctf <?php$rce $_GET[rce]; if (isset($rce)) {if (!preg_match("/cat|more|less|head|tac|tail|nl|od|vi|vim|sort|flag| |\;|[0-9]|\*|\|\%|\&g…

S7-200 SMART 与 S7-1200 之间 TCP 通信— S7-200 SMART 作为服务器

TCP 协议通信 TCP 通信为面向连接的通信&#xff0c;需要双方都调用指令以建立连接及交换数据。S7-200 SMART 与 S7-1200 通过 TCP 通信&#xff0c;在 S7-1200 调用 T-block 指令 ( TCON, TDISCON, TSEND, TRCV ) &#xff0c;在 S7-200 SMART 调用 Open User Communication …

出现身份验证错误,无法连接到本地安全机构 顺利解决这个问题希望能帮助大家

出现身份验证错误&#xff0c;无法连接到本地安全机构&#xff0c;远程计算机&#xff1a;XX&#xff0c;这可能是由于密码过期&#xff0c;如果密码已过期请更新密码。 我们可以在系统属性中对远程进行设置&#xff0c;以解决远程桌面无法连接到本地安全机构这一问题。 步骤…

Vue3获取ref元素的几种方式

静态绑定 获取单个 dom 元素 v-for 中使用 需要注意的是&#xff0c;访问的时候&#xff0c;要确保 ref 引用值已经成功绑定上元素&#xff0c;我们可以使用以下几种方式确保获取

Linux 累加计算递归算法汇编实现

1...n可以使用公式计算&#xff0c;同时也是递归实现的很好例子&#xff0c;其c实现代码为 int f(int i) {i && (if(i-1));return i; } 其终止条件为0&#xff0c;此时i && &#xff08;if(i-1)&#xff09;表达式不成立&#xff0c;不计算if(i-1)直接返回0&…

mongoDB基础知识

文章目录 为什么使用mongoDB&#xff1f;数据模型 想了解什么mongoDB首先我们得先知道什么事“三高”&#xff1f;三高什么呐&#xff1f;具体的应用场景&#xff1f;在这些应用场景中&#xff0c;数据操作方面共同特点是&#xff1a; 什么时候选择mongoDB&#xff1f;mySQL和m…