比价网站开发,平面设计做画册用网站,好的网站建设公司,广州免费停车的地方文章目录1 Eigenfaces1.1 建模流程1.2 示例代码2 Fisherfaces2.1 建模流程2.2 示例代码3 Local Binary Histogram3.1 建模流程3.2 示例代码OpenCV 提供了三种人脸识别方法#xff1a;Eigenfaces
Eigenfaces是一种基于PCA#xff08;Principal Component Analysis#xff0c…
文章目录1 Eigenfaces1.1 建模流程1.2 示例代码2 Fisherfaces2.1 建模流程2.2 示例代码3 Local Binary Histogram3.1 建模流程3.2 示例代码OpenCV 提供了三种人脸识别方法Eigenfaces
Eigenfaces是一种基于PCAPrincipal Component Analysis主成分分析的人脸识别方法属于OpenCV中的特征脸方法之一。该方法将人脸图像转换为低维的特征向量使用PCA降维的方式提取出训练集中的主成分特征进而提取出人脸图像的特征向量。在进行识别时通过比较输入图像与训练集中每个图像的特征向量的相似度来判断其所属的人脸类别。
Local Binary Patterns Histograms (LBPH)
LBPH 是一种基于局部二值模式Local Binary Pattern的人脸识别方法它将每个像素与周围的像素进行比较计算出每个像素点的二进制编码再将编码串联起来形成一个局部特征。LBPH 的优点是对于图像的旋转、缩放和灰度变化等不敏感但对于遮挡和表情变化等因素的鲁棒性还有待提高。
Fisherfaces
Fisherfaces 是一种基于线性判别分析Linear Discriminant Analysis的人脸识别方法它通过将图像投影到低维空间将图像从高维特征向量转换为低维特征向量并使用低维特征向量进行分类。Fisherfaces 的优点是对于光照、表情变化等因素的鲁棒性很强但对于遮挡的鲁棒性还有待提高。
1 Eigenfaces
Eigenfaces 是一种基于主成分分析Principal Component Analysis, PCA的人脸识别方法它是最早的、也是最简单的人脸识别方法之一。
Eigenfaces 方法将每个人脸图像看作一个高维向量通过对这些向量进行 PCA 变换得到一组特征向量也称为 eigenfaces并将每个人脸图像投影到这组特征向量上从而将高维的人脸数据降维到一个低维的特征空间中进而实现人脸识别。
1.1 建模流程
首先通过cv2.face.EigenFaceRecognizer_create()创建Eigenfaces识别器
EigenFaceRecognizer cv2.face.EigenFaceRecognizer_create([, num_components[, threshold]])其中可选参数num_components表示PCA保留的特征数量默认为0即保留所有特征。可选参数threshold表示一个阈值当人脸图像与训练数据的差异小于该阈值时认为这是同一个人。默认值为0表示不使用阈值。
该方法返回一个EigenFaceRecognizer对象可以使用其train()方法进行训练predict()方法进行预测save()和load()方法保存和加载模型。
随后进行训练
cv2.face.EigenFaceRecognizer_create().train(src, labels)
或
EigenFaceRecognizer.train(src, labels)其中
src训练数据可以是一个列表或一个 NumPy 数组其中每个元素都是包含人脸图像的数组。labels与训练数据对应的标签传入的一个 NumPy 数组其中每个元素都是一个整数标签表示训练数据中对应人脸的身份信息。
该函数不返回任何值训练后的识别器会保存在类实例中可以通过调用 cv2.face.EigenFaceRecognizer_create().predict() 函数使用它。
最后使用模型进行预测
label, confidence recognizer.predict(src)recognizer.predict(src)函数是使用已经训练好的人脸识别器对输入的人脸图像进行识别。它接收一个参数src即待识别的人脸图像。该函数返回两个值
label表示识别结果对应的人脸标签通常是一个整数。confidence表示识别结果的置信度或准确度。值越小表示置信度越高一般情况下评分小于5000就可以认为匹配度高评分为0则为完全一样。
1.2 示例代码
下面提供一个代码脚本大概的流程为
定义一个空列表 photos 和一个空列表 labels。使用 OpenCV 中的 cv2.imread() 函数读取一组人脸图像并将其添加到 photos 列表中。每张图像都有一个对应的标签表示这张图像属于哪个人。创建一个字典 names将每个标签与对应的人名关联起来。使用 OpenCV 中的 cv2.face.EigenFaceRecognizer_create() 函数创建一个特征脸识别器。使用 recognizer.train() 函数训练识别器让其学会如何识别这组人脸图像。读取一张待识别的人脸图像并使用 recognizer.predict() 函数对其进行识别。该函数返回一个标签和一个置信度评分。打印出评分和对应的人名。
训练数据网上可以较为容易的找到也可以博客下面留言获取。
import cv2
import numpy as np photos list()
lables list()
photos.append(cv2.imread(第一张图象地址后面依此类推, 0))
lables.append(0) # 第1张图像对应的标签
photos.append(cv2.imread(, 0))
lables.append(0) # 第2张图像对应的标签
photos.append(cv2.imread(, 0))
lables.append(0) # 第3张图像对应的标签 photos.append(cv2.imread(, 0))
lables.append(1) # 第4张图像对应的标签
photos.append(cv2.imread(, 0))
lables.append(1) # 第5张图像对应的标签
photos.append(cv2.imread(, 0))
lables.append(1) # 第6张图像对应的标签 names {0: 张三, 1: 李四} # 标签对应的名称字典 recognizer cv2.face.EigenFaceRecognizer_create() # 创建特征脸识别器
recognizer.train(photos, np.array(lables)) # 识别器开始训练 i cv2.imread(待识别.png, 0) # 待识别的人脸图像
label, confidence recognizer.predict(i) # 识别器开始分析人脸图像
print(confidence str(confidence)) # 打印评分
print(names[str(label)]) # 数组字典里标签对应的名字
cv2.waitKey()
cv2.destroyAllWindows()其运行结果为;
2 Fisherfaces
Fisherfaces 是一种基于线性判别分析Linear Discriminant Analysis, LDA的人脸识别方法它是 Eigenfaces 方法的改进版本。
Fisherfaces 通过寻找最佳的投影方向线性变换将高维的人脸数据投影到一个低维的特征空间中从而实现人脸识别。与 Eigenfaces 不同的是Fisherfaces 不仅仅考虑样本之间的距离还考虑了样本所属的类别之间的距离因此更加适用于多类别人脸识别。
Fisherfaces 方法与 Eigenfaces 方法相比具有更高的识别率和更好的鲁棒性但计算成本较高。
2.1 建模流程
OpenCV的各模型建模流程相同除
recognizer cv2.face.EigenFaceRecognizer_create()
# 需要改成
recognizer cv2.face.FisherFaceRecognizer_create()其余均不需更改。
2.2 示例代码
示例代码与1.2中基本完全相同需要更改的就是2.1中提到的部分。 更改方法后运行结果为 此处看出这个模型的confidence较高也就是对结果更没有信心其原因可能是因为 Fisherfaces 方法对样本数据的数量和质量的要求较高以及对输入图像的光照、姿态、表情等变化更加敏感。
具体来说Fisherfaces 方法需要在训练集中包含足够多的样本并且每个样本需要具有代表性才能够获得较好的分类效果。此外Fisherfaces 方法对于输入图像的光照、姿态、表情等变化比较敏感这些因素会影响特征向量的提取和分类结果的准确性从而降低置信度。
相比之下Eigenfaces 方法虽然对于样本数量和质量的要求不高也比较容易实现但其在人脸识别方面的分类能力和鲁棒性较差因此在某些情况下可能会出现识别错误的情况从而导致置信度较低。
3 Local Binary Histogram
3.1 建模流程
Local Binary HistogramLBH是一种基于局部二值模式Local Binary Pattern, LBP的人脸识别方法。与前面提到的基于 PCA 或 LDA 的人脸识别方法不同LBH 方法直接利用局部纹理特征进行人脸识别具有较好的鲁棒性和识别精度。
具体来说LBH 方法通过以下步骤实现人脸识别 对于每个人脸图像将其分成若干个局部区域并计算每个局部区域的 LBP 特征。 将每个局部区域的 LBP 特征用直方图统计的方法转换为一个向量。 将每个人脸图像的局部区域 LBP 特征向量组合成一个全局的特征向量并将其归一化。 对于测试集中的每个人脸图像同样将其分成若干个局部区域并计算每个局部区域的 LBP 特征。将每个局部区域的 LBP 特征向量用直方图统计的方法转换为一个向量并将这些向量组合成一个测试集的全局特征向量。 计算训练集中每个人脸图像的全局特征向量与测试集中人脸图像的全局特征向量之间的距离将距离最小的训练集中的人脸图像所属的类别作为测试集中人脸图像的识别结果。
相比于传统的基于 PCA 或 LDA 的人脸识别方法LBH 方法更加鲁棒能够更好地应对光照、姿态、表情等变化同时具有较高的识别率和较低的计算成本因此被广泛应用于人脸识别和相关领域。
3.2 示例代码
此处需要更改的部分
recognizer cv2.face.LBPHFaceRecognizer_create()此处因计算方法不同需注意返回值confidence的含义与前两者不同。 此模型的返回值小于50认为匹配度较高0则为完全一样。
代码的输出为