基于Pyhton的人脸识别(Python 3.12+face_recognition库)

news2024/12/28 3:18:44

使用Python进行人脸编码和比较

简介

在这个教程中,我们将学习如何使用Python和face_recognition库来加载图像、提取人脸编码,并比较两个人脸是否相似。face_recognition库是一个强大的工具,它基于dlib的深度学习模型,可以轻松实现人脸检测和识别功能。本教程适合初学者,我们将通过一个简单的项目来了解这个库的基本用法和环境配置。

代码示例

import face_recognition
import cv2
import matplotlib.pyplot as plt

def load_and_encode_face(image_path):
    """加载图片并获取人脸编码"""
    # 加载图像
    image = face_recognition.load_image_file(image_path)

    # 检查图像是否为8位灰度或RGB
    if image.dtype == 'uint8' and (len(image.shape) == 2 or image.shape[2] == 3):
        # 图像已经是8位灰度或RGB
        pass
    else:
        # 转换为8位RGB图像
        image = cv2.convertScaleAbs(image)
        if len(image.shape) == 2:
            # 如果是灰度图像,转换为RGB
            image = cv2.cvtColor(image, cv2.COLOR_GRAY2RGB)
        elif image.shape[2] == 4:
            # 如果是RGBA,转换为RGB
            image = cv2.cvtColor(image, cv2.COLOR_RGBA2RGB)

    face_encodings = face_recognition.face_encodings(image)

    if face_encodings:
        return face_encodings[0], image
    else:
        raise ValueError("No faces found in the image.")

def compare_faces(known_face_encoding, unknown_face_encoding, tolerance=0.5):
    """比较两个人脸编码是否相似"""
    results = face_recognition.compare_faces([known_face_encoding], unknown_face_encoding, tolerance=tolerance)
    return results[0]

def plot_faces(known_image, unknown_image, match):
    """绘制并显示两张人脸图像"""
    fig, axes = plt.subplots(1, 2, figsize=(12, 6))
    axes[0].imshow(cv2.cvtColor(known_image, cv2.COLOR_BGR2RGB))
    axes[0].set_title("Known Face")
    axes[1].imshow(cv2.cvtColor(unknown_image, cv2.COLOR_BGR2RGB))
    axes[1].set_title("Unknown Face")

    # 显示匹配结果
    if match:
        plt.suptitle("Faces Match")
    else:
        plt.suptitle("Faces Do Not Match")
    plt.show()

def main():
    try:
        # 图像路径
        known_image_path = "你的图像路径"
        unknown_image_path = "你的图像路径"

        print(f"Known image path: {known_image_path}")
        print(f"Unknown image path: {unknown_image_path}")

        # 加载并编码已知人脸
        known_face_encoding, known_image = load_and_encode_face(known_image_path)

        # 加载并编码未知人脸
        unknown_face_encoding, unknown_image = load_and_encode_face(unknown_image_path)

        # 比较人脸
        match = compare_faces(known_face_encoding, unknown_face_encoding)
        print(f"Do the faces match? {match}")

        # 绘制并显示两张人脸图像
        plot_faces(known_image, unknown_image, match)
    except ValueError as e:
        print(e)
    except Exception as e:
        print(f"An error occurred: {e}")

if __name__ == "__main__":
    main()

环境准备

在开始之前,请确保您的Python环境已经安装了以下库:

  • face_recognition:用于人脸检测和识别。
  • opencv-pythoncv2):用于图像处理。
  • matplotlib:用于显示图像。

您可以使用pip命令安装这些库:

pip install cmake
pip install boost
pip install face_recognition opencv-python matplotlib

在安装Python库的过程中,我们可能会遇到各种问题。以下是针对Python 3.12环境中一些常见问题的解决方案。请注意,不同版本的解决方案可能会有所不同,以下内容仅供参考。

问题1:安装依赖时出错

如果您在安装过程中遇到错误,且无法根据错误信息下载对应的依赖包,可以尝试以下步骤:
在这里插入图片描述

  1. 安装或更新setuptools
    setuptools是Python包的构建和分发工具,它是可以帮助解决一些依赖问题。

    pip install  setuptools
    

    如果问题得到解决,您可能不需要进行下一步。

  2. 安装distribute
    在某些情况下,安装或更新distribute可以解决安装问题。

    pip3 install distribute
    

问题2:图像处理错误

如果您在处理图像时遇到错误,即使将图像转换为RGB颜色后问题仍然存在,可以尝试以下步骤:
在这里插入图片描述

  1. 修改NumPy版本
    有时候,错误可能是由于NumPy版本不兼容引起的。尝试安装一个特定版本的NumPy可能会解决问题。
    pip install numpy==1.26.4
    
    选择一个与您的环境兼容的NumPy版本。

当您遇到dlib库自动下载失败或者下载后无法正常使用的情况时,您可以选择手动下载特定版本的dlib库以确保兼容性和稳定性。对于使用Python 3.12的环境,您需要下载与您的Python版本和操作系统架构相匹配的dlib库文件。

手动下载dlib库

针对Python 3.12,您可以手动下载名为 dlib-19.24.99-cp312-cp312-win_amd64.whl 的文件。这是一个预编译的wheel文件,专为Python 3.12和64位Windows系统设计,可以避免编译过程中可能出现的问题。

下载步骤

  1. 访问dlib的PyPI页面:https://pypi.org/simple/dlib/

    请注意,如果您在访问此链接时遇到问题,可能是由于网络问题或链接本身的问题。请检查链接的合法性,并在网络稳定的情况下重试。

  2. 在页面上找到与您的Python版本和操作系统相匹配的wheel文件。对于Python 3.12和64位Windows系统,您需要寻找类似 dlib-19.24.99-cp312-cp312-win_amd64.whl 的文件。

  3. 下载相应的wheel文件到您的本地计算机。

安装步骤

下载完成后,您可以使用pip命令来安装下载的wheel文件:

pip install /path/to/dlib-19.24.99-cp312-cp312-win_amd64.whl

请将 /path/to/ 替换为您保存wheel文件的实际路径。

注意事项

  • 确保您的Python版本和操作系统架构与下载的wheel文件相匹配。
  • 如果您在安装过程中遇到任何问题,可以尝试清理pip缓存(使用 pip cache purge)或者重新安装pip。
  • 如果手动下载和安装仍然遇到问题,建议检查Python环境是否正确设置,或者寻求社区的帮助。

以下是一个百度链接的分享

链接: https://pan.baidu.com/s/13AARGnZs8Lv46txN623SYg?pwd=upjc 提取码: upjc

  • 百度网盘下载- :dlib-19.24.99-cp312-cp312-win_amd64.whl

代码解析

下面是一个完整的Python脚本,它包含了加载图像、提取人脸编码、比较人脸以及显示结果的全过程。

1. 导入库

首先,我们需要导入所需的库:

import face_recognition
import cv2
import matplotlib.pyplot as plt

其中 我们在导入时 导入cv2假设我们直接下载这个名称的库,可能会显示 不存在根据教程中之前的内容

pip install  opencv-python 

2. 加载和编码人脸

我们定义了一个函数load_and_encode_face,它接受一个图像路径作为参数,加载图像,并提取其中的人脸编码。

def load_and_encode_face(image_path):
    # 加载图像
    image = face_recognition.load_image_file(image_path)

    # 检查图像是否为8位灰度或RGB
    if image.dtype == 'uint8' and (len(image.shape) == 2 or image.shape[2] == 3):
        # 图像已经是8位灰度或RGB
        pass
    else:
        # 转换为8位RGB图像
        image = cv2.convertScaleAbs(image)
        if len(image.shape) == 2:
            # 如果是灰度图像,转换为RGB
            image = cv2.cvtColor(image, cv2.COLOR_GRAY2RGB)
        elif image.shape[2] == 4:
            # 如果是RGBA,转换为RGB
            image = cv2.cvtColor(image, cv2.COLOR_RGBA2RGB)

    face_encodings = face_recognition.face_encodings(image)

    if face_encodings:
        return face_encodings[0], image
    else:
        raise ValueError("No faces found in the image.")

3. 比较人脸

接下来,我们定义了compare_faces函数,它接受两个人脸编码和一个容差值作为参数,并返回比较结果。

def compare_faces(known_face_encoding, unknown_face_encoding, tolerance=0.5):
    # 比较两个人脸编码是否相似
    results = face_recognition.compare_faces([known_face_encoding], unknown_face_encoding, tolerance=tolerance)
    return results[0]

在人脸比较函数 compare_faces 中使用的容差值(tolerance)是一个重要的参数,它决定了两个人脸编码需要多么相似才能被认为是匹配的。这个值的范围通常在0到1之间,其中0表示完全相同的编码(这在实际中几乎不可能,因为即使是同一个人的两张不同照片也会有所不同),而1表示完全不同的编码。

容差值的大小对比较结果有以下影响:

  1. 较小的容差值

    • 当容差值设置得较小(例如0.2或0.3)时,只有当两个人脸编码非常相似时,函数才会返回匹配的结果。
    • 这会减少误匹配(false positives)的几率,即错误地将不同的人脸识别为同一个人。
    • 但同时,这也可能会增加漏匹配(false negatives)的几率,即错误地将同一个人的人脸识别为不同的人。
  2. 较大的容差值

    • 当容差值设置得较大(例如0.6或0.7)时,两个人脸编码之间的差异可以更大,函数仍然可能返回匹配的结果。
    • 这会增加误匹配的几率,但会减少漏匹配的几率,使得系统更加倾向于将相似的人脸识别为同一个人。
  3. 最佳容差值

    • 最佳的容差值取决于具体的应用场景和需求。在一些对安全性要求较高的场景中,可能需要设置一个较小的容差值,以减少误匹配的风险。
    • 在其他一些场景中,如果用户体验更为重要,可能需要设置一个较大的容差值,以避免漏匹配,提高识别的便利性。
  4. 实验和调整

    • 在实际应用中,可能需要通过实验来确定最佳的容差值。这通常涉及到在一组已知的人脸数据上测试不同的容差值,并观察误匹配和漏匹配的发生率。
    • 可以通过调整容差值并观察识别准确率的变化来找到最佳的平衡点。

总之,容差值是一个调整识别系统敏感度的工具,它需要根据具体的应用需求和场景来设定。在实际应用中,可能需要多次实验和调整来找到最佳的容差值。

4. 显示结果

plot_faces函数用于显示两张人脸图像,并根据比较结果设置标题。

def plot_faces(known_image, unknown_image, match):
    fig, axes = plt.subplots(1, 2, figsize=(12, 6))
    axes[0].imshow(cv2.cvtColor(known_image, cv2.COLOR_BGR2RGB))
    axes[0].set_title("Known Face")
    axes[1].imshow(cv2.cvtColor(unknown_image, cv2.COLOR_BGR2RGB))
    axes[1].set_title("Unknown Face")

    # 显示匹配结果
    if match:
        plt.suptitle("Faces Match")
    else:
        plt.suptitle("Faces Do Not Match")
    plt.show()

5. 主函数

最后,main函数将上述步骤整合在一起,加载两张人脸图像,提取编码,并比较它们是否匹配。

def main():
    try:
        known_image_path = "D:\\DATAX\\pythonProject9\\known.jpg"
        unknown_image_path = "D:\\DATAX\\pythonProject9\\unknown2.jpg"

        known_face_encoding, known_image = load_and_encode_face(known_image_path)
        unknown_face_encoding, unknown_image = load_and_encode_face(unknown_image_path)

        match = compare_faces(known_face_encoding, unknown_face_encoding)
        print(f"Do the faces match? {match}")

        plot_faces(known_image, unknown_image, match)
    except ValueError as e:
        print(e)
    except Exception as e:
        print(f"An error occurred: {e}")

if __name__ == "__main__":
    main()

结论

通过这个简单的项目,我们学习了如何使用face_recognition库来加载图像、提取人脸编码,并比较两个人脸是否相似。这个库的功能非常强大,可以应用于多种场景,包括但不限于安全监控、人脸验证和社交媒体应用。

进一步阅读

  • face_recognition库文档
  • dlib库文档
  • InsightFace:一个开源的深度人脸分析库

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2255383.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

抽象工厂模式的理解和实践

在软件开发中,设计模式是解决常见问题的最佳实践。抽象工厂模式是一种创建型设计模式,提供了一种创建一系列相关或相互依赖对象的接口,而无需指定它们的具体类。本文将详细解释抽象工厂模式的概念、结构、优点、缺点,并通过Java代…

Hadoop生态圈框架部署 伪集群版(五)- HBase伪分布式部署

文章目录 前言一、Hbase伪分布式部署(手动部署)1. 下载Hbase2. 上传安装包3. 解压HBase安装包4. 配置HBase配置文件4.1 修改hbase-env.sh配置文件4.2 修改hbase-site.xml配置文件4.3 修改regionservers配置文件4.4 删除hbase中slf4j-reload4j-1.7.33.jar…

【css】基础(二)

本专栏内容为:前端专栏 记录学习前端,分为若干个子专栏,html js css vue等 💓博主csdn个人主页:小小unicorn ⏩专栏分类:css专栏 🚚代码仓库:小小unicorn的代码仓库🚚 &a…

链式设计模式

链式设计模式——装饰器模式和职责链模式 装饰模式 定义: 指在不改变现有对象结构的情况下,动态地给该对象增加一些职责(即增加其额外功能)的模式。 结构 装饰(Decorator)模式中的角色: 抽…

电子电气架构 --- E/E(电子电气架构)的重新定义

我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 所谓鸡汤,要么蛊惑你认命,要么怂恿你拼命,但都是回避问题的根源&…

app-1 App 逆向环境准备(mumu模拟器+magisk+LSPosed+算法助手+抓包(socksDroid+charles)+Frida环境搭建

一、前言 本篇是基于 mumu模拟器 进行环境配置记录。(真机的后面博客记录) 二、mumu模拟器magiskLSPosed算法助手 2.1、mumu模拟器 选择 mumu 模拟器,下载地址:https://mumu.163.com 安装完成后打开,找到设置中心进…

【服务器问题】xshell 登录远程服务器卡住( 而 vscode 直接登录不上)

打开 xshell ssh 登录远程服务器:卡在下面这里,迟迟不继续 当 SSH 连接卡在 Connection established. 之后,但没有显示远程终端提示符时,这通常意味着连接已经成功建立,说明不是网络连接和服务器连接问题,…

Python Selenium 各浏览器驱动下载与配置使用(详细流程)

1、安装 pip install selenium 2、浏览器驱动下载 Chrome(google)浏览器驱动 下载地址:http://chromedriver.storage.googleapis.com/index.html 或 https://sites.google.com/a/chromium.org/chromedriver/home . 下载地址:http://chromedriver.stor…

Redis的认识

目录 1. Redis的特性2. Redis的使用场景2.1 Redis可以做什么?2.2 Redis不可以做什么 3. Redis的安装和启动4. Redis的基本全局命令4.1 GET和SET命令4.2 KEYS指令4.3 EXISTS指令4.4 DEL指令4.5 EXPIRE指令4.6 TTL指令4.7 TYPE指令 5. 数据类型和内部编码6. 单线程架构…

IntelliJ+SpringBoot项目实战(28)--整合Beetl模板框架

在前面的文章里介绍过freemarker,thymeleaf模板引擎,本文介绍另一个性能超高的模板引擎---Beetl,据说此模板引擎的性能远超Freemarker。官网的说法是,Beetl 远超过主流java模板引擎性能(引擎性能5-6倍于FreeMarker,2倍…

全面解析DApp开发中的智能合约设计

在DApp的开发过程中,智能合约的设计起到了至关重要的作用。智能合约是运行在区块链上的程序,负责处理和执行DApp中的逻辑、交易和数据存储。下面我们将深入探讨智能合约的设计原则、挑战和优化方法,帮助开发者掌握如何设计高效、安全的智能合…

利用Grounding DINO进行自动标注——目标检测任务——YOLO格式

关于Grounding DINO的环境搭建可以参考我的以前的博客,链接如下所示 如何在Linux上离线部署Grounding DINO-CSDN博客 这个博客主要来介绍如何利用Grounding DINO这个项目去进行目标检测的自动化标注。并且给出了相关的代码已经实验验证。 1.数据集准备 2. 开始实…

1.使用docker 部署redis Cluster模式 集群3主3从

1.使用docker 部署redis Cluster模式 集群3主3从 1.1 先安装docker 启动docker服务,拉取redis镜像 3主3从我们要在docker启动6个容器docker run --name redis-node-1 --net host --privilegedtrue -v /data/redis/share/redis-node-1:/data redis:6.0.8 --cluster-…

开发类似的同款小程序系统制作流程

很多老板想要开发一款和别人家类似的同款小程序系统,但是不知道该怎么开发制作,本文就为大家详细介绍一下开发类似的同款小程序的流程为大家做参考。 一、前期准备找到对标小程序:首先,需要找到你想要模仿的同款小程序&#xff0…

Jenkins凭据管理及使用详解

简介:Jenkins凭据管理是指对Jenkins中存储的敏感信息进行管理的功能,这些信息通常用于认证和授权,以确保Jenkins能够安全地与其他系统和服务进行交互。以下是关于Jenkins凭据管理添加及作用的详细介绍: 一、Jenkins凭据管理的添加 进入凭据管理页面: 登录Jenkins后,点击…

车载VR可视化解决方案

车载VR可视化解决方案是通过融合跟踪用户头部运动的特殊预测算法与惯性测量数据而开发的。该系统将大范围虚拟现实跟踪技术与IMU传感器相结合,为VR和AR应用打造了一套全面的运动跟踪与渲染流程,极大地方便了虚拟现实头显制造商定制可视化流程。 该车载VR…

鸿蒙实现数据管理

目录: 1、鸿蒙实现数据管理的三种方式2、用户首选项3、键值型数据管理3.1、获取KVManager实例,用于管理数据库对象3.2、创建并获取键值数据库3.3、调用put()方法向键值数据库中插入数据3.4、调用get()方法获取指定键的值3.5、调用delete()方法删除指定键…

【环境搭建】WordPress本地部署搭建及历史版本插件安装(windows系统)

🏘️个人主页: 点燃银河尽头的篝火(●’◡’●) 如果文章有帮到你的话记得点赞👍收藏💗支持一下哦 【环境搭建】WordPress本地部署搭建及历史版本插件安装(windows系统) WordPress搭建环境部署(…

【教程】创建NVIDIA Docker共享使用主机的GPU

转载请注明出处:小锋学长生活大爆炸[xfxuezhagn.cn] 如果本文帮助到了你,欢迎[点赞、收藏、关注]哦~ 这套是我跑完整理的。直接上干货,复制粘贴即可! # 先安装toolkit sudo apt-get update sudo apt-get install -y ca-certifica…

突破空间限制!从2D到3D:北大等开源Lift3D,助力精准具身智能操作!

文章链接:https://arxiv.org/pdf/2411.18623 项目链接:https://lift3d-web.github.io/ 亮点直击 提出了Lift3D,通过系统地提升隐式和显式的3D机器人表示,提升2D基础模型,构建一个3D操作策略。 对于隐式3D机器人表示&a…