OpenFace人脸分类器训练

  本篇文章关于OpenFace人脸分类器训练,默认已经安装好了OpenFace和其他的依赖关系,如何配置可见上一篇文章

  参考文章

  如有雷同,绝非巧合

  1.准备素材

  人脸原图,每个图包含一个人脸,每个人脸n张图(>15)。不同人的照片放入不同的文件夹下。有多少个人就多少个文件夹即可,如下图:

这里写图片描述
这里写图片描述

  2.素材处理

  包括人脸查找(找到人脸在图像中的位置)

  矫正(拉到正面)

  裁剪(把矫正完的人脸裁剪成96*96像素的正方形图片)

./util/align-dlib.py ./2dface/ align outerEyesAndNose ./aligned-images/ --size 96

  搞定之后在“aligned-images”文件夹中存放着处理好的图像(其中太模糊找不到脸的则被丢弃)

这里写图片描述
这里写图片描述

  3.特征提取

  每个人脸提取128个特征点,提取后保存为csv文件,放入/generated-embeddings/目录中:

./batch-represent/main.lua -outDir ./generated-embeddings/ -data ./aligned-images

  4.模型训练

  训练自己的面部检测模型(SVM模型):输出文件为“classifier.pkl”, 路径为:generated-embeddings/

./demos/classifier.py train ./generated-embeddings/

  5.人脸分类

  获取一张不在数据集中的照片,通过跟前面相同的操作提取出特征之后可由分类器分类得到分类结果和置信度。

./demos/classifier.py infer ./generated-embeddings/classifier.pkl 3.jpg

  基本上对训练集中两个人别的照片分类还是比较靠谱的,但如果随意放入陌生的照片进去,会得到两个人中的一个,置信度还很高,这应该是训练样本太少造成的。后面再做研究。

OpenCV(Open Source Computer Vision Library)是一个开源的计算机视觉库,它提供了很多常用的功能,用于处理图像、视频以及实现计算机视觉算法。在人脸比对方面,OpenCV可以使用一些预训练的深度学习模型或者自己训练模型来提取人脸特征,然后通过比较人脸特征的相似度来实现比对。 实现人脸比对通常分为以下几个步骤: 1. 人脸检测:使用OpenCV中的Haar级联分类器或深度学习方法来检测图像中的人脸。 2. 人脸对齐:通过检测到的人脸关键点,对人脸进行对齐操作,以减少姿态、光照等因素的影响。 3. 特征提取:使用深度学习模型(如FaceNet、OpenFace等)提取人脸特征向量。 4. 特征比较:计算两个特征向量之间的距离,常用的度量方式包括欧氏距离、余弦相似度等,以此来判断人脸的相似度。 使用OpenCV进行人脸比对的一个简单例子可能是这样的: ```python import cv2 import numpy as np # 加载预训练人脸识别模型 face_cascade = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_frontalface_default.xml') # 读取图片并进行人脸检测 image1 = cv2.imread('face1.jpg') gray1 = cv2.cvtColor(image1, cv2.COLOR_BGR2GRAY) faces1 = face_cascade.detectMultiScale(gray1, scaleFactor=1.1, minNeighbors=5) # 假设我们只检测到一张脸 (x1, y1, w1, h1) = faces1[0] # 提取人脸区域 face1 = gray1[y1:y1+h1, x1:x1+w1] # 对第二张图片重复上述过程 image2 = cv2.imread('face2.jpg') gray2 = cv2.cvtColor(image2, cv2.COLOR_BGR2GRAY) faces2 = face_cascade.detectMultiScale(gray2, scaleFactor=1.1, minNeighbors=5) (x2, y2, w2, h2) = faces2[0] face2 = gray2[y2:y2+h2, x2:x2+w2] # 比较两个人脸区域 # 这里使用简单的欧氏距离,实际应用中可能需要更复杂的特征向量和距离度量 distance = np.linalg.norm(face1 - face2) # 根据距离判断是否是同一个人 if distance < 阈值: print("这两个脸很相似") else: print("这两个脸不相似") ``` 请注意,上述代码仅为示例,实际应用中应该使用深度学习方法提取特征向量,并计算特征向量之间的距离。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值