人脸识别数据集建立及应用

一.人脸识别数据集的建立

基于dlib库人脸特征提取

1.采集自己的脸部图片20张,保存到文件夹中

源码:

import cv2
import dlib
import os
import sys
import random
# 存储位置
output_dir = 'D:/myworkspace/JupyterNotebook/People/person/631907060311'
size = 64
 
if not os.path.exists(output_dir):
    os.makedirs(output_dir)
# 改变图片的亮度与对比度
 
def relight(img, light=1, bias=0):
    w = img.shape[1]
    h = img.shape[0]
    #image = []
    for i in range(0,w):
        for j in range(0,h):
            for c in range(3):
                tmp = int(img[j,i,c]*light + bias)
                if tmp > 255:
                    tmp = 255
                elif tmp < 0:
                    tmp = 0
                img[j,i,c] = tmp
    return img
 
#使用dlib自带的frontal_face_detector作为我们的特征提取器
detector = dlib.get_frontal_face_detector()
# 打开摄像头 参数为输入流,可以为摄像头或视频文件
camera = cv2.VideoCapture(0)
#camera = cv2.VideoCapture('D:/z7z8/yy.mp4')

index = 1
while True:
    if (index <= 20):#存储20张人脸特征图像
        print('Being processed picture %s' % index)
        # 从摄像头读取照片
        success, img = camera.read()
        # 转为灰度图片
        gray_img = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
        # 使用detector进行人脸检测
        dets = detector(gray_img, 1)
 
        for i, d in enumerate(dets):
            x1 = d.top() if d.top() > 0 else 0
            y1 = d.bottom() if d.bottom() > 0 else 0
            x2 = d.left() if d.left() > 0 else 0
            y2 = d.right() if d.right() > 0 else 0
 
            face = img[x1:y1,x2:y2]
            # 调整图片的对比度与亮度, 对比度与亮度值都取随机数,这样能增加样本的多样性
            face = relight(face, random.uniform(0.5, 1.5), random.randint(-50, 50))
 
            face = cv2.resize(face, (size,size))
 
            cv2.imshow('image', face)
 
            cv2.imwrite(output_dir+'/'+str(index)+'.jpg', face)
 
            index += 1
        key = cv2.waitKey(30) & 0xff
        if key == 27:
            break
    else:
        print('Finished!')
        # 释放摄像头 release camera
        camera.release()
        # 删除建立的窗口 delete all the windows
        cv2.destroyAllWindows()
        break

运行结果:

在这里插入图片描述

2.分别将每张图片的特征点数组保存到一个独立的表格,通过20张图片的特征,计算出平均特征并保存到表格。

dlib人脸特征检测原理:

1.提取特征点

例:img

2.将特征值保存到CSV文件

3.计算特征数据集的欧氏距离作对比,当误差小于一定阙值就判定为同一人。

源码:

# 从人脸图像文件中提取人脸特征存入 CSV
# Features extraction from images and save into features_all.csv

# return_128d_features()          获取某张图像的128D特征
# compute_the_mean()              计算128D特征均值

from cv2 import cv2 as cv2
import os
import dlib
from skimage import io
import csv
import numpy as np

# 要读取人脸图像文件的路径
path_images_from_camera = "D:/myworkspace/JupyterNotebook/People/person/"

# Dlib 正向人脸检测器
detector = dlib.get_frontal_face_detector(
  • 2
    点赞
  • 59
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
"YOLO人脸情绪识别数据集"是一个专门用于训练和评估人脸情绪识别算法的数据集。YOLO(You Only Look Once)是一种实时对象检测算法,该数据集是为了训练YOLO算法来实现人脸情绪识别而创建的。 该数据集包含多个样本,每个样本都是一张包含人脸的图像,同时标注了人脸的情绪类别。情绪类别通常包括高兴、悲伤、愤怒、惊讶等基本情绪,可能还包括其他情绪类别。每个样本都有一个与之对应的标签,表示该人脸图像所对应的情绪类别。 数据集的构建通常包括以下步骤: 1. 收集人脸图像:数据集的构建需要收集大量的人脸图像,可以通过公开数据集、网络图片、或者自己拍摄等方式获取。 2. 标注情绪类别:针对每个人脸图像,需要手动或者利用人脸识别算法来标注对应的情绪类别,确保每个图像都有准确的情绪标签。 3. 数据预处理:对收集到的人脸图像进行预处理,如大小调整、灰度化、归一化等操作,以便算法能够更好地处理和识别。 4. 数据划分:将整个数据集划分为训练集、验证集和测试集,保证算法能够在独立的数据集上进行评估和泛化。 5. 模型训练:利用标注的人脸情绪类别,使用YOLO算法进行模型训练,使得算法能够准确地识别人脸图像中的情绪。 6. 模型评估:使用验证集和测试集对训练好的模型进行评估,计算模型的准确率、召回率和F1值等指标。 通过这个数据集,我们可以训练出一个能够实时检测人脸,并精确判断出人脸情绪的算法。这对于人机交互、情感识别、智能娱乐等领域都有很大的应用潜力。此外,该数据集的存在也对研究者、开发者和工程师们来说是一个很好的资源,可以用于开发和改进人脸情绪识别算法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值