Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >Python 进行人脸校正

Python 进行人脸校正

作者头像
caoqi95
发布于 2019-03-28 04:05:36
发布于 2019-03-28 04:05:36
2.6K00
代码可运行
举报
运行总次数:0
代码可运行

已同步:博客 | 公众号 | 语雀

问题描述

在做人脸识别的时候,前期的数据处理过程中可能会遇到一个问题,即将人脸从不同尺寸的图像中截取出来,再进行“对齐”操作。这样可以使每一个截取的人脸中的眼睛等位置处于同一位置,会对后面的识别算法起到一定的优化作用。

比如,下面 3 张图片所示,人脸的位置,图像的大小各不一样。我们所需要做的就是,将人脸从各个图片中截取出来,再旋转进行校正,使得眼睛在同一位置上,最后将图片的大小也统一调整为 224 x 224。

校正的效果如下图所示:

实现步骤

前提:已经提取出每张图片里眼睛的坐标,只需要读取数据就行

整个过程遵循以下几个步骤:

  • 找两眼间的直线距离并计算该直线与水平线之间的夹角,即倾斜角度
  • 根据找到的倾斜角度旋转图片
  • 在旋转后的图片中找到眼睛的位置
  • 根据眼睛坐标找到包含面部的框的宽度和高度
  • 调整图片的尺寸
1. 计算直线距离及倾斜角度

计算两眼之间的距离很简单,只要找出两个向量的坐标就可以计算出来。计算两眼之间的距离直线的倾斜角度,就是将两个向量相减,得到一组横纵坐标,然后利用 arctan 的公式求解角度,公式如下所示:

大多数 sin / cos 等函数要求角度为弧度,可以使用这个转换公式:angle = angle * 180 / π。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
"""
1.找到眼睛倾斜的角度和两眼距离
"""
p1 = np.array(eye[0])[::-1] # 左眼坐标
p2 = np.array(eye[1])[::-1] # 右眼坐标
dist = np.sqrt(np.sum(p1-p2)**2) # 两只眼睛之间的距离

dp = p1 - p2
angle = np.arctan(dp[0] / dp[1])
2. 根据找到的角度旋转图片

上一步骤中,求出了眼睛的倾斜角度,这一步就可以使用该角度来旋转图片了。这里方便地调用 scipy.ndimage.rotate 来旋转图片。之后再计算出旋转后图片的中点。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
"""
2. 旋转图片
"""
from scipy import ndimage

# 旋转图片
rot_img = ndimage.rotate(face, angle=+angle*180/np.pi)
# 旋转后图像的中点
rot_image_center = np.array((np.array(rot_img.shape[:2]) - 1) / 2, 
dtype=np.int)
3. 寻找旋转后眼睛的位置

寻找旋转后眼睛的位置,就是寻找旋转后两个点的坐标。旋转的时候,我们是以图片中点为原点来旋转的,因而需要先求解出原图片的原点,也就是图片的中心点。下面是以原点 (x0, y0) 为中心旋转后,求坐标的公式:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
"""
3. 在旋转后的图片中找到眼睛的坐标
"""

# 原两眼距离的中点
org_eye_center = np.array((p1 + p2) / 2, dtype=np.int)
# 原图像的中点
org_image_center = np.array((np.array(face.shape[:2]) - 1) / 2, dtype=np.int)
# 以图片中心进行旋转,在旋转后的图片中找到眼睛的中点
R = np.array([[np.cos(angle), np.sin(angle)], [-np.sin(angle), np.cos(angle)]])
rot_eye_center = np.dot(R, org_eye_center[::-1]
                        -org_image_center[::-1])[::-1] + rot_image_center
rot_eye_center = np.array(rot_eye_center, dtype=int)
4. 根据眼睛坐标找到包含面部的框的宽度和高度

找到旋转后眼睛的坐标,可以利用眼睛的坐标来框出人脸的大致范围。这里就直接看代码,从代码中比较好理解。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
"""
4. 根据眼睛坐标找到包含面部的框的宽度和高度
"""
mid_y, mid_x = rot_eye_center
    
MUL = 2
y_top = int(max(mid_y - MUL * dist, 0))
y_bot = int(min(mid_y + MUL * dist, rot_img.shape[0]))
x_left = int(max(mid_x - MUL * dist, 0))
x_right = int(min(mid_x + MUL * dist, rot_img.shape[1]))
    
cropped_img = rot_img[y_top:y_bot+1, x_left:x_right+1, :]
5. 裁剪图片

将旋转并框出的人脸进行裁剪,将其设定为统一的尺寸。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
"""
5. 裁剪图像的尺寸为 224x224
"""
import skimage.transform as transform

scaled_img = transform.resize(cropped_img, [224, 224], mode='constant')
plt.imshow(scaled_img)

完整的代码链接:face-alignment

参考文献

[1]. Coursera - Deep Learning in Computer Vision Week 1 assigment [2]. 图像旋转的原理,实现与优化 [3]. Rotated image coordinates after scipy.ndimage.interpolation.rotate?

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019.02.22 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
人脸姿态校正算法 附完整C++示例代码
那么假如一张图片只有一个人脸,其实很好判断,通过眼睛的位置的坐标,根据两眼的直线角度,
cpuimage
2018/05/08
2.7K14
人脸姿态校正算法 附完整C++示例代码
目标检测图像数据增强(Data Augmentation)—— 旋转
由于业务需求,需要对部分不符合检测结果的图像进行过滤,因此需要对之前的检测项目进行优化。常见问题有如下亮点:
用户3578099
2019/08/15
1.2K0
使用Pytorch和OpenCV实现视频人脸替换
“DeepFaceLab”项目已经发布了很长时间了,作为研究的目的,本文将介绍他的原理,并使用Pytorch和OpenCV创建一个简化版本。
deephub
2023/08/30
5800
使用Pytorch和OpenCV实现视频人脸替换
快速照片扫描方法记录
因为不太清楚photoshop有自动裁切的功能,所以我最开始花了一个小时多写了一个小程序帮我自动裁切扫描出来的影像的白边。
HomeboyC
2022/09/19
5340
快速照片扫描方法记录
人脸识别系统的原理与实现:PNET训练数据预处理2
上一节我们详细说明了如何为PNET生成用于训练的人脸图片,本节我们需要将上一节分割出的人脸图片存储成文件,相关代码如下:
望月从良
2021/01/02
6450
人脸识别系统的原理与实现:PNET训练数据预处理2
使用这个 Python 库,只需一行命令,给头像戴上口罩!
2019 年底开始蔓延的新型肺炎疫情牵动人心,作为个体,我们力所能及的就是尽量待在家中少出门。
Python猫
2020/02/19
5190
基于 OpenCV 和 Dlib 头部姿态评估简单Demo
庐山烟雨浙江潮,未到千般恨不消。到得还来别无事,庐山烟雨浙江潮。 ----《庐山烟雨浙江潮》苏轼
山河已无恙
2023/08/21
6960
基于 OpenCV 和 Dlib 头部姿态评估简单Demo
如何用OpenCV进行人脸疲劳检测--基于米尔瑞芯微RK3576开发板
本文将介绍基于米尔电子MYD-LR3576开发板(米尔基于瑞芯微 RK3576开发板)的人脸疲劳检测方案测试。
用户10591265
2024/12/19
1450
如何用OpenCV进行人脸疲劳检测--基于米尔瑞芯微RK3576开发板
昇腾AI行业案例(一):基于AI图像处理的疲劳驾驶检测
欢迎学习《昇腾行业应用案例》的“基于AI图像处理的疲劳驾驶检测”实验。在本实验中,您将学习如何使用利用CV(Computer Vision)领域的AI模型来构建一个端到端的疲劳驾驶检测系统,并使用开源数据集进行效果验证。为此,我们将使用昇腾的AI硬件以及CANN等软件产品。
AI布道Mr.Jin_2025
2025/01/15
2150
Part3-1.获取高质量的阿姆斯特丹建筑立面图像(附完整代码)
本文为《通过深度学习了解建筑年代和风格》论文复现的第三部分——获取阿姆斯特丹高质量街景图像的上篇,主要讲了如何获取利用谷歌街景地图自动化获取用于深度学习的阿姆斯特丹的高质量街景图像,此数据集将用于进行建筑年代的模型训练[1]。
renhai
2023/11/24
7440
Part3-1.获取高质量的阿姆斯特丹建筑立面图像(附完整代码)
Python OpenCV 蓝图:6~7
先前我们已经研究了如何通过关键点和特征来描述对象,以及如何在同一物理对象的两个不同图像中找到对应点。 但是,在识别现实环境中的对象并将其分配给概念类别时,我们以前的方法相当有限。 例如,在第 2 章“使用 Kinect 深度传感器进行手势识别”,图像中所需的对象是手,必须将屏幕很好地放置在手掌的中央。 如果我们可以取消这些限制,那岂不是很好吗?
ApacheCN_飞龙
2023/04/27
1.9K0
Python OpenCV 蓝图:6~7
Python实现疲劳驾驶困倦低头检测
部分代码: def get_head_pose(shape): # 头部姿态估计 # (像素坐标集合)填写2D参考点 # 17左眉左上角/21左眉右角/22右眉左上角/26右眉右上角/36左眼左上角/39左眼右上角/42右眼左上角/ # 45右眼右上角/31鼻子左上角/35鼻子右上角/48左上角/54嘴右上角/57嘴中央下角/8下巴角 image_pts = np.float32([shape[17], shape[21], shape[22], shape[26], sh
用户8544541
2022/04/19
5920
视觉进阶 | Numpy和OpenCV中的图像几何变换
上面的图像使它不言而喻什么是几何变换。它是一种应用广泛的图像处理技术。例如,在计算机图形学中有一个简单的用例,用于在较小或较大的屏幕上显示图形内容时简单地重新缩放图形内容。
小白学视觉
2020/02/27
2.3K0
【单目测距】3D检测框测距
(1) 横向测距偏差。当目标有一定倾斜角度时,尤其近距离目标。如下图id = 0目标白车,如果是2D检测框测距,会误认为车尾在点 A 处,而实际应该在图像最左侧外部
读书猿
2024/02/05
3010
【单目测距】3D检测框测距
基于Adaboost算法的人脸检测分类器
人脸检测属于计算机视觉的范畴,早期人们的主要研究方向是人脸识别,即根据人脸来识别人物的身份,后来在复杂背景下的人脸检测需求越来越大,人脸检测也逐渐作为一个单独的研究方向发展起来。
Datawhale
2020/07/14
2K0
如何用Python实现神奇切图算法seam carving?
我们把时钟拨到 11 年前,2007 年,在第 34 届 SIGGRAPH 2007 数字图形学年会上,以色列的两位教授 Shai Avidan 和 Ariel Shamir 展示了一种新的缩放裁剪图像方法,他们称之为 Seam Carving for Content-Aware Image Resizing,也就是我们后来所说的“接缝剪裁”(Seam Carving)算法。
一墨编程学习
2018/12/07
2.2K0
【OpenCV】Chapter10.色彩转换与图像绘制
常见的色彩空间包括:GRAY 色彩空间(灰度图像)、XYZ 色彩空间、YCrCb 色彩空间、HSV 色彩空间、HLS 色彩空间、CIELab 色彩空间、CIELuv 色彩空间、Bayer 色彩空间等。
zstar
2022/09/28
2.7K0
【OpenCV】Chapter10.色彩转换与图像绘制
前端机器学习--识别人脸在脸颊上画草莓
当然,我们仅仅是使用人脸识别,那有人已经在TensorFlow的基础上封装了专门针对人脸识别的库 face-api.js
从入门到进错门
2020/01/02
6690
基于OpenCV的人脸追踪
云台HAT的选择是非常重要的。因为我们必须找到一种控制Pan-Tilt HAT的方法。我们使用的是Waveshare的Pan-Tilt HAT,小伙伴们可能需要花费一些时间来了解如何通过键盘或者通过HAT手动控制伺服电机。USB-C输出的电池对于Raspberry上的项目(其中Raspberry必须是可移动的)非常有用。
小白学视觉
2020/12/07
1.3K0
基于OpenCV的人脸追踪
OpenCV实现人脸对齐
OpenCV实现人脸对齐 一:人脸对齐介绍 在人脸识别中有一个重要的预处理步骤-人脸对齐,该操作可以大幅度提高人脸识别的准确率与稳定性,但是早期的OpenCV版本不支持人脸Landmark检测,因此一
OpenCV学堂
2018/04/24
4.3K2
OpenCV实现人脸对齐
推荐阅读
相关推荐
人脸姿态校正算法 附完整C++示例代码
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验