基于OpenCV的人脸识别系统

2023-11-17

人脸识别技术是计算机视觉领域的重要应用之一,它可以通过对人脸图像的分析和比较,实现对不同人的身份的自动识别。在本文中,我们将使用OpenCV这一流行的计算机视觉库,介绍一个简单的人脸识别系统,并且逐步深入到算法的具体实现方式。

1. 安装与配置OpenCV

首先,我们需要安装OpenCV库,并进行相关的配置工作。这里我们以Python为例,介绍OpenCV的安装和配置方法。

安装OpenCV

我们可以使用pip命令来安装OpenCV库:

pip install opencv-python

配置OpenCV

在编写程序时,我们需要使用OpenCV库提供的函数和类来实现人脸识别的功能。因此,在开始编程之前,我们需要先导入OpenCV库并配置相关环境。

import cv2

# 读取图片
img = cv2.imread("test.jpg")

# 显示图片
cv2.imshow("Image", img)
cv2.waitKey(0)
cv2.destroyAllWindows()

在上面的代码中,我们首先导入了OpenCV库,并使用cv2.imread函数读取了一张名为“test.jpg”的图片文件。然后,使用cv2.imshow函数显示该图片,并使用cv2.waitKey()等函数进行其他的配置和操作。

2. 检测人脸

在实现人脸识别功能之前,我们需要先检测出图片中的人脸。这里我们将介绍使用OpenCV库实现人脸检测的方法。

import cv2

# 加载人脸检测器
face_cascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')

# 读取图片并进行灰度化处理
img = cv2.imread('test.jpg')
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)

# 检测人脸
faces = face_cascade.detectMultiScale(gray, scaleFactor=1.3, minNeighbors=5)

# 标记人脸位置
for (x,y,w,h) in faces:
    cv2.rectangle(img, (x,y), (x+w,y+h), (0,255,0), 2)

# 显示结果图片
cv2.imshow('image', img)
cv2.waitKey(0)
cv2.destroyAllWindows()

在上面的代码中,我们首先加载了一个名为“haarcascade_frontalface_default.xml”的人脸检测器,并使用cv2.CascadeClassifier函数创建了一个名为face_cascade的对象。然后,读取了一张名为“test.jpg”的图片文件,并使用cv2.cvtColor函数将其转换为灰度图像。接着,使用face_cascade.detectMultiScale函数检测图片中的人脸,返回人脸所在矩形区域的坐标和宽高信息,并用绿色的矩形框标记出来。最后,使用cv2.imshow函数显示处理后的图片,并使用cv2.waitKey()等函数进行其他的配置和操作。

3. 训练模型

在实现人脸识别功能之前,我们需要先训练一个模型来对人脸进行分类和识别。这里我们将介绍使用OpenCV库实现训练模型的方法。

import cv2
import os

# 加载人脸检测器
face_cascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')

# 遍历训练数据集中的所有图片
training_data = []
for root, dirs, files in os.walk("training_data"):
    for file in files:
        if file.endswith(".jpg"):
            # 读取图片并进行灰度化处理
            img_path = os.path.join(root, file)
            img = cv2.imread(img_path)
            gray= cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
            # 检测人脸
            faces = face_cascade.detectMultiScale(gray, scaleFactor=1.3, minNeighbors=5)

            # 将图片和标签添加到训练数据集中
            for (x, y, w, h) in faces:
                face_img = gray[y:y+h, x:x+w]
                training_data.append((face_img, label))

训练模型

face_recognizer = cv2.face.LBPHFaceRecognizer_create()
faces, labels = [], []
for data in training_data:
    faces.append(data[0])
    labels.append(data[1])
face_recognizer.train(faces, np.array(labels))

# 保存模型
face_recognizer.write('face_model.xml')

在上面的代码中,我们首先加载了一个名为“haarcascade_frontalface_default.xml”的人脸检测器,并创建一个空的训练数据集 training_data。然后,使用 os.walk 函数遍历了一个名为“training_data”的文件夹中所有的jpg图片,并使用上一节中介绍的方法将其转换为灰度图像,检测并标记出其中的人脸,并将它们加入到训练数据集中。

接着,我们使用 cv2.face.LBPHFaceRecognizer_create函数创建了一个基于LBPH算法的人脸识别器对象 face_recognizer,并使用训练数据集 training_data 对其进行训练。最后,使用 face_recognizer.write 函数将训练好的模型保存到一个名为 “face_model.xml”的文件中。

进行人脸识别

import cv2

# 加载人脸检测器和人脸识别器
face_cascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')
face_recognizer = cv2.face.LBPHFaceRecognizer_create()
face_recognizer.read('face_model.xml')

# 读取测试图片并进行灰度化处理
img = cv2.imread('test.jpg')
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)

# 检测人脸
faces = face_cascade.detectMultiScale(gray, scaleFactor=1.3, minNeighbors=5)

# 遍历检测到的人脸
for (x, y, w, h) in faces:
    # 提取人脸图像并进行识别
    face_img = gray[y:y+h, x:x+w]
    label, confidence = face_recognizer.predict(face_img)

    # 标记人脸位置和身份信息
    name = "Unknown"
    if confidence < 50:
        name = "person_" + str(label)
    cv2.rectangle(img, (x, y), (x+w, y+h), (0, 255, 0), 2)
    cv2.putText(img, name, (x, y-10), cv2.FONT_HERSHEY_SIMPLEX, 0.9, (0, 255, 0), 2)

# 显示处理后的图片
cv2.imshow('image', img)
cv2.waitKey(0)
cv2.destroyAllWindows()

在上面的代码中,我们首先加载了一个名为 “haarcascade_frontalface_default.xml”的人脸检测器和训练好的人脸识别器对象 face_recognizer,并使用 cv2.face.LBPHFaceRecognizer_create 函数从名为 “face_model.xml” 的文件中读取已经训练好的模型。

然后,读取一张名为 “test.jpg” 的测试图片,并使用 cv2.cvtColor 函数将其转换为灰度图像。接着,使用 face_cascade.detectMultiScale 函数检测图片中的人脸,并遍历检测到的每一个人脸。对于每个人脸图像,使用 face_recognizer.predict 函数进行分类和识别,并根据分类结果标记出人脸位置和身份信息。最后,使用 cv2.imshow 函数显示处理后的图片。

4. 进行人脸识别

在训练好模型之后,我们就可以使用它来进行人脸识别了。这里我们将介绍使用 OpenCV 库实现人脸识别的方法。

import cv2

# 加载人脸检测器和人脸识别器
face_cascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')
face_recognizer = cv2.face.LBPHFaceRecognizer_create()
face_recognizer.read('face_model.xml')

# 读取测试图片并进行灰度化处理
img = cv2.imread('test.jpg')
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)

# 检测人脸
faces = face_cascade.detectMultiScale(gray, scaleFactor=1.3, minNeighbors=5)

# 遍历检测到的人脸
for (x, y, w, h) in faces:
    # 提取人脸图像并进行识别
    face_img = gray[y:y+h, x:x+w]
    label, confidence = face_recognizer.predict(face_img)

    # 标记人脸位置和身份信息
    name = "Unknown"
    if confidence < 50:
        name = "person_" + str(label)
    cv2.rectangle(img, (x, y), (x+w, y+h), (0, 255, 0), 2)
    cv2.putText(img, name, (x, y-10), cv2.FONT_HERSHEY_SIMPLEX, 0.9, (0, 255, 0), 2)

# 显示处理后的图片
cv2.imshow('image', img)
cv2.waitKey(0)
cv2.destroyAllWindows()

在上面的代码中,我们首先加载了一个名为 “haarcascade_frontalface_default.xml”的人脸检测器和训练好的人脸识别器对象 face_recognizer,并使用 cv2.face.LBPHFaceRecognizer_create 函数从名为 “face_model.xml” 的文件中读取已经训练好的模型。

然后,使用 cv2.imread 函数读取一张名为 “test.jpg” 的测试图片,并使用 cv2.cvtColor 函数将其转换为灰度图像。接着,使用 face_cascade.detectMultiScale 函数检测灰度图像中的人脸,并遍历检测到的每一个人脸。对于每个人脸图像,使用 face_recognizer.predict 函数进行分类和识别,并根据分类结果标记出人脸位置和身份信息。如果识别的置信度 confidence 小于 50 ,则将这个人脸的身份设置为 "person_" 加上其对应的标签值 label,否则将身份设置为 "Unknown"。最后,使用 cv2.imshow 函数显示处理后的图片。

其中,函数 cv2.rectangle 用于在图像上画矩形,它需要四个参数:起始坐标 (x, y) 和结束坐标 (x+w, y+h),以及颜色和线宽。函数 cv2.putText 用于在图像上写文字,它需要七个参数:要写的文本、起始坐标、字体类型、字体大小、颜色和线宽。

总之,以上代码实现了一个基于 LBPH 算法的人脸识别系统,可以对输入的图片进行人脸检测和身份识别,并在图像上进行标记和显示。

本文介绍了如何使用 OpenCV 库实现基于 LBPH 算法的人脸识别系统,包括数据采集、模型训练和人脸识别三个部分。

在数据采集阶段,我们需要先收集一些人脸图像作为训练数据,并对这些图片进行预处理和特征提取,最后将它们保存到一个训练数据集中。

在模型训练阶段,我们需要使用已经准备好的训练数据集来训练一个基于 LBPH 算法的人脸识别器,并将训练好的模型保存到一个文件中以备后续使用。

在人脸识别阶段,我们需要使用训练好的模型对输入的图片进行人脸检测和身份识别,并在图像上进行标记和显示,从而实现一个完整的人脸识别系统。

总之,本文介绍的基于 LBPH 算法的人脸识别系统是一个简单而有效的方法,可以应用于多种场景和应用中。同时,由于 OpenCV 库是免费且开源的,因此它也是一个非常受欢迎和实用的工具库。

最后,记得点个关注哟!

依旧是你们的萧萧吖!!!

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

基于OpenCV的人脸识别系统 的相关文章

  • 如何以“正确”的方式处理带有空字节的 Python unicode 字符串?

    Question PyWin32 似乎很乐意将 null 终止的 unicode 字符串作为返回值 我想以 正确 的方式处理这些字符串 假设我得到一个像这样的字符串 u C Users Guest MyFile asy x00 x00sy
  • 如何检查python xlrd库中的excel文件是否有效

    有什么办法与xlrd库来检查您使用的文件是否是有效的 Excel 文件 我知道还有其他库可以检查文件头 我可以使用文件扩展名检查 但为了多平台性我想知道是否有任何我可以使用的功能xlrd库本身在尝试打开文件时可能会返回类似 false 的内
  • Python - 来自 .进口

    我第一次尝试图书馆 我注意到解决图书馆内导入问题的最简单方法是使用如下结构 from import x from some module import y 我觉得这件事有些 糟糕 也许只是因为我不记得经常看到它 尽管公平地说我还没有深入研究
  • Python 2.7 中的断言对我来说不起作用示例assertIn

    我的 Mac 上安装了 python 2 7 通过在终端中运行 python v 进行验证 当我尝试使用任何新的 2 7 断言方法时 我收到 AtributeError 我看过http docs python org 2 library u
  • 如何在 Python 中加密并在 Java 中解密?

    我正在尝试在 Python 程序中加密一些数据并将其保存 然后在 Java 程序中解密该数据 在Python中 我像这样加密它 from Crypto Cipher import AES KEY 1234567890123456789012
  • 如何使用文本相似性删除 pandas 数据框中相似(不重复)的行?

    我有数千个数据 这些数据可能相似也可能不相似 使用 python 的默认函数 drop duplicates 并没有真正的帮助 因为它们只检测相似的数据 例如 如果我的数据包含类似以下内容怎么办 嗨 早上好 嗨 早上好 Python 不会将
  • 将 OpenCV Mat 转换为数组(可能是 NSArray)

    我的 C C 技能很生疏 OpenCV 的文档也相当晦涩难懂 有没有办法获得cv Mat data属性转换为数组 NSArray 我想将其序列化为 JSON 我知道我可以使用 FileStorage 实用程序转换为 YAML XML 但这不
  • 从扫描文档中提取行表 opencv python

    我想从扫描的表中提取信息并将其存储为 csv 现在我的表提取算法执行以下步骤 应用倾斜校正 应用高斯滤波器进行去噪 使用 Otsu 阈值进行二值化 进行形态学开局 Canny 边缘检测 进行霍夫变换以获得表格行 去除重复行 10像素范围内相
  • Geodjango距离查询未检索到正确的结果

    我正在尝试根据地理位置的接近程度来检索一些帖子 正如您在代码中看到的 我正在使用 GeoDjango 并且代码在视图中执行 问题是距离过滤器似乎被完全忽略了 当我检查查询集上的距离时 我得到了预期距离 1m 和 18km 但 18km 的帖
  • 通过索引访问Python字典的元素

    考虑一个像这样的字典 mydict Apple American 16 Mexican 10 Chinese 5 Grapes Arabian 25 Indian 20 例如 我如何访问该字典的特定元素 例如 我想在对 Apple 的第一个
  • 在 keras 中保存和加载权重

    我试图从我训练过的模型中保存和加载权重 我用来保存模型的代码是 TensorBoard log dir output model fit generator image a b gen batch size steps per epoch
  • Mac OSX 10.6 上的 Python mysqldb 不工作

    我正在使用 Python 2 7 并尝试让 Django 项目在 MySQL 后端运行 我已经下载了 mysqldb 并按照此处的指南进行操作 http cd34 com blog programming python mysql pyth
  • Anaconda 无法导入 ssl 但 Python 可以

    Anaconda 3 Jupyter笔记本无法导入ssl 但使用Atom终端导入ssl没有问题 我尝试在 Jupyter 笔记本中导入 ssl 但出现以下错误 C ProgramData Anaconda3 lib ssl py in
  • Elasticsearch 通过搜索返回拼音标记

    我用语音分析插件 https www elastic co guide en elasticsearch plugins current analysis phonetic html由于语音转换 从弹性搜索中进行一些字符串匹配 我的问题是
  • 如何与其他用户一起使用 pyenv?

    如何与其他用户一起使用 pyenv 例如 如果我在用户 test 的环境中安装了 pyenv 则当我以 test 身份登录时可以使用 pyenv 但是 当我以其他用户 例如 root 身份登录时如何使用 pyenv 即使你这么做了 我也会s
  • Django 与谷歌图表

    我试图让谷歌图表显示在我的页面上 但我不知道如何将值从 django 视图传递到 javascript 以便我可以绘制图表 姜戈代码 array Year Sales Expenses 2004 1000 400 2005 1170 460
  • 如何根据第一列创建新列,同时考虑Python Pandas中字母和列表的大小? [复制]

    这个问题在这里已经有答案了 我在 Python Pandas 中有 DataFrame 如下所示 col1 John Simon prd agc Ann White BeN and Ann bad list Ben Wayne 我需要这样做
  • 从 pandas DataFrame 中删除少于 K 个连续 NaN

    我正在处理时间序列数据 我在从数据帧列中删除小于或等于阈值的连续 NaN 时遇到问题 我尝试查看一些链接 例如 标识连续 NaN 出现的位置以及计数 Pandas NaN 孔的游程长度 https stackoverflow com que
  • 查找总和为给定数字的值组合的函数

    这个帖子查找提供的 Sum 值的组合 https stackoverflow com a 20194023 1561176呈现函数subsets with sum 它在数组中查找总和等于给定值的值的组合 但由于这个帖子已经有6年多了 我发这
  • 如何为不同操作系统/Python 版本编译 Python C/C++ 扩展?

    我注意到一些成熟的Python库已经为大多数架构 Win32 Win amd64 MacOS 和Python版本提供了预编译版本 针对不同环境交叉编译扩展的标准方法是什么 葡萄酒 虚拟机 众包 我们使用虚拟机和Hudson http hud

随机推荐

  • 【ES6】Set 和 Map 数据结构

    文章目录 前言 一 Set 1 用法详解 1 1 声明方式 1 2 遍历的四种方式 2 应用场景 2 1 数组去重 2 2 合并去重 2 3交集 2 4 差集 3 WeakSet 二 Map 1 用法详解 1 1 声明方式 1 2 遍历的四
  • 论文阅读 Semantic Graph Convolutional Networks for 3D Human Pose Regression

    Semantic Graph Convolutional Networks for 3D Human Pose Regression 使用语义图卷积网络对三维人体姿态进行回归 Abstract 在这篇论文中 我们研究了学习Graph Con
  • (查看,和保存)windows下通过cmd命令符窗口查看、保存文件目录结构

    背景 有时候我们查看目录结构 或者保存目录结构信息 来对项目进行说明 一 查看文件结构 1 tree 查看tree命令操作 2 tree 只展示文件夹 tree 3 tree F 文件夹文件都展示 tree F 二 保存文件结构 在上述使用
  • PHP第三课:流程判断(下)

    上期PHP 我们学会了if判断 今天我们来学switch 看下这串代码
  • java算法题两个数组合并_算法:两个有序数组合并成一个有序数组 java语言

    题目 有两个有序数组a 和b 将它们合并成数组c 需要c 也是有序数组 思路 新建一个以两个集合长度之和为长度的新数组 从两数组最左边开始比起 把小的放入新集合 并用变量标记后一位置 每次比较都是比较的最左边未比较过的元素 通过变量 循环比
  • 用python计算灰度图像中掩模的面积(以像素为单位)

    下面是一个使用OpenCV的方法 我们用Otsu的阈值来获得一个二值图像 这个图像的前景对象是白色的 背景是黑色的 从这里我们使用cv2 countNonZero 它返回掩码上的白色像素数 找到白色像素的数量 pixels cv2 coun
  • Linux中的O_RDONLY、O_WRONLY、O_RDWR、O_APPEND、O_TRUNC、O_EXCL、O_EXCL、O_SYNC、O_NONBLOCK

    2023年7月11日 周二下午 这几个常量被定义在头文件fcntl h中 fcntl 是 file control 的缩写 它是由 file 文件 和 control 控制 两个单词组合而成的 在介绍这几个常量之前 要先介绍一下open函数
  • 【CTF】初学ROP

    在CTF PWN的题型中有一种利用方式是ROP 原理学明白了 但是实操起来一直不太理解ROP链的具体构造 为了弄明白原理 就找了一道入门题目 对照着wp进行单步调试 来理解ROP链的构造 题目 buuctf PicoCTF 2018 rop
  • slice+append陷阱

    1 前言 今天在网上看slice扩容原理 偶然看到一个slice的题目 感觉很有意思 题目如下 package main import fmt func main s1 int 1 2 s2 s1 s2 append s2 3 Test1
  • 用Python生成化学结构式

    from rdkit import Chem from rdkit Chem Draw import rdMolDraw2D print 欢迎使用化学式绘制工具 while 1 绘制主链 print 示例 CCC C CC 是第三个碳原子上
  • 3. C++ 11特性 数组和结构初始化、数组、循环、作用域内枚举

    目录 1 数组初始化 2 字符串初始化 3 结构初始化 4 数组替代模板类array 5 基于范围的for循环 6 作用域内枚举 1 数组初始化 初始化数组时 可省略等号 double earnings 4 1 2e4 1 6e4 1 1e
  • SpringMVC:从入门到精通,7篇系列篇带你全面掌握--七.自定义注解

    目录 Welcome Huihui s Code World 一 Java注解简介 1 原生注解的分类 1 JDK基本注解 Override SuppressWarnings value unchecked 2 JDK元注解 Retenti
  • chatgpt赋能python:用Python计算e的方法

    用Python计算e的方法 Python是一种功能强大的编程语言 可以用它来解决许多数学问题 其中之一就是计算数学常数e e是一个无理数 约为2 71828 它在许多数学和科学领域中都有重要应用 例如微积分 概率论和物理学 什么是e e是一
  • qt无边框窗体的移动

    无边框窗体的移动 this gt setWindowFlags Qt FramelessWindowHint 设置窗体为无边框 鼠标移动窗体移动涉及到三个事件分别是 鼠标按下 鼠标移动 鼠标松开 这三个事件在Qwidget中是虚函数 在QW
  • 人工智能复习

    大纲 5个大题 知识表示 一阶谓词逻辑 产生式 框架表示法 知识推理 归结原理 搜索算法 第三 四题 宽度优先算法 深度优先算法 开放题 论述题 计算题 用归结反演求取问题的答案 已知 张 Zhang 和李 Li 是同班同学 如果x和y是同
  • 超全总线控制方式总结

    总线控制 看了网络上的文章 质量真的不太行 就自己结合着整理一下 总线控制主要是两个大方面 总线判优控制和总线通信控制 一 总线判优控制 总线上同一时刻只允许一个设备进行占用 为了防止冲突 我们引入了判优逻辑 仲裁谁可以先占用 实际上我也没
  • Java基础12--面向对象:封装

    Java基础12 面向对象 封装 在面向对象程式设计方法中 封装 英语 Encapsulation 是指一种将抽象性函式接口的实现细节部分包装 隐藏起来的方法 封装可以被认为是一个保护屏障 防止该类的代码和数据被外部类定义的代码随机访问 要
  • chatGLM介绍

    一 简述 清华大学推出的ChatGLM的第二代版本 支持中文 效果好 清华大学的ChatGLM应该是中文大语言模型中最好的 要求低 可以在消费级的显卡上运行 二 链接 工程 https github com THUDM ChatGLM2 6
  • Ajax提交form表单

    Ajax提交form表单 ajax 几个参数需要注意一下 type POST 方法类型 传递方式 dataType json 预期服务器返回的数据类型 url url 就是form里面的action 不要忘了url前面加 data form
  • 基于OpenCV的人脸识别系统

    人脸识别技术是计算机视觉领域的重要应用之一 它可以通过对人脸图像的分析和比较 实现对不同人的身份的自动识别 在本文中 我们将使用OpenCV这一流行的计算机视觉库 介绍一个简单的人脸识别系统 并且逐步深入到算法的具体实现方式 1 安装与配置