Opencv学习项目3——人脸识别

上一个项目我们使用2个函数检测了两张图片的人脸是否为同一个人,这次我们将他的相似度使用face_distance来显示

face_distance函数参数说明

face_recognition.face_distance(known_face_encodings, face_to_compare)

参数说明

  • known_face_encodings: 这是一个列表,包含了已知的多个人脸编码(通常是从已知的图像中提取得到的)。每个人脸编码是一个128维的向量。

  • face_to_compare: 这是一个单独的人脸编码,通常是从另一张图像中提取的。也是一个128维的向量。

返回值

  • 函数返回一个包含浮点数的数组,表示 face_to_compareknown_face_encodings 中每个人脸编码之间的欧氏距离。

功能和用途

  • 欧氏距离计算: 对于每个人脸编码对,函数计算其欧氏距离。欧氏距离越小,表示两个人脸编码之间越相似。

  • 相似度比较: 通过比较欧氏距离,可以判断两个人脸是否属于同一个人,或者在人脸识别任务中,用于识别最相似的人脸。

接下来我们来看代码

代码实现

复制代码
import cv2
import face_recognition

# 加载图像文件
img1 = face_recognition.load_image_file('lyf1.png')
img2 = face_recognition.load_image_file('lyf2.png')
# 将图像从 BGR 格式转换为 RGB 格式
img1 = cv2.cvtColor(img1, cv2.COLOR_BGR2RGB)
img2 = cv2.cvtColor(img2, cv2.COLOR_BGR2RGB)
# 第一个人的人脸位置信息
faceloc1 = face_recognition.face_locations(img1)[0]
faceloc2 = face_recognition.face_locations(img2)[0]
# 提取人脸编码
face_encoding1 = face_recognition.face_encodings(img1, [faceloc1])[0]
face_encoding2 = face_recognition.face_encodings(img2, [faceloc2])[0]
#框出人脸
cv2.rectangle(img1, (faceloc1[3], faceloc1[0]), (faceloc1[1], faceloc1[2]), (0, 255, 0), 3)
cv2.rectangle(img2, (faceloc2[3], faceloc2[0]), (faceloc2[1], faceloc2[2]), (0, 255, 0), 3)
#比对人脸特征
res = face_recognition.compare_faces([face_encoding1],face_encoding2)
facedis = face_recognition.face_distance([face_encoding1],face_encoding2)
print(res,round(facedis[0],2))
cv2.putText(img1,f'{res}{round(facedis[0],2)}',(50,50),cv2.FONT_HERSHEY_COMPLEX,1,(0,255,0),3)
#打印人脸位置信息
# print(faceloc1)
# print(faceloc2)

cv2.imshow('lyf1', img1)
cv2.imshow('lyf2', img2)
cv2.waitKey(0)

效果演示

这样就完成了

相关推荐
追光的蜗牛丿1 小时前
目标检测中的ROI Pooling
人工智能·目标检测·计算机视觉
缘华工业智维5 小时前
工业设备预测性维护:能源成本降低的“隐藏钥匙”?
大数据·网络·人工智能
于小汐在咯6 小时前
词根学习笔记 | Agri系列
笔记·学习
DooTask官方号6 小时前
跨语言协作新范式:阿里云Qwen-MT与DooTask的翻译技术突破
人工智能·ai·项目管理·机器翻译·dootask
霜绛6 小时前
Unity:Json笔记——Json文件格式、JsonUtlity序列化和反序列化
学习·unity·json·游戏引擎
凯禾瑞华养老实训室7 小时前
聚焦生活照护能力培育:老年生活照护实训室建设清单的模块设计与资源整合
大数据·人工智能·科技·ar·vr·智慧养老·智慧健康养老服务与管理
倔强青铜三7 小时前
苦练Python第64天:从零掌握多线程,threading模块全面指南
人工智能·python·面试
我命由我123458 小时前
Excel - Excel 列出一列中所有不重复数据
经验分享·学习·职场和发展·word·powerpoint·excel·职场发展
格林威8 小时前
偏振相机是否属于不同光谱相机的范围内
图像处理·人工智能·数码相机·计算机视觉·视觉检测·工业相机
璞致电子8 小时前
fpga开发板ZYNQ 璞致 PZ7010/7020 邮票孔核心板简介-ZYNQ7000系列小系统学习板
linux·嵌入式硬件·学习·fpga开发·fpga·fpga开发板·xilinx开发板