当前位置: 首页 > news >正文

OpenCv高阶(十五)——EigenFace人脸识别

文章目录

  • 前言
  • 一、EigenFace人脸识别原理
  • 二、EigenFace人脸识别代码
    • 1、导入OpenCV和NumPy库
    • 2、数据加载与预处理部分
    • 3、创建与训练EigenFace模型部分
    • 4、预测与结果输出部分
    • 5、可视化部分:在测试图像上叠加识别结果
  • 总结


前言

人脸识别作为生物特征识别技术的重要分支,凭借其非接触性与便捷性,广泛应用于安防、金融等领域。传统方法依赖几何特征或局部纹理分析,但对光照、姿态变化敏感,泛化能力受限。1991年Turk与Pentland提出的EigenFace算法,开创性地将主成分分析(PCA)应用于人脸识别,通过构建低维“特征脸”空间实现高维人脸数据的高效表征,为统计学习方法奠定了基石。尽管深度学习已在识别精度上实现突破,但EigenFace揭示的“特征空间降维”思想仍是理解现代算法的关键。本文系统解析该算法的数学原理、实现流程与实践要点,剖析其优势与局限性,为探索复杂模型提供理论支撑。


一、EigenFace人脸识别原理

EigenFace人脸识别是一种基于主成分分析(PCA)的经典方法,用于人脸识别和降维。其核心思想是将人脸图像转换为低维特征空间中的投影,通过比较这些投影实现识别。

  1. 数据预处理
    灰度化与对齐:将所有人脸图像转换为灰度图,并调整至相同尺寸(如100×100像素),确保人脸关键部位(如眼睛、嘴巴)对齐。

向量化:将每张图像按行或列展开为一个列向量。例如,100×100的图像变为10,000维向量,记为Γi。

构建训练矩阵:将所有
K
K张训练图像的向量按列排列,构成矩阵
在这里插入图片描述
2. 计算平均脸(Mean Face)
计算所有训练图像的平均向量:
在这里插入图片描述
去中心化:每张图像减去平均脸,得到差值向量:
在这里插入图片描述
3. 主成分分析(PCA)
协方差矩阵:计算数据的变化方向,协方差矩阵为:
在这里插入图片描述
在这里插入图片描述
4. 投影与特征提取
将每张训练图像投影到特征脸空间,得到权重向量:
在这里插入图片描述
5. 识别过程
在这里插入图片描述

二、EigenFace人脸识别代码

1、导入OpenCV和NumPy库

import cv2
import numpy as np

2、数据加载与预处理部分

加载4张训练图像,并统一调整为120x180像素的灰度图

a = cv2.resize(cv2.imread('../data/face-detect/lyf1.png', 0), (120, 180))  # 参数0表示以灰度模式读取
b = cv2.resize(cv2.imread('../data/face-detect/lyf2.png', 0), (120, 180))
c = cv2.resize(cv2.imread('../data/face-detect/pyc1.png', 0), (120, 180))
d = cv2.resize(cv2.imread('../data/face-detect/pyc2.png', 0), (120, 180))

将图像存入列表,构成训练集

image = []
image.append(a)
image.append(b)
image.append(c)
image.append(d)

定义标签:前两张(lyf1, lyf2)标记为0,后两张(pyc1, pyc2)标记为1

labels = [0, 0, 1, 1]

加载待识别的测试图像,并进行相同预处理

pre_image = cv2.imread('../data/face-detect/lyf.png', 0)
pre_image = cv2.resize(pre_image, (120, 180))

3、创建与训练EigenFace模型部分

创建EigenFace识别器,设置阈值(相似度超过阈值则返回-1)
threshold参数控制分类的严格程度:值越大,判定为"未知"的可能性越高

recoginzer = cv2.face.EigenFaceRecognizer_create(threshold=5000)

使用训练图像和标签训练模型
注:OpenCV的train方法要求标签必须为NumPy数组格式

recoginzer.train(image, np.array(labels))

4、预测与结果输出部分

对测试图像进行预测,返回预测标签和置信度
注意:置信度值越小表示匹配度越高(本质上是与特征空间的距离)

labels, confidence = recoginzer.predict(pre_image)

定义标签与名称的映射字典,-1表示未知

dict = {0: 'lyf', 1: 'pyc', -1: 'not found'}

输出识别结果和置信度

print("这是", dict[labels])
print("置信度为:", confidence)  # 数值越低,匹配度越高

5、可视化部分:在测试图像上叠加识别结果

复制原始彩色图像(非灰度图)用于显示,避免修改原图

aa = cv2.putText(cv2.imread('../data/face-detect/lyf.png').copy(),  # 读取原始彩色图像并复制dict[labels],                                      # 要显示的文本内容(20, 30),                                         # 文本左下角坐标cv2.FONT_HERSHEY_SIMPLEX,                         # 字体类型0.65,                                             # 字体大小(0, 0, 255),                                      # 颜色(BGR格式,红色)1                                                 # 线宽
)

显示处理后的图像

cv2.imshow('xx', aa)
cv2.waitKey(0)  # 等待按键后关闭窗口

最终效果
在这里插入图片描述
可以类比LBPH人脸识别调用摄像头的方法,使用EigenFace人脸识别检测器来进行人脸识别

总结

EigenFace通过PCA提取人脸图像的主成分,构建低维特征空间实现高效识别。尽管已被深度学习(如CNN)超越,但其核心思想仍是理解传统模式识别方法的基础。
EigenFace算法基于PCA提取人脸主成分,构建低维特征空间实现识别,核心要点如下:

原理与实现

	流程:灰度化→尺寸统一→计算特征脸→投影匹配。代码关键:OpenCV的EigenFaceRecognizer接口实现训练与预测,阈值控制分类严格性。

挑战与优化

	数据要求:需多光照、多姿态样本增强泛化性。参数调优:通过交叉验证优化阈值,平衡识别率与误检率。预处理改进:直方图均衡化、人脸对齐提升鲁棒性。

意义与启示

	优势:简洁高效,奠定统计学习方法基础。局限:对光照、姿态敏感,局部特征捕捉弱。应用定位:轻量级场景适用,理解特征降维的经典案例。

该算法虽被深度学习超越,但其PCA思想仍是计算机视觉领域的重要理论基石。

开启新对话

http://www.xdnf.cn/news/562303.html

相关文章:

  • 【C语言】复习~数组和指针
  • JS手写代码篇---手写Promise
  • 【软件设计师】知识点简单整理
  • 数学建模,机器决策人建模
  • HTTPS和HTTP区别
  • 693SJBH基于.NET的题库管理系统
  • 用Recommenders,实现个性化推荐
  • 基于OpenCV的物体跟踪:CSRT算法
  • 自托管互联网广播电台Airstation
  • Docker网关冲突导致容器启动网络异常解决方案
  • Linux `cat` 命令深度解析与高阶应用指南
  • C++ - 仿 RabbitMQ 实现消息队列(3)(详解使用muduo库)
  • 物流项目第六期(短信微服务——对接阿里云第三方短信服务JAVA代码实现、策略模式 + 工厂模式的应用)
  • bitbar环境搭建(ruby 2.4 + rails 5.0.2)
  • 【寻找Linux的奥秘】第七章:虚拟地址空间
  • 第16天-使用Python Pillow库常见图像处理场景
  • javaweb-html
  • mapbox进阶,手写放大镜功能
  • C语言之预处理和宏
  • SAP-ABAP:ABAP异常处理与SAP现代技术融合—— 面向云原生、微服务与低代码场景的创新实践
  • 云原生攻防4(Kubernetes基础补充)
  • word通配符表
  • Linux上conda环境安装完全手札
  • OpenHarmony外设驱动使用 (十),Sensor
  • 企业级爬虫开发全流程指南
  • elementUI 中el-date-picker和el-select的样式调整
  • CSS 文字样式全解析:从基础排版到视觉层次设计
  • spring-boot-starter-data-redis应用详解
  • C# AI(Trae工具+claude3.5-sonnet) 写前后端
  • maven快速上手