原文:https://mp.weixin.qq.com/s/3BgDld9hILPLCIlyysZs6Q
哈喽,大家好。
今天给大家总结几个简单、好用的人脸识别算法。 人脸识别是计算机视觉中比较常见的技术,生活中,我们接触最多的人脸识别场景是人脸考勤,我之前还专门写过一篇人脸考勤的项目,感兴趣的朋友可以看看。
人脸识别的算法最核心的工作是从一张图片中识别出人脸的位置。识别的算法可以说是多种多样, 下面我就来为大家一一介绍下。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-HpDrJQ6T-1658047045564)(https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/073fb49682aa4c65be6713f680d378dc~tplv-k3u1fbpfcp-zoom-1.image)]
\
1. HoG人脸检测
该算法采用传统的机器学习算法来识别人脸。传统机器学习算法的特点是人工构造特征,然后将构造好的特征送入模型训练。
该算法用HoG
提取图片中人脸特征,用SVM
算法进行分类。
HoG
(Histogram of Oriented Gradient, 方向梯度直方图)特征是一种在计算机视觉和图像处理中用来进行物体检测的特征描述子,通过计算和统计图像局部区域的梯度方向直方图来构成特征。
dlib
库中有该算法的实现,下面我们看看核心代码
import dlib
# 加载预训练的 HoG 人脸检测器
hog_face_detector = dlib.get_frontal_face_detector()
# 对图片进行人脸检测
results = hog_face_detector(imgRGB, 0)
for bbox in results:
x1 = bbox.left() # 人脸左上角x坐标
y1 = bbox.top() # 人脸左上角y坐标
x2 = bbox.right() # 人脸右下角x坐标
y2 = bbox.bottom() # 人脸右下角y坐标
results
存放一张图中检测出来的多个人脸, 遍历<