玩转大数据大数据程序员

一行做代码人脸识别:初学face_recognition

2018-05-12  本文已影响665人  无鱼二饼

前天听人吹牛,说某某的系统好牛,可以识别客户的头像,好高科技巴拉巴拉。
于是昨天找了一下,发现Python的face_regcognition包可以做,代码封装的非常简单,一点识别原理都不懂的人,也可以使用。

face_recognition项目地址

face_regcognition 可以实现的功能包括:

使用环境:Python3.6 + Windows10

因为依赖dlib库的原因,在安装前需要先安装dlib。建议使用dlib的官方包安装,否则容易报错
dlib地址

一、在示例图片上找到人脸的位置,并做框线标注

示例图片


test03.jpg

标注后的图片效果


test_result.jpg

示例

import face_recognition as fr
import cv2
img = fr.load_image_file("tmp/locations.jpg")   # 加载图片保存为numpy数组
loc = fr.face_locations(img)  # 查找人脸位置,返回位置坐标的list, 真的只有一行哦

# 遍历坐标list,给每个人脸位置画上标线框
for i in loc:
    cv2.rectangle(img, (i[3],i[0]), (i[1],i[2]), color=(0,255,255), thickness=3)

# 保存标后的图片
cv2.imwrite('/tmp/test_result.jpg', img)

二、查找最相似的人脸

示例图片:在这四张相片中,找到与目标图片最相似的人脸。范爷,范爷她弟,大景甜,明日花绮罗(好像混进了不一样的东西)


fanbingbing.jpg
fanchenchen.jpg
jingtian.jpg
mingrihuayiluo.jpg

目标图片


test01.jpg

示例

import face_recognition as fr
# 读取图像
img_a = fr.load_image_file("tmp/fanbingbing.jpg")
img_b = fr.load_image_file('tmp/fanchenchen.jpg')
img_c = fr.load_image_file('tmp/jingtian.jpg')
img_d = fr.load_image_file('tmp/mingrihuayiluo.jpg')
img_x = fr.load_image_file('tmp/test01.jpg')
# 进行特征编码
encoding_a = fr.face_encodings(img_a)[0]
encoding_b = fr.face_encodings(img_b)[0]
encoding_c = fr.face_encodings(img_c)[0]
encoding_d = fr.face_encodings(img_d)[0]
encoding_x = fr.face_encodings(img_x)[0]
# 将示例图片与目标人脸逐一对比,返回 list, 包含True/False, 表示是否匹配
fr.compare_faces([encoding_a, encoding_b, encoding_c, encoding_d], encoding_x)
# 返回 [True, True, True, False]
# 我擦,不对啊,怎么第2,3张也是True。

# 差值默认为0.5,越小对比越严格
fr.compare_faces([encoding_a, encoding_b, encoding_c, encoding_d], encoding_x, tolerance=0.4)
# 返回值[True, False, False, False],得知目标人脸属于范爷

三、对比示例人脸与目标人脸的相似度

将上面示例的人脸与目标人脸对比,计算欧氏距离。距离越小越相似。

fr.face_distance([encoding_a, encoding_b, encoding_c, encoding_d], encoding_x)
# 返回array([ 0.33231199,  0.59964459,  0.55151852,  0.63861249])
# 最相似的是第一张范爷,其次是范爷她弟,不愧是亲姐弟啊。
上一篇下一篇

猜你喜欢

热点阅读