人脸特征提取(在眼睛处绘制黑色实心圆)
以人脸识别(属于分类问题)为例,理解实际应用中的特征数据集提取。
1)用python3 + opencv3.4 + dlib库编程,打开摄像头,实时采集人脸并保存、绘制68个特征点;
2)不在原视频上绘制显示特征点,而是给人脸虚拟P上一付墨镜(提示:找到双眼特征点坐标值,以坐标中心点为圆心,用opencv函数绘制两个圆,并填充黑色)
嘿!我是目录
- 一、dlib库介绍
- 二、dlib与opencv下载
- 2.1 dlib
- 2.1.1 下载链接
- 2.1.2 安装
- 2.2 opencv
- 三、用dlib库在眼睛处绘制黑色的实心圆
- 3.1 代码
- 3.2 实验结果
- 小小的总结
- 参考文献
一、dlib库介绍
- 简介:dlib是一个机器学习的开源库,包含了机器学习的很多算法,使用起来很方便,直接包含头文件即可,并且不依赖于其他库(自带图像编解码库源码)。Dlib可以帮助您创建很多复杂的机器学习方面的软件来帮助解决实际问题。目前Dlib已经被广泛的用在行业和学术领域,包括机器人,嵌入式设备,移动电话和大型高性能计算环境。
- Dlib是一个使用现代C++技术编写的跨平台的通用库,遵守Boost Software licence. 主要特点如下:
● 完善的文档:每个类每个函数都有详细的文档,并且提供了大量的示例代码,如果你发现文档描述不清晰或者没有文档,告诉作者,作者会立刻添加。
● 可移植代码:代码符合ISO C++标准,不需要第三方库支持,支持win32、Linux、Mac OS X、Solaris、HPUX、BSDs 和 POSIX 系统 。
● 线程支持:提供简单的可移植的线程API 。
● 网络支持:提供简单的可移植的Socket API和一个简单的Http服务器 。
● 图形用户界面:提供线程安全的GUI API 。
● 数值算法:矩阵、大整数、随机数运算等 。
● 机器学习算法
● 图形模型算法
● 图像处理:支持读写Windows BMP文件,不同类型色彩转换
● 数据压缩和完整性算法:CRC32、Md5、不同形式的PPM算法
● 测试:线程安全的日志类和模块化的单元测试框架以及各种测试assert支持
● 一般工具:XML解析、内存管理、类型安全的big/little endian转换、序列化支持和容器类
二、dlib与opencv下载
2.1 dlib
2.1.1 下载链接
链接:https://pan.baidu.com/s/1b6Lnrci7EQzaBN_NVunNVg
提取码:1111
笔主这里用的python版本是3.8的,所以安装的dlib版本也是38的,必须对应版本去安装。
- 如果不知道自己的python版本,按Windows键打开,用下面方式打开终端:
- 输入
python
命令
- 即可看到自己的python版本。
- 然后到网上去找对应的版本,笔主这里提供一个链接:dlib软件及模型文件下载(可以参考一下,但下载下来都是压缩包,需要在里面去找文件,其实自行百度是最合适的)
- 笔主再提供36、37、38版本的下载链接:
链接:https://pan.baidu.com/s/1pkYlWrkrQu6eb2ToYBDaDg
提取码:1122
2.1.2 安装
- 按上文方式打开终端后,按以下方式打开你下载上面dlib文件所在的路径:
- 输入命令
pip install dlib-19.19.0-cp38-cp38-win_amd64.whl
- 出现Successfully installed…,即说明安装成功。
2.2 opencv
- 在终端直接输入:
pip install opencv_python==3.4.11.45
注意:如果在网络不好的情况下可能会出现安装失败的情况,可以用清华的镜像网站安装。
输入命令:
pip --default-timeout=100 install opencv_python==3.4.11.45 -i http://pypi.douban.com/simple/ --trusted-host pypi.douban.com
- 这样就安装好我们所需要的库文件啦。
三、用dlib库在眼睛处绘制黑色的实心圆
3.1 代码
# 导入包
import numpy as np
import cv2
import dlib
import os
import sys
import randomdef get_detector_and_predicyor():detector = dlib.get_frontal_face_detector()#返回训练好的人脸68特征点检测器predictor = dlib.shape_predictor('D:/ProgramData/wenjian/shape_predictor_68_face_landmarks.dat')#之前下载的dlib文件存放的路径return detector,predictor#获取检测器
detector,predictor=get_detector_and_predicyor()
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))"""利用circle函数画圆函数原型 cv2.circle(img, center, radius, color[, thickness[, lineType[, shift]]])img:输入的图片datacenter:圆心位置radius:圆的半径color:圆的颜色thickness:圆形轮廓的粗细(如果为正)。负厚度表示要绘制实心圆。lineType: 圆边界的类型。shift:中心坐标和半径值中的小数位数。"""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)#打开摄像头
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()
3.2 实验结果
小小的总结
最终调试出来还挺奇妙的,也说明dlib库和opencv的强大,功能很全,支持各个不同的系统。
opencv对于侧面的人脸,识别没有正面的灵敏,不适用于非正面人脸图像,但它可以检测不同比例的人脸。
总的来说过程并不难,可能安装的时候会遇到一些小小的问题,没关系,百度搜搜,解决它!
参考文献
- dlib库简介
- 人脸特征提取
- dlib软件及模型文件下载
- 人脸特征提取(dlib+opencv3.4+python3.8)
人脸特征提取(在眼睛处绘制黑色实心圆)相关推荐
- Android开发(1):随机绘制彩色实心圆
本文介绍了如何利用Android的绘图技术随机绘制彩色实心圆.效果如图1所示. 图1 这个程序的核心是画布,也就是Canvas对象.要想在Canvas上绘制 ...
- python画实心圆_OpenCV python 绘制随机实心圆
OpenCV python 绘制随机实心圆 import numpy as np import cv2 def main(): # 1.创建白色背景图片 d = 400 img = np.ones(( ...
- python实心点怎么画_python 绘制随机实心圆,保存标签
import numpy as np import cv2 import os def main(): ann_images = 'D:/University/Data/images/' ann_sa ...
- OpenCV3实现人脸识别(一)——基于OpenCV3级联分类器实现人脸检测与眼睛检测
前言 1.OpenCV官方训练好的人脸和眼睛的级联分类器,3.30的版本都放在opencv\sources\data这个文件夹下,在OpenCV这个文件夹中,主要有 Haar特征 和 LBP特征进行人 ...
- 用php绘制空心圆,html5使用canvas画空心圆与实心圆_html5教程技巧
这里给大家分享的是一个学习canvas的时候做的画空心圆与实心圆的练习题,非常简单. 代码如下: var canvas=document.getElementById("canvas&quo ...
- 人脸系列:人脸检测、人脸关键点定位、人脸优选、人脸对齐、人脸特征提取、人脸跟踪、人脸活体检测
一.一点想法 缘由:最近想整理下从事人脸方向的所有查阅过的论文,做过的相关实验,因为随着时间的推移,自己总会遗忘当初的一些想法,所以想好好整理下自己的学习笔记. 过程:本系列包括从人脸检测.人脸关键点 ...
- 基于opencv-python的人脸识别、眼睛识别和微笑识别
目录 前言 1.1 静态识别 1.1.1 原始图像展示 1.1.2 代码 1.1.3 识别效果展示 1.2 动态识别 1.2.1 代码 1.2.2 识别效果展示 前言 开源一个小项目,关于人脸识别,眼 ...
- 使用亚博智能K210实现人脸特征提取和识别
使用亚博智能K210实现人脸特征提取和识别 亚博智能K210开发板自带有使用C语言编程实现的人脸检测代码,即可以检测到摄像头范围内的人脸并将人脸框定出来,不能实现人脸的特征提取和人脸的识别.因此,我们 ...
- android人脸特征提取,基于人脸检测和特征提取的移动人像采集系统
摘要: 目前公安部门使用的人脸识别系统大多属于台式设备和专业器材,而且是在成像条件相对较好,取得被拍照人员良好配合的情况下进行人像采集,软件算法针对的是约束条件下采集得到的人像照片.但是,公安警务还涉 ...
最新文章
- Lintcode18 Subsets II solution 题解
- 【已解决】Navicat 远程连接 Linux服务器上的MySQL数据库
- Excel单因素方差分析
- 312. Burst Balloons 戳气球
- 那些年职场老鸟都踩过哪些坑?送给后来人的一些职场建议
- java hashmap 常用方法_Java的HashMap中的常用方法总结
- STL vector用法介绍
- 使用Maven搭建Struts2框架的开发环境
- Spring-Data-Redis存储对象(redisTemplate)
- 【优化算法】可变步长LMS算法(VSS-LMS)【含Matlab源码 317期】
- 怎么解决IPA processing failed错误, 用xcode 11打包
- 4.16 期货每日早盘操作建议
- box2d的角色邹形
- 认识SlackwareLinux及制作系统安装磁片之关於bootdisk(转)
- python lisp_给Lisp程序员的Python简介
- IBL-镜面反射(预滤波篇)
- 【冰点】:重庆“高烧”不退
- DataBinding详解
- 基于 node.js 的校园交流平台的设计与实现(word文档)
- chromium 调试之inspect--调试网页数据资源加载过程