美文网首页
小白教程-人脸识别

小白教程-人脸识别

作者: 柯柏笔记 | 来源:发表于2023-11-08 15:04 被阅读0次

背景

公司的门禁,通过识别检测,如果是公司的员工,就开门,否则不开门。用的是百度的人脸识别技术实现。突然公司要自研(毕竟百度是收费的),也许要彰显公司的技术实力。任务分配给我,我一个搞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

这就简单实现了,人脸的检测识别,文章对你有帮助,麻烦点赞关注,谢谢,后续会继续分享。

相关文章

  • Windows 平台下实现人脸识别入门

    本教程基于虹软免费的人脸认知引擎,介绍了人脸检测和人脸识别如何应用于实践。 此为小白教程,高手可略过。 第一步: ...

  • Windows免费人脸SDK开发——小白教程

    本教程基于虹软免费的人脸认知引擎,介绍了人脸检测和人脸识别如何应用于实践。此为小白教程,高手可略过。第一步:先从虹...

  • 人脸识别AK信息获取教程

    人脸识别AK信息获取教程

  • 树莓派进行人脸识别

    人脸识别大家并不陌生,在树莓派上进行人脸识别的教程已经有不少了,所以本文就不上传代码了。跟着网上的教程弄完之后我发...

  • 人脸识别技术 通识

    人脸识别技术 通识 1 人脸识别概要 2 人脸识别工作原理 3 人脸识别技术分类 4 人脸识别技术优缺点 5 人脸...

  • 都在说人脸识别有Bug,是真的吗?

    “人脸识别破解”“反人脸识别技术”“人脸识别漏洞”“人脸识别失误”“尽量不要用人脸识别”….网上N多这样的信息铺天...

  • 2020-06-09

    云卡通人脸识别系统含盖:动态人脸识别门禁管理系统、动态人脸识别消费系统、动态人脸识别考勤系统。其中动态人脸识别消费...

  • 我所理解的“人脸识别”行业

    我是个技术小白,对事物好奇。因为工作原因,需要大概了解一下人脸识别这个行业。通过半天的网络搜索,查找关于“人脸识别...

  • 人脸识别闸机安装知识

    随着人脸识别技术的成熟,人脸识别闸机越来越受欢迎,在选型上也丰富多样。人脸识别闸机包含人脸识别摆闸、人脸识别翼闸、...

  • 2020-07-28

    一、人脸识别系统具有广泛的应用:包括人脸识别出入管理系统、人脸识别门禁考勤系统、人面识别消费管理系统、人脸识别通道...

网友评论

      本文标题:小白教程-人脸识别

      本文链接:https://www.haomeiwen.com/subject/mieqwdtx.html