【人脸识别】基于dlib库实现人脸特征值提取
一、Dlib库介绍与安装
1. Dlib库简介
2. 安装Dlib库
pip install dlib
二、OpenCV介绍即安装
1. OpenCV简介
2. OpenCV安装
pip3 install opencv_python
三、提取人脸特征点
# -*- coding: utf-8 -*-
"""
Created on Wed Oct 27 03:15:10 2021@author: GT72VR
"""
import numpy as np
import cv2
import dlib
import os
import sys
import random
# 存储位置
output_dir = 'C:/Users/王青松/'
size = 64if 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 = 255elif tmp < 0:tmp = 0img[j,i,c] = tmpreturn img#使用dlib自带的frontal_face_detector作为我们的特征提取器
detector = dlib.get_frontal_face_detector()
# 打开摄像头 参数为输入流,可以为摄像头或视频文件
camera = cv2.VideoCapture('D:/wudipuls.mp4')
#camera = cv2.VideoCapture(0)
ok = Truedetector = dlib.get_frontal_face_detector()
predictor = dlib.shape_predictor('shape_predictor_68_face_landmarks.dat')while ok:# 读取摄像头中的图像,ok为是否读取成功的判断参数ok, img = camera.read()# 转换成灰度图像img_gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)rects = detector(img_gray, 0)for i in range(len(rects)):landmarks = np.matrix([[p.x, p.y] for p in predictor(img,rects[i]).parts()])for idx, point in enumerate(landmarks):# 68点的坐标pos = (point[0, 0], point[0, 1])print(idx,pos)# 利用cv2.circle给每个特征点画一个圈,共68个cv2.circle(img, pos, 2, color=(0, 255, 0))# 利用cv2.putText输出1-68font = cv2.FONT_HERSHEY_SIMPLEXcv2.putText(img, str(idx+1), pos, font, 0.2, (0, 0, 255), 1,cv2.LINE_AA)cv2.imshow('video', img)k = cv2.waitKey(1)if k == 27: # press 'ESC' to quitbreakcamera.release()
cv2.destroyAllWindows()
四、在眼睛处绘制黑色的实心圆
def painting_sunglasses(img,detector,predictor): #给人脸带上墨镜rects = detector(img_gray, 0) for i in range(len(rects)):landmarks = np.matrix([[p.x, p.y] for p in predictor(img,rects[i]).parts()])right_eye_x=0right_eye_y=0left_eye_x=0left_eye_y=0for i in range(36,42):#右眼范围#将坐标相加right_eye_x+=landmarks[i][0,0]right_eye_y+=landmarks[i][0,1]#取眼睛的中点坐标pos_right=(int(right_eye_x/6),int(right_eye_y/6))cv2.circle(img=img, center=pos_right, radius=30, color=(0,0,0),thickness=-1)for i in range(42,48):#左眼范围#将坐标相加left_eye_x+=landmarks[i][0,0]left_eye_y+=landmarks[i][0,1]#取眼睛的中点坐标pos_left=(int(left_eye_x/6),int(left_eye_y/6))cv2.circle(img=img, center=pos_left, radius=30, color=(0,0,0),thickness=-1)#camera = cv2.VideoCapture(0)#打开摄像头
camera = cv2.VideoCapture('D:/wudipuls.mp4')
ok=True
# 打开摄像头 参数为输入流,可以为摄像头或视频文件
while ok:ok,img = camera.read()# 转换成灰度图像img_gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)#display_feature_point(img,detector,predictor)painting_sunglasses(img,detector,predictor)#调用画墨镜函数cv2.imshow('video', img)k = cv2.waitKey(1)if k == 27: # press 'ESC' to quitbreak
camera.release()
cv2.destroyAllWindows()
五、总结
本文简略地介绍了dlib库与OpenCV,并初步尝试使用dlib库对人脸的特征值进行提取。
六、参考
【人脸识别】基于dlib库实现人脸特征值提取_YangMax1的博客-CSDN博客
【人脸识别】基于dlib库实现人脸特征值提取相关推荐
- 视觉识别入门之人脸识别——基于FACENET的高精度人脸识别
视觉识别入门之人脸识别---- 基于FACENET的高精度人脸识别 一:项目展示: - 这是实时视频读取的展示,是可以读单张图片,或者本地视频流,抑或是实时人脸检测与分类的,至于我为什么不展示我的自拍 ...
- 基于Dlib库的人脸表情分析与识别——Python
本项目主要由包含我在内的四名成员共同完成:孙明喆.吴震.张晨.张明 项目介绍,及可执行文件.模型文件.详细报告均在GitHub中可以查看: GitHub 关于项目的详细介绍,可能过些日子在复习时候会有 ...
- python中dlib库_python 基于dlib库的人脸检测的实现
本周暂时比较清闲,可以保持每日一更的速度. 国外身份证项目新增需求,检测出身份证正面的人脸.最开始考虑mobilenet-ssd,经同事提醒,有现成的人脸库dlib,那就用传统方法尝试一下. dlib ...
- caffe检测图片是否包含人脸_人脸识别(基于Caffe)
人脸识别(基于Caffe, 来自tyd) 人脸识别(判断是否为人脸) LMDB(数据库, 为Caffe支持的分类数据源) mkdir face_detect cd face_detect mkdir ...
- 人脸识别(基于Caffe, 来自tyd)
人脸识别(基于Caffe, 来自tyd) 人脸识别(基于Caffe, 来自tyd) 数据获取 在相关的bentchmark找 在thinkface论坛上找数据集 截取人脸 基于IoU 负样本可以找一些 ...
- 基于python的dlib库的人脸识别
首先通过pip安装cmake,只有安装了cmake才能装上dlib库,建议装dlib的时候关闭后台的360杀毒软件. 源代码如下: import dlib import cv2 as cvimage_ ...
- dlib库包的介绍与使用,opencv+dlib检测人脸框、opencv+dlib进行人脸68关键点检测,opencv+dlib实现人脸识别,dlib进行人脸特征聚类、dlib视频目标跟踪
文章目录: 1 dlib库介绍 2 dlib人脸检测:绘制出人脸检测框 2.1 dlib人脸检测源码 2.2 opencv + dlib 人脸检测 2.3 dlib人脸检测总结 3 dlib人脸关键点 ...
- 基于dlib库进行微笑识别和口罩识别
环境配置 tensorflow和keras参考我之前的博客https://blog.csdn.net/A981012/article/details/106650686 下载dlib库不能从anaco ...
- python dlib人脸识别_python3+dlib人脸识别及情绪分析
一.介绍 我想做的是基于人脸识别的表情(情绪)分析.看到网上也是有很多的开源库提供使用,为开发提供了很大的方便.我选择目前用的比较多的dlib库进行人脸识别与特征标定.使用python也缩短了开发周期 ...
最新文章
- java核心编程视频教学
- 阿里的STORM——JSTORM
- 由《我也能做CTO》引起的作者与读者的交流
- JavaScript练习笔记
- 基于webpack的react脚手架
- 堆的应用(堆排序,TopK问题)
- 关于DateTime的一点记录 ToString(yyyy-MM-dd HH:mm:ss)
- X264学习笔记(1)
- python中异或运算_python – 基于ID列表有效计算XOR(^)校验和的方法
- 在文件编辑器中添加dock菜单项_将应用程序添加到Mac 的Dock的简便方法
- html雪碧图效果,html和css中雪碧图的使用
- GIMP教程 5 选择
- 阿里巴巴平台型产品经理
- Java学习之基础知识2
- 为 Vue 项目添加 cnzz 统计
- An exception occurred while acquiring a poolable resource. Will retry.
- 生信必会格式:Fasta Fastq 简介及转换
- android#boardcast#发送自定义广播
- Android 屏幕刷新机制 VSync+Choreographer
- 网络上摘抄的数据库设计规范