0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

如何用Python写一个人脸识别系统

奈因PCB电路板设计 来源:CSDN博客 作者:Together_CZ 2021-08-11 10:37 次阅读

face_recognition是一个强大、简单、易上手的人脸识别开源项目,并且配备了完整的开发文档和应用案例,特别是兼容树莓派系统。 face_recognition一经开源发布就得到的广泛的热捧,使用简单,功能强大成为其非常显著的标签。face_recognition对于公司或者是一些工程实践性的应用场景来说是非常好用好上手的利器,不需要你有太多的理论基础就可以比较轻松地去完成一个识别项目,所以今天我们专门来讲解一下。

首先face_recognition项目开源地址是:https://github.com/ageitgey/face_recognition

网上有比较完整的API说明以及实例应用,我这里就不多去说明了。首先,使用face_recognition需要安装,可以通过pip完成。

安装完成后就可以使用了,在编码前可以通过简单的测试来检验是否安装成功,如下所示:

成功安装后,就可以进入使用了。

1、定位图像中的人脸

def demoFunc():

‘’‘

在一张包含人脸的图片中圈出来人脸

’‘’

image = face_recognition.load_image_file(“test.jpg”)

face_locations = face_recognition.face_locations(image)

for one in face_locations:

y0, x1, y1, x0=one

cv2.rectangle(image, pt1=(x0, y0), pt2=(x1, y1), color=(0, 0, 255), thickness=3)

cv2.imshow(‘aaa’, image)

if cv2.waitKey(0) & 0xFF == ord(‘q’):

cv2.destroyAllWindows()

感觉还是很强大的,当然了,在我实践的过程中也发现了部分图像识别检测人脸失败的问题,这个毕竟不是一个百分之百的问题,face_recognition更像是一个基础框架,帮助我们更加高效地去构建自己的人脸识别的相关应用。

2、切割图像中的每个人脸保存本地

def demoFunc():

‘’‘

图片中人脸截图保存

’‘’

img = cv2.imread(“test.jpg”)

image = face_recognition.load_image_file(“test.jpg”)

face_locations = face_recognition.face_locations(image) #(top, right, bottom, left)

for i in range(len(face_locations)):

y0, x1, y1, x0 = face_locations[i]

cropped = img.crop((x0,y0,x1,y1)) # (left, upper, right, lower) 左上角 右下角

cropped.save(str(i)+“_.jpg”)

cropped.show()

使用的原始图像同上,结果如下所示:

五张人脸都检测成功,并且保存成功,这里主要是要注意一些face_locations这个函数的返回结果,返回的子列表中每个子列表包含4个元素,分别是单张人脸图像的左上顶点和右下顶点坐标,主要需要注意的是这四个参数的顺序,我给出来的结果中(x0,y0)表示左上顶点的坐标,(x1,y1)表示右下顶点的坐标。

3、将图像中的每个人脸编码成一个128维的向量

def demoFunc():

‘’‘

将图片中的每张人脸编码成一个128维长度的向量

’‘’

image = face_recognition.load_image_file(“cl.jpg”)

face_locations = face_recognition.face_locations(image) #(top, right, bottom, left)

face_encodings = face_recognition.face_encodings(image, face_locations) #将单个人脸数据转化为一个128维的向量

for one in face_encodings:

print(‘one: ’,one)

进行到这里就不得不去讲一下face_recognition的一些应用原理,下面是我的一些总结,如有不当欢迎指教。

face_recognition模块人脸识别应用实现的原理:

(1) 给定想要识别的人脸的图片并对其进行编码(每个人只需要一张),并将这些不同的人脸编码构建成一个列表。编码其实就是将人脸图片映射成一个128维的特征向量。

(2) 计算图像向量之间的相似度根据阈值或者是容错度来决定是否是同一个人。

(3) 输出识别结果标签。

毫不夸张地说,face_recognition整个的核心就在于这一块的向量化处理中,输入的每一张人脸图像都会被转化为一个128维的特征向量进行存储,128维特征向量的生成也是一个算法在里面的感兴趣的话可以去查一下深入了解一下,我这里就不展开了,之后的人脸识别就转化为了两个人脸图像之间向量相似度的问题了。

这里使用一张成龙大哥的图像来进行测试,原始图像如下所示:

向量化结果如下:

9dda3ef8-f6fd-11eb-9bcf-12bb97331649.png

如果自己想要构建自己的个性化应用的话一般会选择在这里进行改造,首先就是需要保存这里的特征向量。

4、输入两张人脸图像,判断是否是同一个人

def demoFunc(one_pic=‘c1.jpg’,two_pic=‘c2.jpg’):

‘’‘

给定两张图片,判断是否是同一个人

’‘’

chenglong = face_recognition.load_image_file(one_pic)

unknown_image = face_recognition.load_image_file(two_pic)

biden_encoding = face_recognition.face_encodings(chenglong)[0]

unknown_encoding = face_recognition.face_encodings(unknown_image)[0]

results = face_recognition.compare_faces([biden_encoding], unknown_encoding)

print(‘results: ’,results)

return results[0]

这里其实跟上面第三部分的有点相似,这部分是建立在第三部分基础上的只不过是自带了compare_faces这个相似度计算接口,这里其实可以自己去实现替换的。

同样,使用了两张成龙大哥的图像来进行测试,原始图像如下所示:

测试结果如下:

9e01090c-f6fd-11eb-9bcf-12bb97331649.png

5、脸部关键点识别和标注

def demoFunc(pic_path=‘cl.jpg’):

‘’‘

脸部关键点识别、标注

’‘’

image = face_recognition.load_image_file(pic_path)

face_landmarks_list = face_recognition.face_landmarks(image)

print(“I found {} face(s) in this photograph.”.format(len(face_landmarks_list)))

pil_image = Image.fromarray(image)

d = ImageDraw.Draw(pil_image)

for face_landmarks in face_landmarks_list:

for facial_feature in face_landmarks.keys():

print(“The {} in this face has the following points: {}”.format(facial_feature, face_landmarks[facial_feature]))

for facial_feature in face_landmarks.keys():

d.line(face_landmarks[facial_feature], width=5)

pil_image.show()

脸部的关键点包括:鼻子、嘴巴、眼睛、眉毛等,这里还是用的上面成龙大哥的图片,下面的结果输出:

9e15c2ca-f6fd-11eb-9bcf-12bb97331649.png

6、化妆

这部分是建立在第五部分基础上的,得到的面部的特征以后就可以进行自动化妆了,下面是具体的实现:

def demoFunc(pic_path=“haiwang.jpg”):

‘’‘

化妆

’‘’

image = face_recognition.load_image_file(pic_path)

face_landmarks_list = face_recognition.face_landmarks(image)

pil_image = Image.fromarray(image)

for face_landmarks in face_landmarks_list:

demo = ImageDraw.Draw(pil_image, ‘RGBA’)

demo.polygon(face_landmarks[‘left_eyebrow’], fill=(68, 54, 39, 128))

demo.polygon(face_landmarks[‘right_eyebrow’], fill=(68, 54, 39, 128))

demo.line(face_landmarks[‘left_eyebrow’], fill=(68, 54, 39, 150), width=2)

demo.line(face_landmarks[‘right_eyebrow’], fill=(68, 54, 39, 150), width=2)

demo.polygon(face_landmarks[‘top_lip’], fill=(150, 0, 0, 128))

demo.polygon(face_landmarks[‘bottom_lip’], fill=(150, 0, 0, 128))

demo.line(face_landmarks[‘top_lip’], fill=(150, 0, 0, 64), width=2)

demo.line(face_landmarks[‘bottom_lip’], fill=(150, 0, 0, 64), width=2)

demo.polygon(face_landmarks[‘left_eye’], fill=(255, 255, 255, 30))

demo.polygon(face_landmarks[‘right_eye’], fill=(255, 255, 255, 30))

demo.line(face_landmarks[‘left_eye’] + [face_landmarks[‘left_eye’][0]], fill=(0, 0, 0, 110), width=2)

demo.line(face_landmarks[‘right_eye’] + [face_landmarks[‘right_eye’][0]], fill=(0, 0, 0, 110), width=2)

pil_image.show()

7、基于face_recognition构建自己的简单人脸识别应用

上面介绍了很多face_recognition的应用,这里才是最重要的内容我觉得是这样的,基于已有的功能来实现我们自己的个性化应用,我这里只是简单的抛砖引玉,给出来自己的最最简单的实现:

def faceRecognitionDemo(picDir=‘data/’, test_pic=‘test.png’):

‘’‘

基于 face_recognition 构建人脸识别模块

’‘’

pic_list=os.listdir(picDir)

for one_pic in pic_list:

one_pic_path=picDir+one_pic

one_res=demo6(one_pic=one_pic_path,two_pic=test_pic)

one_name=one_pic.split(‘。’)[0].strip()

if one_res:

print(‘This Person is: ’, one_name)

break

else:

print(‘This Person is not: ’, one_name)

结果输出如下:

9ef55f20-f6fd-11eb-9bcf-12bb97331649.png

当然了,实时计算肯定当前的计算方式不能满足的,这个只是一个最简单的应用而已,只想在这里抛砖引玉,这里是通过调用了face_recognition接口的形式来完成相似判定的工作的,还有一种非常常见的办法,就是在得到人脸图像的128维特征向量之后,就可以将人脸识别问题转化为基于机器学习模型的一个简单分类问题了,比如SVM、RF、GBDT等都可以非常出色地完成上面的任务。

责任编辑:haq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 人脸识别
    +关注

    关注

    76

    文章

    3953

    浏览量

    80531
  • python
    +关注

    关注

    51

    文章

    4667

    浏览量

    83440

原文标题:手把手教你用Python写个简单又强大的人脸识别系统

文章出处:【微信号:pcbgood,微信公众号:奈因PCB电路板设计】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    基于labview的人脸识别系统的设计………………

    我现在做的是基于labview的人脸识别系统的设计与实现,现在已经开始在做,但是在算法这块被卡到了,不知道改用什么样的算法和如何实现这个算法,可能是水平低了点把,请高人指点下啊!!
    发表于 03-17 09:56

    基于LabVIEW的语音识别系统

    请大家帮帮忙,基于LabVIEW的语音识别系统,要求先录几个人的声音做样板,然后再让其中一个人说话,能辨别出是谁说的
    发表于 05-16 11:16

    【LeMaker Guitar申请】基于LeMaker Guitar的人脸识别系统

    学习对嵌入式应用层开发有更深入的认识。项目描述:基于LeMaker Guitar的人脸识别系统设计思路是把 OpenCV移植到嵌入式操作系统
    发表于 01-18 16:23

    【LeMaker Guitar试用体验】之基于Python下的人脸识别系统【结贴】

    Python编程语言下实现基于LeMaker Guitar的人脸识别系统,具体方案操作如下。.实验说明系统设备:1.LeMakerGuit
    发表于 02-25 14:03

    有大神吗?找大神帮忙做一个人脸识别

    有大神吗?找大神帮忙做一个人脸识别
    发表于 04-17 21:39

    浅谈人脸识别系统在智慧社区方面的应用

    车牌、颜色、品牌、型号等比对致无误时,方可正常通过。如果有系统未录入信息的临时车辆进入时,车辆识别系统将发出警报或者发出短信给相关负责人,由相关负责人放行临时车辆。 人脸
    发表于 09-26 14:03

    基于嵌入式LInux的人脸识别系统

    1,基于嵌入式LInux的人脸识别系统
    发表于 10-27 07:02

    基于linux操作系统实现一个人脸识别门禁系统

    形成组网,实现一个人脸识别门禁系统。客户端为嵌入式Linux设备,采用QT库显示界面,通过摄像头采集图像。服务器为PC上 Ubuntu系统,采用QT库显示界面,以OpenCV库为基础进
    发表于 12-14 06:24

    用隐马尔可夫模型设计人脸表情识别系统

    根据隐马尔可夫模型(HMM)的基本理论和算法设计了一个人脸表情识别系统。该系统由两层HMM组成:低层由六个HMM组成,分别对应六种特定表情。人脸表情特征向量进入
    发表于 05-14 19:53 26次下载

    人脸识别系统定位功能剖析

    经常被网友问到“人脸识别系统是如何找到人的?”,本文将通过实际案例具体分析人脸识别系统的组成、人脸识别系
    发表于 08-29 14:46 5522次阅读

    如果一个人化妆了还能被人脸识别系统认出来吗

    万维人脸识别技术是利用分析比对的技术来实现人脸识别,一项热门的计算机技术研究领域,其中包括人脸追踪侦测,自动调整影像放大,夜间红外侦测,自动
    发表于 07-09 17:23 9585次阅读

    人脸识别系统的厂家如何选择

    人脸识别是最近几年大家听到比较多的一个热门词,听上去就感觉非常的高科技。的确,人脸识别系统是通过对一个人的脸部信息进行收集并且
    发表于 09-02 15:15 744次阅读

    如何使用ESP32-CAM构建一个人脸识别系统

    在这个项目中,我们将使用 ESP32-CAM 构建一个人脸识别系统,该系统还可以通过识别未经授权的人的面部来作为 ESP32-CAM 安全系统
    发表于 08-22 16:35 1.4w次阅读
    如何使用ESP32-CAM构建<b class='flag-5'>一个人脸</b><b class='flag-5'>识别系统</b>

    Xilinx KV 260构建一个人脸识别车库门锁

    电子发烧友网站提供《Xilinx KV 260构建一个人脸识别车库门锁.zip》资料免费下载
    发表于 10-26 11:24 7次下载
    Xilinx KV 260构建<b class='flag-5'>一个人脸</b><b class='flag-5'>识别</b>车库门锁

    基于python代码的人脸识别实例

    基于python代码的一个人脸识别的实例,完整的实例,本人在pycharm中实测通过,是一个很基础的入门级的人脸检测和识别
    发表于 07-18 11:11 10次下载