python opencv3 人脸识别的例子
一个人脸识别的例子
程序中用到了公共数据集, 欢迎去我的git上下载源码,源码里带有数据集
git:https://github.com/linyi0604/Computer-Vision
脚本中一个三个函数
第一个: 调用本机摄像头采集一些自己的照片 作为数据集的一部分
第二个:把自己的照片 和公共数据集照片一并读取 作为输入数据
第三个: 预测函数 调用第二个函数拿到x 和y 进行训练后 开启摄像头 进行预测
# coding:utf-8 import cv2
import os
import numpy as np # 1 生成人脸识别数据
# 图像是灰度格式,后缀名.pgm
# 图像是正方形 图像大小要一样 在这里使用200*200
def generate():
# 加载检测图像中人脸位置的对象, xml文件需要去opencv文件夹里面找, 放到项目里面来引入
face_cascade = cv2.CascadeClassifier("../data/haarcascade_frontalface_default.xml")
# 调用本机摄像头
camera = cv2.VideoCapture(0)
count = 0
# 读取摄像头
while True:
# 读入 帧
ret, frame = camera.read()
# 变为灰度图像
gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
# 检测人脸位置
faces = face_cascade.detectMultiScale(gray, 1.3, 5)
# 将图片中人脸位置单独拿出来改变成200*200大小的图片 存入本地 作为数据集
for (x, y, w, h) in faces:
img = cv2.rectangle(frame, (x, y), (x+w, y+h), (255, 0, 0), 2)
f = cv2.resize(gray[y:y+h, x:x+w], (200, 200))
cv2.imwrite("./data/%s.pgm" % str(count), f)
count += 1 cv2.imshow("camera", frame)
# 如果按键q就退出 否则等50毫秒
if cv2.waitKey(50) & 0xff == ord("q"):
break camera.release()
cv2.destroyAllWindows() # 读取生成好的数据 在我项目目录下整理好的
def readImages():
x, y = [], []
path = "./data/faces/"
image_file = os.listdir(path)
image_files = [path + i for i in image_file]
for file in image_files:
images = os.listdir(file)
label = file.split("/")[-1][1:]
for i in images:
img = cv2.imread(file + "/" + i, cv2.IMREAD_GRAYSCALE)
img = cv2.resize(img, (200, 200))
x.append(np.asarray(img, dtype=np.uint8))
y.append(int(label)) y = np.asarray(y, dtype=np.int32)
return x, y # 检测人脸
def face_rec():
# 获取数据
x, y = readImages() # 人脸识别的模型
model = cv2.face.EigenFaceRecognizer_create()
# fisherfaces算法的模型
# model = cv2.face.FisherFaceRecognizer_create()
# LBPH算法的模型
# model = cv2.face.LBPHFaceRecognizer_create()
"""
Eigenfaces和Fisherfaces 预测时候产生0到20000的评分
低于4000 5000 的评分都是相当可靠的
LBPH 产生评分不同,低于50是可靠的 高于80是不可靠的
""" # 训练模型
model.train(np.asarray(x), np.asarray(y)) # 开摄像头
camera = cv2.VideoCapture(0)
# 加载检测人脸对象
face_cascade = cv2.CascadeClassifier("../data/haarcascade_frontalface_default.xml")
while True:
# 读取当前帧
read, img = camera.read()
# 当前帧下检测人脸
faces = face_cascade.detectMultiScale(img, 1.3, 5)
for (x, y, w, h) in faces:
# 画出人脸
img = cv2.rectangle(img, (x, y), (x+w, y+h), (255, 0, 0), 2)
# 转成灰度图
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
# 拿出人脸部分
roi = gray[x: x+w, y: y+h]
try:
# 更改大小
roi = cv2.resize(roi, (200, 200), interpolation=cv2.INTER_LINEAR)
# 进行预测
params = model.predict(roi)
# 在图像上写预测结果
# 1.2是字体大小 2是粗细
img = cv2.putText(img, str(params[0]), (x, y), cv2.FONT_HERSHEY_SIMPLEX, 1.2, (0, 255, 0), 2)
# prams是一个二元素列表, 第一个元素是预测结果,第二个元素是得分情况
print(params) except Exception as e:
print(e)
cv2.imshow("detect face", img)
if cv2.waitKey(5) & 0xff == ord("q"):
break cv2.destroyAllWindows() if __name__ == '__main__':
# 调用摄像头 采集人脸照片数据
# generate() # 检测人脸
face_rec()
python opencv3 人脸识别的例子的更多相关文章
- 手把手教你如何用 OpenCV + Python 实现人脸识别
下午的时候,配好了OpenCV的Python环境,OpenCV的Python环境搭建.于是迫不及待的想体验一下opencv的人脸识别,如下文. 必备知识 Haar-like 通俗的来讲,就是作为人脸特 ...
- 用Python进行人脸识别
本文的模型使用了C++工具箱 dlib 基于深度学习的最新人脸识别方法,基于户外脸部数据测试库Labeled Faces in the Wild 的基准水平来说,达到了99.38%的准确率. dlib ...
- 「Python」人脸识别应用
人脸识别主要步骤: face_recognition 库的安装 安装此库,首先需要安装编译dlib,此处我们偷个懒,安装软件Anaconda(大牛绕过),此软件预装了dlib. 安装好后,我们直接通过 ...
- 使用OpenCV和Python进行人脸识别
介绍 人脸识别是什么?或识别是什么?当你看到一个苹果时,你的大脑会立刻告诉你这是一个苹果.在这个过程中,你的大脑告诉你这是一个苹果水果,用简单的语言来说就是识别.那么什么是人脸识别呢?我肯定你猜对了. ...
- 动手实操:如何用 Python 实现人脸识别,证明这个杨幂是那个杨幂?
当前,人脸识别应用于许多领域,如支付宝的用户认证,许多的能识别人心情的 AI,也就是人的面部表情,还有能分析人的年龄等等,而这里面有着许多的难度,在这里我想要分享的是一个利用七牛 SDK 简单的实现人 ...
- 一种基于python的人脸识别开源系统
今天在搜索人脸识别的文章时,无意中搜到一个比较开源代码,介绍说是这个系统人脸的识别率 是比较高的,可以达到:99.38%.这么高的识别率,着实把我吓了一跳.抱着实事求是的态度.个人 就做了一些验证和研 ...
- python通过人脸识别全面分析好友,一起看透你的“朋友圈”
微信:一个提供即时通讯服务的应用程序,更是一种生活方式,超过数十亿的使用者,越来越多的人选择使用它来沟通交流. 不知从何时起,我们的生活离不开微信,每天睁开眼的第一件事就是打开微信,关注着朋友圈里好友 ...
- opencv python训练人脸识别
总计分为三个步骤 一.捕获人脸照片 二.对捕获的照片进行训练 三.加载训练的数据,识别 使用python3.6.8,opencv,numpy,pil 第一步:通过笔记本前置摄像头捕获脸部图片 将捕获的 ...
- Python实现人脸识别
识别图片 #coding=utf-8 import requests,cv2 import re import os import bs4 #2.读取图片 filename = 'E:/Python/ ...
随机推荐
- 苹果手机浏览器$(document).on(“click”,function(){})点击无效的问题
<label class="js_highlight" style="display: inline-block;float: left;width: 50%;&q ...
- 关于Python编码问题小记
Python编码问题小记: 引子: 最近在复习redis,当我在获取redis的key的时候,redis 存储英文和汉字下面这个样子的,我知道汉字是用16进制的UTF-8编码了,然后突然很想搞清楚字符 ...
- 【黑客免杀攻防】读书笔记17 - Rootkit基础
1.构建Rootkit基础环境 1.1.构建开发环境 VS2012+WDK8 1.2.构建基于VS2012的调试环境 将目标机.调试机配置在同一个工作组内 sVS2012配置->DRIVER-& ...
- 41 - 数据库-pymysql41 - 数据库-pymysql-DBUtils
目录 1 Python操作数据库 2 安装模块 3 基本使用 3.1 创建一个连接 3.2 连接数据库 3.3 游标 3.3.1 利用游标操作数据库 3.3.2 事务管理 3.3.3 执行SQL语句 ...
- Shell编写8点建议
这八个建议,来源于键者几年来编写 shell 脚本的一些经验和教训.事实上开始写的时候还不止这几条,后来思索再三,去掉几条无关痛痒的,最后剩下八条.毫不夸张地说,每条都是精挑细选的,虽然有几点算是老生 ...
- MongoDB官方文档结构
本文展示MongoDB 3.6.4.0的官方Server文档的结构图——一眼可见完整的知识脉络图.不过,MongoDB除了Server的文档外,还有DRIVERS.CLOUD.TOOLS.DUIDES ...
- Python列表(list)
序列是Python中最基本的数据结构.序列中的每个元素都分配一个数字 - 它的位置,或索引,第一个索引是0,第二个索引是1,依此类推. 此外,Python已经内置确定序列的长度以及确定最大和最小的元素 ...
- caffe+win7+vs2013 仅CPU环境安装
笔者对深度学习一直充满着好奇与兴趣,之前学校都是研究图像处理的特征点方式,机器学习使用也不多,别提深度学习了. 在看了李宏毅大佬的PPT后,有了初步的认识,虽然是渣渣电脑,也想自己跑几个深度模型. 说 ...
- 关于Eclipse连接sql server 2008的若干问题
以下内容转自:https://www.cnblogs.com/skylarzhan/p/7619977.html Eclipse中使用SQL server 2008数据库 一.准备材料 要能够使用数据 ...
- 20155225 2006-2007-2 《Java程序设计》第四周学习总结
20155225 2006-2007-2 <Java程序设计>第四周学习总结 教材学习内容总结 对"是一种"语法测试几次之后,总结一句:满足"是一种" ...