小白教程-人脸识别
背景
公司的门禁,通过识别检测,如果是公司的员工,就开门,否则不开门。用的是百度的人脸识别技术实现。突然公司要自研(毕竟百度是收费的),也许要彰显公司的技术实力。任务分配给我,我一个搞Java的,Java并不擅长图片的处理,调研下,python比较适合做这方面场景的应用,但是我对python,只能说了解,并不熟练,肿么办呢?尽然给我了,当做学习了,硬着头皮就上。
技术调研
谷歌是最好的老师,搜索下,找找这方面的资料。但是心里面也得想想大概的流程,第一步,我怎么才能检测出图片上,有没有人呢,这是比较关键的一步,经过搜索比对,发现insightface,能识别出图片上,有没有人。那图片上检测出人,剩下的就是图片上的人,跟目标图片比对下,看两个人的相似度是多少,设置一个阀值,达到这个值就是一个人,然后告诉门禁,开门,万事大吉,搞定。理一理流程,流程如下:
insightface介绍
InsightFace 是一个开源的 2D 和 3D 深度人脸分析工具箱,主要基于 PyTorch 和 MXNet。
详情查看网站。
InsightFace 有效地实现了丰富多样的人脸识别、人脸检测和人脸对齐的最新算法,并对训练和部署进行了优化。
环境搭建
前提先要安装python,python版本3.6以上,安装下面的库
# 安装人脸识别包
# 人脸识别库
pip install -U insightface
# 图片处理的库
pip install opencv-python
识别人脸
import cv2
from insightface.app import FaceAnalysis
# 加载人脸识别模型
app = FaceAnalysis(providers=['CUDAExecutionProvider', 'CPUExecutionProvider'])
app.prepare(ctx_id=0, det_size=(640, 640))
# 读取图片
img = cv2.imread("./test.jpeg")
# 获取人脸数据
faces = app.get(img)
# 把图片中的人脸圈出来
rimg = app.draw_on(img, faces)
# 对图片中的人脸处理后保存
cv2.imwrite('./t1_output.jpg', rimg)
测试图片
test.jpeg
识别后的效果
image.png
那现在我们准确的识别出测试图片里面有三个人,同时标识出人脸的位置。其实,提出人脸数据是一些图片像素点,人脸识别出来了,那接下来,就只需要,识别出,图片里的人脸是谁,完成了检测比对
人脸比对
录入人脸数据
需要提前录入人脸,进行识别,提取人脸数据,进行存储,存储可以本地文件存储,也可以使用向量数据库存储,比如:milvus,此代码演示使用pickle进行本地存储,需要提前安排库,
pip install pickle4
图片数据
我们准备了杨紫、景甜的照片,也可以自己找其他图片进行测试
杨紫.jpeg 景甜.jpeg
注册的核心代码
import pickle
from numpy.linalg import norm
import cv2
import numpy as np
from insightface.app import FaceAnalysis
app = FaceAnalysis(providers=['CUDAExecutionProvider', 'CPUExecutionProvider'])
app.prepare(ctx_id=0, det_size=(640, 640))
faces_embedding = list()
# # 使用本地人家存储
f = open('./face_ai_db', 'wb')
# 读取照片
img1 = cv2.imread("./杨紫.jpeg")
# 提取人脸数据
yzFace = app.get(img1)
# 杨紫人脸数据加入到列表中
faces_embedding.append({"userName":"杨紫","embedding":yzFace[0].normed_embedding})
# 读取景甜的照片
img2 = cv2.imread("./景甜.jpeg")
# 提取杨紫的人脸数据
jtFace = app.get(img2)
# 景甜人脸数据加入到列表中
faces_embedding.append({"userName":"景甜","embedding":jtFace[0].normed_embedding})
pickle.dump(faces_embedding,f)
f.close()
执行此程序,杨紫、景甜提取的人脸数据已经存在,本地文件 face_ai_db文件中
对目标图片进行识别
对目标图片,进行识别,找出里面有没有库里的人
import pickle
from numpy.linalg import norm
import cv2
import numpy as np
from insightface.app import FaceAnalysis
app = FaceAnalysis(providers=['CUDAExecutionProvider', 'CPUExecutionProvider'])
app.prepare(ctx_id=0, det_size=(640, 640))
# 使用本地人家存储
f = open('./face_ai_db', 'rb')
# 加载前面存储的人脸数据
faces_embedding = pickle.load(f)
# 读取图片
img = cv2.imread("./test.jpeg")
# 图片里面有多个人,faces就有多个值,是个数组
faces = app.get(img)
# 用提取的每一张人脸去跟库里面的人脸数据比对,检测出是否有库里的注册的人
for face in faces:
feat1 = face.normed_embedding
for t in faces_embedding:
feat2 = t["embedding"]
# 余弦相似度比较
sim = np.dot(feat1, feat2) / (norm(feat1) * norm(feat2))
sim = sim * 100
# 设置一个阈值,就是分数,大于40,就得到我们库里的人,打印下分数 以及是哪个明星
if sim >40:
print("姓名:{},分数;{}".format(t['userName'],sim))
测试结果:准确的识别出图片人
姓名:景甜,分数;64.38514590263367
姓名:杨紫,分数;44.4240003824234
这就简单实现了,人脸的检测识别,文章对你有帮助,麻烦点赞关注,谢谢,后续会继续分享。