首页 技术 正文
技术 2022年11月15日
0 收藏 700 点赞 3,604 浏览 2075 个字

本文由兔崩溃公布http://blog.csdn.net/smartempire/article/details/31373817。

转载请注明出处。howdeshui#163.com

近期在做三维人脸识别相关的东西,在已获取三维数据的情况下进行人脸的识别分割是第一步。本文将介绍预处理内的几个操作,终于给出分割后的三维人脸数据以及经过变换的灰度图像。

作者之前申请了国内的三维人脸数据库都没申请到,FRGC v2库也没有回复,仅仅申请到了一个很小众的库。此库重点是研究有遮挡情况下的三维人脸识别,所以不太符合后面要做表情变化研究。

1、填洞插值操作

扫描得到的数据可能会有一些洞。例如以下图的眼睛眉毛等部分,所以须要採用cubic等方式进行插值,并且脸部会有称为spike的凸起。这个在后面切割出人脸后会进行消除。

须要注意的是,原始数据的x,y轴上的坐标并非等间距的。所以在插值后须要进行重採样,使得x,y轴上为等间距。

原始三维数据

2、图像插值重採样

之所以会有这一步,是由于三维数据经过插值重採样之后与二维图像的像素点已经不是一一相应的关系了,所以为了接下来的人脸区域检測等操作须要类似的重採样。原始图像与插值重採样后的图分别例如以下:

原始RGB图像重採样图像

你可能会问原始图像是彩色的,重採样后为毛变成灰度的了,没办法,RGB图像有三个分量,插值与採样我实在不知道该怎么在三个分量上进行。假设在每一个分量上进行得到的图像简直才不忍赌。

3、鼻尖点检測

这是关键的一步,由于以鼻尖点为中心做80mm的圆球就能将人脸分割出来,所以这一步的准确性非常关键。

在一些论文里是这么做的,将三维数据做横向的切片称为slice,在鼻尖点处的slice基本例如以下图。假设以每一点为圆心做圆。假设圆的半径合适(比方30mm),那么圆心与交点会形成一个三角形并且这个三角形的高(altitude)是最大的。通过这种方式基本能够确定鼻尖点。可是假设仅仅是这么做会发现有些衣服如衣领等会形成误操作。所以能够先在灰度图像上检測人脸区域,在这个区域取slice能够基本消除误測。

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvc21hcnRlbXBpcmU=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast” alt=””>

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvc21hcnRlbXBpcmU=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast” alt=”” style=”font-family:’Microsoft YaHei'”>

鼻尖点检測示意图鼻尖点(图中黑点)

3、提取人脸部分

在第2步得到nose tip 后,以该点做圆球。以80mm(视情况而定)做半径,落在圆球内的三维点即为人脸点。

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvc21hcnRlbXBpcmU=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast” alt=””>

4、降噪、去spike操作

Spike主要是一些毛刺。能够定义该点到8-neighbor的距离作为推断根据,假设距离超过某个阈值则能够把该点抹成0然后又一次採样,或者直接抹成8-neighbor的均值或者中值。降噪主要针对脸部凹凸不平的情况,作者測试了中值和均值滤波器,可是效果并不明显,也许是由于前期已经重採样的原因。下图是得到的人脸,貌似和第三部的结果没有差别。

5、姿态矫正

有些人脸可能会有旋转平移的情况。这一步将对姿态进行矫粗方便兴许的ICP等方法的对齐,矫正用到的方法是Hotelling transform。在之前的博文里介绍过了,不再赘述。结果例如以下图,因为博主本来选择的数据就是姿态不明显的,所以矫正的结果并不明显。

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvc21hcnRlbXBpcmU=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast” alt=””>

以上就是预处理的几步。没有涉及到复杂的算法实现,仅仅是实现起来比較琐碎,像nose tip的检測要推断圆与slice的交点,要由粗到细的取slice的间隔以节省CPU时间。所以实现起来比較费时。之前上传的人脸识别的demo即使是免费的也还是有人发牢骚。所以本文的MATLAB代码就不再免费发布了。假设有须要能够联系我howdeshui#163.com。

版权声明:本文博客原创文章,博客,未经同意,不得转载。

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,162
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,628
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,474
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,247
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,883
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,050