opencv学习:人脸识别FisherFaceRecognizer_create算法的使用

server/2024/10/22 7:24:45/

FisherFaceRecognizer_create算法

cv2.face.FisherFaceRecognizer_create() 是 OpenCV 中用于创建 FisherFace 人脸识别模型的函数。FisherFace 是一种基于线性判别分析(Linear Discriminant Analysis,LDA)的人脸识别方法。这种方法的核心思想是在低维表示中,使得同一类别的样本尽可能聚集在一起,而不同类别的样本尽可能地分散开来,从而最大化类间距离和最小化类内距离。

函数参数

  • num_components:这是一个可选参数,表示在进行线性判别分析时保留的成分数量。如果设置为0,函数将自动设置合适的成分数量,这通常等于类别数减一(c-1)。
  • threshold:这也是一个可选参数,用于在预测时设置阈值。如果最近邻居的距离大于这个阈值,函数将返回-1,表示识别结果不可靠。

函数用法

使用 cv2.face.FisherFaceRecognizer_create() 创建的识别器可以用于训练和预测。首先,你需要准备一组训练图像和对应的标签,然后使用 train 方法训练模型。训练完成后,可以使用 predict 方法对新的人脸图像进行识别。

代码步骤

初始化一个空列表来存储图像,图像并转换为灰度图,然后调整图像大小为120x180

# 初始化一个空列表来存储图像
images=[]
# 读取图像并转换为灰度图,然后调整图像大小为120x180
a=cv2.imread('hg1.png',0)
a=cv2.resize(a,(120,180))
b=cv2.imread('hg2.png',0)
b=cv2.resize(b,(120,180))
c=cv2.imread('hjh1.png',0)
c=cv2.resize(c,(120,180))
d=cv2.imread('hjh2.png',0)
d=cv2.resize(d,(120,180))
images.append(a)
images.append(b)
images.append(c)
images.append(d)

创建标签列表,与图像列表对应

# 创建标签列表,与图像列表对应
labels=[0,0,1,1]

读取要预测的图像,转换为灰度图,并调整大小

# 读取要预测的图像,转换为灰度图,并调整大小
pre_image=cv2.imread('hg.png',0)
pre_image=cv2.resize(pre_image,(120,180))

创建FisherFace识别器实例,使用图像列表和标签列表训练识别器

# 创建FisherFace识别器实例
recongnizer=cv2.face.FisherFaceRecognizer_create()
# 使用图像列表和标签列表训练识别器
recongnizer.train(images,np.array(labels))

使用训练好的识别器预测要预测的图像的标签和置信度

# 使用训练好的识别器预测要预测的图像的标签和置信度
label,condidence=recongnizer.predict(pre_image)

在原图上添加文本标签

# 在原图上添加文本标签
aa=cv2.putText(cv2.imread('hg.png').copy(),dic[label],(10,30),cv2.FONT_HERSHEY_SIMPLEX,0.9,(0,0,255),2)cv2.imshow('s',aa)

运行结果

完整代码

import cv2  # 导入OpenCV库# 初始化一个空列表来存储图像
images = []# 读取图像并转换为灰度图,然后调整图像大小为120x180
a = cv2.imread('hg1.png', 0)
a = cv2.resize(a, (120, 180))b = cv2.imread('hg2.png', 0)
b = cv2.resize(b, (120, 180))c = cv2.imread('hjh1.png', 0)
c = cv2.resize(c, (120, 180))d = cv2.imread('hjh2.png', 0)
d = cv2.resize(d, (120, 180))# 将调整大小后的图像添加到images列表中
images.append(a)
images.append(b)
images.append(c)
images.append(d)# 创建标签列表,与图像列表对应
labels = [0, 0, 1, 1]# 读取要预测的图像,转换为灰度图,并调整大小
pre_image = cv2.imread('hg.png', 0)
pre_image = cv2.resize(pre_image, (120, 180))# 创建FisherFace识别器实例
recognizer = cv2.face.FisherFaceRecognizer_create()# 使用图像列表和标签列表训练识别器
recognizer.train(images, np.array(labels))# 使用训练好的识别器预测要预测的图像的标签和置信度
label, confidence = recognizer.predict(pre_image)# 创建一个字典来映射标签到对应的类别名称
dic = {0: "hu", 1: "hjh", -1: 'error'}# 打印预测结果和置信度
print('这人是', dic[label])
print('置信度', confidence)# 在原图上添加文本标签
aa = cv2.putText(cv2.imread('hg.png').copy(), dic[label], (10, 30), cv2.FONT_HERSHEY_SIMPLEX, 0.9, (0, 0, 255), 2)# 显示添加了文本标签的图像
cv2.imshow('s', aa)# 等待按键,0表示无限等待直到用户按下任意键
cv2.waitKey(0)

局限性

  1. 对光照敏感:FisherFace算法对光照条件比较敏感,不同的光照条件可能会影响人脸特征的提取,从而影响识别的准确性。

  2. 特征损失:在特征提取过程中,可能会损失一些重要的人脸特征信息,这在某些特殊情况下可能会导致识别错误。

  3. 计算复杂度:尽管FisherFace通过LDA降维减少了计算量,但在处理大规模数据集时,计算投影系数和散度矩阵仍然可能非常耗时。

  4. 对姿态变化敏感:FisherFace算法对于人脸的姿态变化较为敏感,侧脸或非正面人脸可能难以被准确识别。

  5. 需要足够训练样本:为了获得较好的识别效果,FisherFace算法需要足够多的训练样本来覆盖不同人脸之间的差异。


http://www.ppmy.cn/server/133829.html

相关文章

DataWhale10月动手实践——Bot应用开发task04学习笔记

一、图像流 1. 什么是图像流? 图像流是一种直观的图像处理流程工具,用户可以灵活组合各类图像处理模块。该系统将不同的图像处理工具模块化,并通过可视化界面,将这些模块以拖拽方式组合,构建完整的处理流程。用户可以…

【图文指引】5分钟搭建Django轻量级框架服务

本篇内容为从零开始搭建一个Django项目,背景是windows系统且安装了最新版本的python3.13,至于python的相关安装过程省去,可自行查看其它教程。为了保证后续各项目之间依赖包隔离,以免产生冲突问题,首先配置虚拟环境。 …

XShell 中实现免密登录 Linux 服务器的详细流程

个人主页:Jason_from_China-CSDN博客 所属栏目:Linux系统性学习_Jason_from_China的博客-CSDN博客 所属栏目:Linux知识点的补充_Jason_from_China的博客-CSDN博客 XShell 中实现免密登录 Linux 服务器的详细流程: 一、在本地生成…

倍福TwinCAT程序中遇到的bug

文章目录 问题描述:TwinCAT嵌入式控制器CX5140在上电启动后,X001网口接网线通讯灯不亮,软件扫描不到硬件网口 解决方法:硬件断电重启后,X001网口恢复正常 问题描述:TwinCAT软件点击激活配置后,…

Yolo目标检测:Yolo v1简介

一、Yolo系列介绍 YOLO(You Only Look Once)是一种基于深度学习的目标检测算法,由Joseph Redmon等人于2016年提出。它的核心思想是将目标检测问题转化为一个回归问题,通过一个神经网络直接预测目标的类别和位置。YOLO算法将输入图…

CloudStack图形化界面-创建资源域zone配置及正常关机

1.进入系统,创建资源域 打开浏览器访问http://192.168.100.10:8080/client (默认账户:admin / password) 直接跳过指南 2. 首页—》基础架构–》查看全部 在右上角—》添加资源域 基本–》名称: zone1 DNS:114.114.114.114 虚拟机管理程序:K…

补题:J. Robot Factory

传送门:Problem - 1600J - Codeforces 题意:给定一个二维矩阵,每个矩阵中的元素均为 [ 0, 15 ]的范围内,每个矩阵中的元素二进制位上为1时,就代表一堵墙(不能通过),求二维矩阵联通块…

Solon 3.0 新特性:HttpUtils 了解一下

Solon 3.0 引入一个叫 HttpUtils 小插件,这是一个简单的同步 HTTP 客户端,基于 URLConnection 适配(也支持切换为 OkHttp 适配)。使得编写 HTTP 客户端代码更加直观和易于阅读。 使用 URLConnection 适配时(大小为 40…