人脸采集训练识别

news2025/1/1 23:41:21

项目概述:

       本地摄像头采集人脸数据集,通过训练得到trainingData.yml模型,加载haarcascade_frontalface_default.xml实现人脸识别。haarcascade_frontalface_default.xml 文件并不是一个完整的人脸识别模型,而是一个用于检测正脸(frontal face)的 Haar 特征级联分类器文件。具体来说,这个 XML 文件包含了经过训练的级联分类器,用于在图像中快速定位和识别人脸区域。这种级联分类器主要基于 Haar 特征,通过使用一系列特征模板来区分对象。该分类器主要用于人脸检测任务,识别出输入图像中可能存在的人脸区域。

haarcascade_frontalface_default.xml文件下载地址:

opencv/data/haarcascades/haarcascade_frontalface_default.xml at master · kipr/opencv · GitHub

1、数据采集

使用在线sqlite3(SQL Online Compiler - Next gen SQL Editor)创建数据库。

 CREATE TABLE students(
   Id int,
   Name varchar(20),
   age INT
 );

 '''
 数据采集 dataset_creater.py
 '''
 ​
 import cv2
 import sqlite3
 ​
 faceDetect = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')  # 摄像头中面部识别
 cam = cv2.VideoCapture(0)  # 打开默认的第一个摄像头
 ​
 ​
 def inserttoupdate(Id, Name, age):
     conn = sqlite3.connect("sqlite.db")
     cmd = "SELECT * FROM STUDENTS WHERE ID=" + str(Id)
     cursor = conn.execute(cmd)
     isRecordExist = 0
     for row in cursor:
         isRecordExist = 1
     if isRecordExist == 1:
         conn.execute("UPDATE STUDENTS SET NAME =?,AGE=? WHERE ID=?", (Name, age, Id))
     else:
         conn.execute("INSERT INTO STUDENTS (ID,NAME,AGE) VALUES (?,?,?)", (Id, Name, age))
     conn.commit()
     conn.close()
 ​
 ​
 # 向sqlite3数据库中插入数据
 Id = input('输入用户的ID:')
 Name = input('输入用户的姓名:')
 age = input('输入用户的年龄')
 inserttoupdate(Id, Name, age)
 ​
 sampleNum = 0  # 假设数据集中没有样本
 ​
 while True:
     ret, img = cam.read()
     gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
     faces = faceDetect.detectMultiScale(gray, 1.3, 5)
     for (x, y, w, h) in faces:
         sampleNum = sampleNum + 1  # 如果检测到了人脸+1
         cv2.imwrite("dataset/User." + str(Id) + "." + str(sampleNum) + ".jpg", gray[y:y + h, x:x + w])
         cv2.rectangle(img, (x, y), (x + w, y + h), (0, 255, 0), 2)
         cv2.waitKey(100)
     cv2.namedWindow('Face', cv2.WINDOW_NORMAL)
     cv2.imshow('Face', img)  # 显示网络摄像头中检测到的面孔
     if cv2.waitKey(5) & 0xFF == 27:  # 按ESC退出
         break
 cam.release()
 cv2.destroyAllWindows()
 ​2、数据训练
'''
 数据训练 trainer.py
 '''
 ​
 import os
 import cv2
 import numpy as np
 from PIL import Image
 ​
 recognizer = cv2.face.LBPHFaceRecognizer_create()  # 创建 LBPH 人脸识别器
 path = "dataset"
 ​
 def getImagesWithID(path):
     imagePaths = [os.path.join(path, f) for f in os.listdir(path)]  # 获取图像路径
     faces = []
     IDs = []
     for imagePath in imagePaths:
         faceImg = Image.open(imagePath).convert('L')  # 打开并转换为灰度图像
         faceNp = np.array(faceImg, 'uint8')
         ID = int(os.path.split(imagePath)[-1].split(".")[1])  # 从文件名中提取ID
         print(ID)
         faces.append(faceNp)
         IDs.append(ID)
         cv2.imshow("Training", faceNp)  # 在窗口中显示训练图像
         cv2.waitKey(100)
     return np.array(IDs), faces
 ​
 Ids, faces = getImagesWithID(path)
 recognizer.train(faces, Ids)  # 使用图像数据进行训绋
 recognizer.save('recognizer/trainingData.yml')  # 保存训练好的模型
 ​
 cv2.destroyAllWindows()  # 关闭所有 OpenCV 窗口
 ​

运行以上代码中如果出现以下错误:

 AttributeError: module 'cv2' has no attribute 'face'

可以重新 pip install opencv-contrib-python

3、人脸分析 
'''
 人脸分析 detect.py
 '''
 ​
 import cv2
 import sqlite3
 ​
 facedetector = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')
 cam = cv2.VideoCapture(0)
 ​
 recognizer = cv2.face.LBPHFaceRecognizer_create()
 recognizer.read('recognizer/trainingData.yml')
 ​
 ​
 def getprofile(id):
     conn = sqlite3.connect("sqlite.db")
     cmd = "SELECT * FROM STUDENTS WHERE ID=" + str(id)
     cursor = conn.execute(cmd)
     profile = None
     for row in cursor:
         profile = row
     conn.close()
     return profile
 ​
 ​
 id = 0
 while True:
     ret, im = cam.read() # 从摄像头捕获一帧图像,ret 表示是否成功读取帧,im 是捕获的图像。
     gray = cv2.cvtColor(im, cv2.COLOR_BGR2GRAY)
     faces = facedetector.detectMultiScale(gray, 1.2, 5)
     for (x, y, w, h) in faces:
         cv2.rectangle(im, (x, y), (x + w, y + h), (225, 0, 0), 2)
         id, conf = recognizer.predict(gray[y:y + h, x:x + w])
         profile = getprofile(id)
         print(profile)
         if profile is not None:
             cv2.putText(im, "Name:" + str(profile[1]), (x, y + h + 20), cv2.FONT_HERSHEY_COMPLEX, 1, (0, 255, 127), 2)
             cv2.putText(im, "Age:" + str(profile[2]), (x, y + h + 45), cv2.FONT_HERSHEY_COMPLEX, 1, (0, 255, 255), 2)
     cv2.imshow('Face', im)
     if cv2.waitKey(5) & 0xFF == 27: # 按ESC退出
         break
 cam.release()
 cv2.destroyAllWindows()

​在人脸识别代码中:

facedetector 是使用的人脸检测器对象,通常是一个基于 Haar 特征的级联分类器。在这段代码中,facedetector 是通过加载名为 'haarcascade_frontalface_default.xml' 的 XML 文件创建的。该 XML 文件包含了训练好的模型,用于检测图像中的人脸。具体来说,这个级联分类器可以根据预先训练好的数据集,通过对输入图像进行特征匹配和分类来识别出人脸。detectMultiScale() 方法用于在图像中检测多个尺度的目标(在这种情况下是人脸)。在 detectMultiScale() 方法中,传入的参数包括灰度图像、每次缩小图像的尺寸比例因子以及定义人脸大小的参数。这个方法会返回检测到的人脸区域的坐标和尺寸,以便后续对每个人脸区域进行识别和处理。总之,facedetector 对象是用于检测输入图像中人脸的重要组件,通过使用 Haar 特征和级联分类器技术,在实时视频流中定位并识别人脸。recognizer.predict() 方法返回两值:识别出的人脸 ID 和与该 ID 相关的置信度(confidence)。

  1. Person ID:

    • 这是表示识别出的人脸属于哪个个体的标识符。

    • 在训练期间,每个被识别的人脸都会分配一个唯一的 ID。

    • 通过这个 ID,可以在数据库中查找对应的个人信息。

  2. Confidence (置信度):

    • 置信度是指识别系统对预测结果的自信程度或确定性水平。

    • 通常用数值来表示,越低表示系统认为识别可能不太可靠,而较高的值则表示系统更有信心认为识别结果准确。

    • 对于人脸识别系统,置信度越低表示系统对于该识别结果的可靠性存在疑问。

因此,recognizer.predict() 返回的两个值可以帮助我们了解识别出的人脸属于哪个个体,并提供了一个指标来评估系统对该识别结果的确定程度。

最后识别结果:

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

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

相关文章

基于Spring Cloud的房产销售平台设计与实现

基于Spring Cloud的房产销售平台设计与实现 开发语言:Java 框架:SpringCloud JDK版本:JDK1.8 数据库工具:Navicat11 开发软件:eclipse/myeclipse/idea 系统部分展示 前台首页界面,前台首页包括房源信息、…

RS485空调系统到BACnet江森楼宇系统的高效整合攻略

智慧城市的每一栋建筑都在追求更高的能效与更佳的居住体验,而这一切的实现离不开强大且灵活的楼宇自动化系统。其中,协议转换网关作为连接不同设备的纽带,扮演着至关重要的角色。本文将以一个典型的商业综合体为例,揭秘BACnet协议…

零基础开发新闻小程序带评论点赞收藏功能,可以回复评论,借助小程序云开发云模板开发一款图文小程序,新闻列表新闻详情,登录注册功能

小程序官方有改版了,搞得石头哥不得不紧急的再新出一版,教大家开通最新版的cms网页管理后台 一,技术选型和技术点 1,小程序前端 wxml css JavaScript MINA原生小程序框架 2,数据库 云开发 云数据库 云…

力扣:62. 不同路径

62. 不同路径 一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为 “Start” )。 机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为 “Finish” )。 问总共有多少条不同的路径&…

20232906 2023-2024-2 《网络与系统攻防技术》第九次作业

20232906 2023-2024-2 《网络与系统攻防技术》第九次作业 1.实验内容 本次实践的对象是一个名为pwn1的linux可执行文件。 该程序正常执行流程是:main调用foo函数,foo函数会简单回显任何用户输入的字符串。 该程序同时包含另一个代码片段,getShell&am…

【负载均衡式在线OJ项目day4】编译运行功能整合及打包网络服务

一.前言 前面两天完成了编译和运行两个子模块,今天的任务是完成CompileRun模块,它的任务如下: 解析来自客户端的Json字符串,反序列化提取编译运行需要的数据,即代码,时间限制和空间限制把代码写入临时文件…

太阳能无人机的多元化应用

随着新能源技术的不断发展和成熟,太阳能在无人机的应用技术已经成熟。太阳能无人机得到了量产和广泛的应用。传统无人机相比,太阳能无人机无需燃油,运行费用低廉,搭载多种高科技设备,能够高效、多元化地采集和分析各类…

公司活动想找媒体报道宣传怎样联系媒体?

作为公司宣传负责人,我深知媒体报道对于企业活动宣传的重要性。然而,在过去,每当有重要活动需要媒体曝光时,我总会被繁琐的媒体联系工作所困扰。 那时,我需要一家家地查询媒体联系方式,发送邮件、打电话,甚至亲自前往媒体机构进行沟通。然而,这样的过程不仅费时费力,而且效率低…

成本降低 90%,出海社交平台 Typing 基于 Databend 的大数据探

Typing(输入中科技)成立于 2022 年,是一家主要面向东南亚、拉美、中东等海外地区提供社交平台的出海企业。其社交平台类似于国内的 Soul、陌陌等,提供视频直播、语音聊天室、短视频、生活分享、文字聊天等社交功能,注册…

英语学习笔记5——Nice to meet you.

Nice to meet you. 很高兴见到你。 词汇 Vocabulary Mr. 先生 用法:自己全名 / 姓 例如:Mr. Zhang Mingdong 或 Mr. Zhang,绝对不能是 Mr. Mingdong! Miss 女士,小姐 未婚 用法:自己全名 / 姓 例如&#…

区块链(打新)如何被割韭菜

看上去,像我只要去每个都买一遍新发行的代币,一定可以成功的 但是好像没有想象中这么简单,因为这些山寨币,庄家可以自己控盘的,看上去好像有跌宕起伏的买卖,但是一单掀桌子,庄家他自己都不玩了…

SOCKET编程(3):相关结构体与函数

相关结构体与函数 sockaddr、sockaddr_in结构体 sockaddr和sockaddr_in详解 struct sockaddr共16字节,协议族(family)占2字节,IP地址和端口号在sa_data字符数组中 /* Structure describing a generic socket address. */ struct sockaddr {__SOCKADDR…

推荐3个实用的github开源项目

目录: 1、AI生成高清短视频 2、媒体平台爬虫 3、文本转语音项目

ubuntu server 22.04 安装docker、docker-compose

ubuntu server 22.04安装docker有两种方式,第一种是使用ubuntu镜像源的软件包进行安装,第二种使用官方GPG密钥手动添加Docker存储库方式进行安装,两种方式都可以,但第二种方式略复杂,这里介绍第一种比较简单的安装方式…

图像ISP——AGC参数解析

前言 AWB和AGC是两种常见的自动调整功能。AWB用于自动调整图像的白平衡,以确保颜色在不同光照条件下仍然看起来自然。而AGC则用于自动调整图像的增益,以在不同的亮度条件下保持适当的曝光。 代码例程 static AWB_AGC_TABLE_S g_stAwbAgcTable {/* bvali…

深入解析Java中Set接口

哈喽,各位小伙伴们,你们好呀,我是喵手。运营社区:C站/掘金/腾讯云;欢迎大家常来逛逛 今天我要给大家分享一些自己日常学习到的一些知识点,并以文字的形式跟大家一起交流,互相学习,一…

【前端基础】CSS样式+Vue中绘制时间轴

深度选择器 在 Vue.js 中,/deep/、>>>、:deep 和 ::v-deep 这些都是深度选择器,用于修改子组件的样式。它们主要用于解决作用域样式和组件样式之间的冲突问题。 1. /deep/ 或 >>> /deep/ 和 >>> 是相同的选择器,…

spring boot参数验证注解@NotNull、@NotBlank和@NotEmpty区别

目录 前言说明举例 前言 使用spring boot参数验证是常常会使用NotNull、NotBlank和NotEmpty三个判断是否不为空的注解,中文都有不能为空的意思,大部分使用者都傻傻分清它们之间到底有什么区别。今天就让咱们来一起探索它们之间的不同吧。 说明 注解名…

一文了解webpack和vite中Tree-Shaking

1、什么是Tree-Shaking 1.1 摇树优化(Tree Shaking)是Webpack中一种用于优化JavaScript代码的技术。它的目标是通过静态分析,从代码中剔除未被使用的模块,从而减少最终打包文件的大小。 1.2 Tree-shaking 它的名字来源于通过摇晃…

【线性代数】英语版听课笔记

线性代数 - 北京航天航空大学(英文版)_哔哩哔哩_bilibili 39.concept of vector space in this lecture we will studyvector space, the concept of basis dimension and coordinates 向量空间的维数:向量空间的基底所含向量的…