卷积神经网络实战人脸检测与识别

文章目录
- 前言
- 一、人脸识别一般过程
- 二、人脸检测主流算法
- 1. MTCNN
- 2. RetinaFace
- 3. CenterFace
- 4. BlazeFace
- 5. YOLO
- 6. SSD
- 7. CascadeCNN
- 三、人脸识别主流算法
- 1.deepface
- 2.FaceNet
- 3.ArcFace
- 4.VGGFace
- 5.DeepID
- 四、人脸识别系统实现
- 0.安装教程与资源说明
- 1. 界面采用PyQt5框架
- 2.人脸定位
- 3. 人脸注册
- 4.人脸删除
- 5.单人脸匹配识别
- 6.多人脸匹配识别
- 7.未注册人脸匹配识别
- 8.代码实现
- 五、总结
- 结束语
深度学习实战人脸检测与识别
前言
人脸识别技术的研究意义是多方面的,它涉及到社会生活的各个领域,并为社会发展和人民生活带来便利和安全。以下是人脸识别研究的几个主要意义:
-
安全领域:人脸识别技术可以应用于门禁系统、监控系统等,实现人员身份的快速识别和记录,提高安全性。
-
社会管理:在公安、边检、人口普查等社会管理领域,人脸识别技术可以进行人员身份的准确核验,确保社会管理工作的效率和准确性。
-
商业领域:在金融、零售、旅游等行业,人脸识别技术可以实现快速的身份识别和安全支付,提高用户体验。
-
医疗领域:在医院门诊、护理等医疗领域,人脸识别技术可以快速识别患者身份,提高医疗服务的质量和效率。
-
技术创新:人脸识别技术的发展推动了计算机视觉和人工智能领域的技术进步,尤其是在深度学习的应用上,人脸识别技术取得了显著的成就。
-
跨领域应用:人脸识别技术与其他技术领域如物联网、移动计算等的融合,创造出新的应用场景和业务模式。
综上所述,人脸识别技术的研究意义不仅在于技术层面的创新,也包括对社会、法律和伦理方面问题的深入思考,以实现技术的健康发展和应用。
一、人脸识别一般过程
人脸识别的一般过程可以分为以下几个步骤:
-
人脸检测:
- 图像采集:首先需要获取图像数据,这可以是静态图像或视频流。
- 人脸定位:在图像中定位人脸的位置,这通常通过人脸检测算法实现,如Haar特征、HOG+SVM、MTCNN等。
-
预处理:
- 图像预处理:包括灰度化、直方图均衡化、噪声去除等,以提高后续处理的准确性。
- 人脸对齐:将检测到的人脸调整到标准位置和大小,通常涉及到旋转、缩放和裁剪等操作。
-
特征提取:
- 特征表示:从预处理后的人脸图像中提取特征,这些特征可以是几何特征、纹理特征或基于深度学习的特征。
- 特征选择:选择最有代表性的特征用于识别,以减少计算量并提高识别率。
-
特征匹配:
- 特征编码:将提取的特征转换为一种可以比较的形式,如特征向量。
- 相似度计算:计算待识别人脸的特征向量与数据库中已知人脸的特征向量的相似度。
-
分类决策:
- 分类器训练:使用已知的人脸数据训练分类器,如支持向量机(SVM)、神经网络、决策树等。
- 分类预测:将待识别人脸的特征向量输入分类器,得到识别结果。
-
结果输出:
- 输出识别结果:将识别结果输出给用户,可以是人脸的身份信息、相似度分数等。
- 反馈学习:根据识别结果的准确性,对模型进行调整和优化。
-
活体检测:
- 防止欺骗:为了提高安全性,人脸识别系统通常会加入活体检测步骤,以区分真实人脸和照片、视频等伪造人脸。
二、人脸检测主流算法
1. MTCNN
MTCNN (Multi-task Cascaded Convolutional Networks)是由中国科学院提出的一种多任务级联卷积神经网络,它可以同时进行人脸检测、关键点定位和姿态估计等任务,具有精度高、速度快、能够处理多个尺度的人脸等优点。
具体说明与代码实现可参考博主写的教程MTCNN人脸检测算法实现(python)
2. RetinaFace
RetinaFace 是由中国香港城市大学提出的一种准确率更高的人脸检测与关键点定位算法,其使用了可变形卷积网络(Deformable Convolutional Network)来实现更加准确的定位,RetinaFace 特别适用于小尺度人脸的定位。
3. CenterFace
CenterFace 是由华为提出的一种轻量级人脸检测与关键点定位算法,该算法只需要 1.5MB 的模型大小,可以在移动端实时运行,CenterFace 采用了 Hourglass 模型和特征金字塔网络(Feature Pyramid Network)来实现高精度的人脸定位。
4. BlazeFace
BlazeFace 是由 Google 提出的一种极其轻量级的人脸检测算法,它的模型大小只有 2MB 左右,可以在移动端实时运行,BlazeFace 采用了创新的 anchor-free 检测方式,可以实现更快速度的人脸定位。
5. YOLO
YOLO 是一种端到端的实时目标检测算法,可以同时对多个目标进行检测和定位。由于 YOLO 可以将整张图像划分为网格,并在每个网格上预测目标的类别和边界框,因此它通常比其他基于区域的目标检测算法更快。
6. SSD
SSD 是一种基于卷积神经网络的单步目标检测算法,可以在一次前向传播中完成对多个目标的检测,相对于 Faster R-CNN 等基于区域的检测算法,SSD 更加简单与高效。
7. CascadeCNN
CascadeCNN 是由微软亚洲研究院提出的级联卷积神经网络,能够在不牺牲性能的情况下大幅减小网络规模和计算量。CascadeCNN 的结构是由多个级联阶段组成,每个阶段包含多个级联卷积层和池化层,可以有效地提高人脸定位的精确度和稳定性。
三、人脸识别主流算法
深度学习在人脸识别领域的主流算法主要包括以下几种:
1.deepface
DeepFace:由Facebook开发,使用深度神经网络来识别人脸,达到了接近人类水平的识别准确率。
2.FaceNet
FaceNet:由Google开发,使用三元组损失函数(triplet loss)将人脸映射到欧几里得空间中,使得相似的人脸在空间中的距离更近。
3.ArcFace
ArcFace:在之前模型的基础上引入了角度边际损失(angular margin loss),使得学习到的特征更具区分性。
4.VGGFace
VGGFace:这是一个深度网络,使用大型数据集进行训练,以提供高精度的人脸识别任务。
5.DeepID
DeepID系列:一系列深度学习模型,用于人脸识别任务,以逐步提高识别性能而闻名。
这些算法在设计、训练/测试数据集、应用场景以及评估协议等方面都取得了显著的进展,并且它们在处理RGB-D、视频和异构人脸数据方面也表现出色。这些主流算法的发展,极大地推动了人脸识别技术的进步,并在多个方面重塑了人脸识别的研究格局。
四、人脸识别系统实现
0.安装教程与资源说明
离线安装配置文件说明


1. 界面采用PyQt5框架

2.人脸定位

3. 人脸注册

4.人脸删除

5.单人脸匹配识别

6.多人脸匹配识别

7.未注册人脸匹配识别

8.代码实现
class QThreadFaceModel(QThread):cnn_predict_finish_sig = pyqtSignal(object)face_recog_record_insert_sig = pyqtSignal(list)face_recog_warning_sig = pyqtSignal(str)def __init__(self):super(QThreadFaceModel, self).__init__()self.run_flag = Falseself.mode = 0self.last_pid_list = []self.cap = cv2.VideoCapture(0)def __del__(self):print('__del__')self.cap.release()def set_run_flag(self, flag):self.run_flag = flagdef set_face_model(self, model):self.face_model = modeldef set_model(self, mode):self.mode = modedef set_face_features(self, face_features):self.face_features = face_featuresdef set_face_names(self, face_name_dict):self.face_name_dict = face_name_dictdef query_face_id(self, query_feature, sim_thresh=0.65):id ='unknown'for key in self.face_features:face_sim = self.face_model.CalculateSimilarity(query_feature, self.face_features[key])# print(face_sim)if face_sim >= sim_thresh:id = keybreakreturn iddef run(self):"""线程启动后执行的函数入口,采用run_flag控制流程的运行状态"""while True:if self.run_flag:ok, frame = self.cap.read() # 读取一帧数据# print(frame.shape)if not ok:self.cap = cv2.VideoCapture(0)continuetry:detect_result = self.face_model.Detect(frame)# print(detect_result)for i in range(detect_result.size):face = detect_result.data[i].posif self.mode == 1:face_points = self.face_model.mark5(frame, face)face_crop_image = self.face_model.CropFace(frame, face_points)face_crop_image_feature = self.face_model.ExtractCroppedFace(face_crop_image)face_id = self.query_face_id(face_crop_image_feature)if face_id == 'unknown':cv2.rectangle(frame, (face.x, face.y), (face.x + face.width, face.y + face.height),(0, 0, 255), 2)frame = cv2ImgAddText(frame, self.face_name_dict[face_id], face.x - 30, face.y -30,textColor=(255, 0, 0), textSize=30)else:cv2.rectangle(frame, (face.x, face.y), (face.x + face.width, face.y + face.height),(255, 0, 0), 2)frame = cv2ImgAddText(frame, self.face_name_dict[face_id], face.x - 30, face.y - 30,textColor=(0, 255, 0), textSize=30)elif self.mode == 0:cv2.rectangle(frame, (face.x, face.y), (face.x + face.width, face.y + face.height),(255, 0, 0), 2)# cv2.putText(frame, f"pid:{PID}", (face.x, face.y), 0, 1, (0, 255, 0))self.cnn_predict_finish_sig.emit(frame)except Exception as e:self.cap = cv2.VideoCapture(0)print(e)
五、总结
深度学习人脸定位算法已经取得了非常显著的进展,已经被广泛应用于人脸识别、人脸表情分析、虚拟换脸等应用场景中,这些算法在不断地优化和改进中,未来还有很大的发展空间。
结束语
由于博主能力有限,本篇文章中提及的方法,也难免会有疏漏之处,希望您能热心指出其中的错误,以便下次修改时能以一个更完美更严谨的样子,呈现在大家面前。
相关文章:
卷积神经网络实战人脸检测与识别
文章目录 前言一、人脸识别一般过程二、人脸检测主流算法1. MTCNN2. RetinaFace3. CenterFace4. BlazeFace5. YOLO6. SSD7. CascadeCNN 三、人脸识别主流算法1.deepface2.FaceNet3.ArcFace4.VGGFace5.DeepID 四、人脸识别系统实现0.安装教程与资源说明1. 界面采用PyQt5框架2.人…...
【面试题系列】Java 多线程面试题深度解析
本文涉及Java 多线程面试题,从基础到高级,希望对你有所帮助! 一、基础概念类 1. 请简述 Java 中线程的几种状态及其转换条件 题目分析:这是多线程基础中的基础,考查对线程生命周期的理解,在多线程编程中&…...
【C语言】左旋字符串(三种实现方式)
题目: 实现一个函数,可以左旋字符串中的k个字符。 例如: ABCD左旋一个字符得到BCDA ABCD左旋两个字符得到CDAB 方法一: 我们画个图分析一下: 基本逻辑: 就是我们每一次旋转之前,我们就取出…...
数论补充 之 前后缀分解问题
文章目录 [0,i-1] 和 [i1,n-1] 共同作用3334,数组的最大因子得分 对于前缀分解问题,我愿把它分为几个大问题:[0,i] 或 [i,n-1] 或 [l,r],或 [0,i-1] 和 [i1,n-1] 共同作用的问题 [0,i-1] 和 [i1,n-1] 共同作用 3334,数组的最大因子得分 3334,数组的最大…...
IoTDB 集群节点 IP 改变,如何更新集群
问题 问题1:如果 IoTDB 配置的时候用的 IP,没有用 hostname,后面 IP 修改了,历史数据需要重新导吗? 问题2:如果现场运行 IoTDB 半年,电脑 IP 要改的话,半年的数据要导出来再导入么…...
【AI系列】从零开始学习大模型GPT (2)- Build a Large Language Model (From Scratch)
前序文章 【AI系列】从零开始学习大模型GPT (1)- Build a Large Language Model (From Scratch) Build a Large Language Model 背景第1章:理解大型语言模型第2章:处理文本数据第3章:编码Attention机制什么是Attention机制?Attention机制的基本原理数学表示应用总结为什么要…...
webshell通信流量分析
环境安装 Apatche2 php sudo apt install apache2 -y sudo apt install php libapache2-mod-php php-mysql -y echo "<?php phpinfo(); ?>" | sudo tee /var/www/html/info.php sudo ufw allow Apache Full 如果成功访问info.php,则环境安…...
数据可视化+SpringBoot+协同过滤推荐算法的美食点餐管理平台
感兴趣的可以先收藏起来,还有大家在毕设选题,项目以及论文编写等相关问题都可以给我留言咨询,我会一一回复的,希望帮助到更多的人。 背景分析 在当今数字化浪潮席卷全球的时代,餐饮行业也正经历着深刻的变革…...
DeepSeek 关联 Word 使用教程:解锁办公新效率
在当今数字化办公时代,将强大的人工智能模型与常用办公软件相结合,能显著提升工作效率。DeepSeek 作为一款先进的人工智能工具,若能与广泛使用的办公软件 Word 实现关联,可在文档撰写、编辑、内容优化等诸多方面为用户带来极大便利…...
[极客大挑战 2019]Havefun1
[极客大挑战 2019]Havefun1 代码审计发现 根据代码逻辑,要求传入’cat’参数,值为’dog’时执行if的操作,所以构造参数: ?catdog获得flag...
基于Swift实现仿IOS闹钟
仿 iOS 系统闹钟 添加闹钟效果图 收到通知效果图 更新日志 2018.09.12 由于 iOS 系统限制了注册本地推送的数量,最大的注册量为 64 条,且一旦超出 64 条,所有的推送都将失效,故而在添加推送的时候做了一个判断,超过…...
Threadlocal的实现原理
文章目录 ThreadLocal与Thread关系分析Threadlocal 不支持继承性lnheritableThreadLocal 类 ThreadLocal与Thread关系分析 由该图可知, Thread 类中有一个 threadLocals 和一个 inheritableThreadLocals , 它们 都是 ThreadLocalMap 类型 的变量 &#x…...
线程池处理异常
线程池在提交的任务在处理过程中发生了异常,却没有捕获到,导致异常只是输出在控制台,这通常需要把异常记录下来1、通过观察ThreadGroup的构造方法知道,当调用线程组的构造方法时,会获取当前线程所属的线程组࿰…...
RabbitMQ配置SSL证书
配置阿里云服务器RabbitMQ-SSL证书【windows】 文章目录 配置阿里云服务器RabbitMQ-SSL证书【windows】1. 证书下载2. 系统中添加证书(不知道是不是必要的)3. OpenSSL下载4. ca、server证书及私钥提取5. RabbitMQ-SSL证书配置6. 参考博客 1. 证书下载 进…...
.NET 9.0 的 Blazor Web App 项目,进度条 <progress> 组件使用注意事项
一、执行过程中,要刷新 进度条 的显示,需要 延时、释放,否则进度条不 实时 更新,最后一下到 100% // 延时,释放给前端:【必须】,否则进度条不 实时 更新,最后一下到 100await Task.D…...
第J7周:对于ResNeXt-50算法的思考
目录 FROM思考 FROM 🍨 本文为🔗365天深度学习训练营 中的学习记录博客🍖 原作者:K同学啊 📌你需要解决的疑问:这个代码是否有错?对错与否都请给出你的思考 📌打卡要求:…...
【第2章:神经网络基础与实现——2.3 多层感知机(MLP)的构建与调优技巧】
在当今科技飞速发展的时代,人工智能早已不是一个陌生的词汇,它已经渗透到我们生活的方方面面,从智能语音助手到自动驾驶汽车,从图像识别到自然语言处理。而支撑这一切的核心技术之一,就是神经网络。作为机器学习领域的璀璨明星,神经网络已经在众多任务中取得了令人瞩目的…...
【Elasticsearch】keyword分析器
Elasticsearch 中的keyword分析器是一种非常特殊的分析器,它的行为与其他常见的分析器(如standard、whitespace等)截然不同。keyword分析器的核心功能是将整个输入字符串作为一个单一的标记(token)返回,而不…...
重生之我在异世界学编程之C语言:深入预处理篇(上)目录)
大家好,这里是小编的博客频道 小编的博客:就爱学编程 很高兴在CSDN这个大家庭与大家相识,希望能在这里与大家共同进步,共同收获更好的自己!!! 本文目录 引言正文一、预处理的作用与流程…...
MySQL数据库误删恢复_mysql 数据 误删
2、BigLog日志相关 2.1、检查biglog状态是否开启 声明: 当前为mysql版本5.7 当前为mysql版本5.7****当前为mysql版本5.7 2.1.1、Navicat工具执行 SHOW VARIABLES LIKE LOG_BIN%;OFF 是未开启状态,如果不是ON 开启状态需要开启为ON。{默认情况下就是关闭状态} 2.…...
【人工智能】神经网络的优化器optimizer(二):Adagrad自适应学习率优化器
一.自适应梯度算法Adagrad概述 Adagrad(Adaptive Gradient Algorithm)是一种自适应学习率的优化算法,由Duchi等人在2011年提出。其核心思想是针对不同参数自动调整学习率,适合处理稀疏数据和不同参数梯度差异较大的场景。Adagrad通…...
Vue3 + Element Plus + TypeScript中el-transfer穿梭框组件使用详解及示例
使用详解 Element Plus 的 el-transfer 组件是一个强大的穿梭框组件,常用于在两个集合之间进行数据转移,如权限分配、数据选择等场景。下面我将详细介绍其用法并提供一个完整示例。 核心特性与用法 基本属性 v-model:绑定右侧列表的值&…...
iPhone密码忘记了办?iPhoneUnlocker,iPhone解锁工具Aiseesoft iPhone Unlocker 高级注册版分享
平时用 iPhone 的时候,难免会碰到解锁的麻烦事。比如密码忘了、人脸识别 / 指纹识别突然不灵,或者买了二手 iPhone 却被原来的 iCloud 账号锁住,这时候就需要靠谱的解锁工具来帮忙了。Aiseesoft iPhone Unlocker 就是专门解决这些问题的软件&…...
聊聊 Pulsar:Producer 源码解析
一、前言 Apache Pulsar 是一个企业级的开源分布式消息传递平台,以其高性能、可扩展性和存储计算分离架构在消息队列和流处理领域独树一帜。在 Pulsar 的核心架构中,Producer(生产者) 是连接客户端应用与消息队列的第一步。生产者…...
智能在线客服平台:数字化时代企业连接用户的 AI 中枢
随着互联网技术的飞速发展,消费者期望能够随时随地与企业进行交流。在线客服平台作为连接企业与客户的重要桥梁,不仅优化了客户体验,还提升了企业的服务效率和市场竞争力。本文将探讨在线客服平台的重要性、技术进展、实际应用,并…...
P3 QT项目----记事本(3.8)
3.8 记事本项目总结 项目源码 1.main.cpp #include "widget.h" #include <QApplication> int main(int argc, char *argv[]) {QApplication a(argc, argv);Widget w;w.show();return a.exec(); } 2.widget.cpp #include "widget.h" #include &q…...
SpringBoot+uniapp 的 Champion 俱乐部微信小程序设计与实现,论文初版实现
摘要 本论文旨在设计并实现基于 SpringBoot 和 uniapp 的 Champion 俱乐部微信小程序,以满足俱乐部线上活动推广、会员管理、社交互动等需求。通过 SpringBoot 搭建后端服务,提供稳定高效的数据处理与业务逻辑支持;利用 uniapp 实现跨平台前…...
OpenLayers 分屏对比(地图联动)
注:当前使用的是 ol 5.3.0 版本,天地图使用的key请到天地图官网申请,并替换为自己的key 地图分屏对比在WebGIS开发中是很常见的功能,和卷帘图层不一样的是,分屏对比是在各个地图中添加相同或者不同的图层进行对比查看。…...
Linux离线(zip方式)安装docker
目录 基础信息操作系统信息docker信息 安装实例安装步骤示例 遇到的问题问题1:修改默认工作路径启动失败问题2 找不到对应组 基础信息 操作系统信息 OS版本:CentOS 7 64位 内核版本:3.10.0 相关命令: uname -rcat /etc/os-rele…...
【学习笔记】erase 删除顺序迭代器后迭代器失效的解决方案
目录 使用 erase 返回值继续迭代使用索引进行遍历 我们知道类似 vector 的顺序迭代器被删除后,迭代器会失效,因为顺序迭代器在内存中是连续存储的,元素删除后,后续元素会前移。 但一些场景中,我们又需要在执行删除操作…...
