使用Python比较两张人脸图像并获得准确度

使用 Python、OpenCV 和人脸识别模块比较两张图像并获得这些图像之间的准确度水平。

一、原理

使用Face Recognition python 模块来获取两张图像的128 个面部编码,并比较这些编码。比较结果返回 True 或 False。如果结果为True ,那么两个图像将是相同的。如果是False,则两个图像将不相同。

二、128 种面部编码

仅当比较结果返回 True 值时,才会打印准确度级别。

三、实现

首先在conda中或终端安装需要的模块

pip install opencv-python
pip install face-recognition

安装后导入模块

创建一个名为 find_face_encodings(image_path) 的新函数,它获取图像位置(路径)并返回 128 个面部编码,这在比较图像时非常有用。

find_face_encodings(image_path) 函数将使用 OpenCV 模块,从我们作为参数传递的路径中读取图像,然后返回使用 face_recognition 模块中的 face_encodings() 函数获得的 128 个人脸编码。使用两个不同的图像路径调用 find_face_encodings(image_path) 函数,并将其存储在两个不同的变量中,image_1和image_2

import cv2
import face_recognition
def find_face_encodings(image_path):
    # reading image
    image = cv2.imread(image_path)
    
    # get face encodings from the image
    face_enc = face_recognition.face_encodings(image)
    
    # return face encodings
    return face_enc[0]
# getting face encodings for first image
image_1 = find_face_encodings("image_1.jpg")

# getting face encodings for second image
image_2  = find_face_encodings("image_2.jpg")

现在,我们可以使用编码执行比较和查找这些图像的准确性等操作。

  • 比较将通过使用 face_recognition 中的 compare_faces() 函数来完成。

  • 通过找到 100 和 face_distance 之间的差异来确定准确性。

# checking both images are same
is_same = face_recognition.compare_faces([image_1], image_2)[0]
print(f"Is Same: {is_same}")
if is_same:
    # finding the distance level between images
    distance = face_recognition.face_distance([image_1], image_2)
    distance = round(distance[0] * 100)
    
    # calcuating accuracy level between images
    accuracy = 100 - round(distance)
    
    print("The images are same")
    print(f"Accuracy Level: {accuracy}%")
else:
    print("The images are not same")

参考链接:https://blog.csdn.net/woshicver/article/details/12860789

  • 34
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 11
    评论
实现两张人脸图像替换可以分为以下几个步骤: 1. 使用 OpenCV 进行人脸检测,找到要替换的人脸和替换后的人脸。 2. 对于要替换的人脸和替换后的人脸使用 OpenCV 进行人脸对齐,使得两张人脸的尺寸和角度一致。 3. 将替换后的人脸和要替换的人脸进行融合。可以使用 OpenCV 的 blend 函数将两张图片按照一定比例进行融合。 4. 最后,将融合后的图像覆盖到原始图像中,完成人脸替换。 下面是一个使用 Python 和 OpenCV 实现人脸替换的示例代码: ```python import cv2 # 加载原始图像和替换后的人脸图像 original_img = cv2.imread('original.jpg') replacement_img = cv2.imread('replacement.jpg') # 加载人脸检测器 face_detector = cv2.CascadeClassifier('haarcascade_frontalface_default.xml') # 在原始图像中检测人脸 faces = face_detector.detectMultiScale(original_img, scaleFactor=1.1, minNeighbors=5, minSize=(30, 30)) # 遍历每个人脸并进行替换 for (x, y, w, h) in faces: # 对要替换的人脸进行对齐 aligned_replacement = ... # 对替换后的人脸进行对齐 aligned_original = ... # 将替换后的人脸和要替换的人脸进行融合 blended_face = cv2.addWeighted(aligned_original, 0.5, aligned_replacement, 0.5, 0) # 将融合后的图像覆盖到原始图像中 original_img[y:y+h, x:x+w] = blended_face # 显示结果 cv2.imshow('Result', original_img) cv2.waitKey(0) cv2.destroyAllWindows() ``` 需要注意的是,这个示例代码并没有完整实现对齐和融合的过程,需要根据实际情况进行补充和调整。
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值