人脸对齐matlab实现-FaceAlignment 3000fps
前言
最近研读了孙剑团队的Face Alignment at 3000fps via Regressing Local Binary Features这篇paper,基于matlab进行实现。
实现原理:
包含训练和测试两个阶段;
1.基于标准随机森林回归算法独立地学习每个特征点的局部二值特征,连接形成每张图像的特征;
2.基于双坐标下降法学习全局线性回归;
论文下载:
http://www.jiansun.org/papers/CVPR14_FaceAlignment.pdf
matlab实现步骤:
1.源代码地址(含有实现方法的英文说明):
https://github.com/jwyang/face-alignment
2.环境:
官方:win64 + matlab2014a;
个人:win64 + matlab2014b;
3.下载数据库:
数据库下载网址:http://ibug.doc.ic.ac.uk/resources/facial-point-annotations
可以下载需要的样本库,不过发现300W四个文件夹中的数据完全一样;
4.配置训练样本函数的依赖库liblinear.
从网址http://www.csie.ntu.edu.tw/~cjlin/liblinear/可以直接下载liblinear库文件.
如果系统是windows64可以直接将里边windows文件夹中的文件全部拷贝到创建的matlab工程目录下;
5.准备数据.
将数据库解压到工程目录新建的datasets文件夹中,细节可参见train_model.m文件.
6.train_model.m文件中代码表示读入的训练样本数据的文件是Path_Image.txt,所以进入cmd控制台change目录到datasets文件夹中的一个数据库中,比如.\afw,然后输入命令dir /b/s/p/w *.jpg>Path_Images.txt,这是将所有jpg格式的文件名都输入到Path_Images.txt文件中,其他数据库文件的获取类似,注意图片格式和路径即可.
7.训练样本库.
1)在matlab工程目录下创建一个m文件,命名为train_3000fps.m;
filepath_ranf = './ranf.mat';
filepath_ws = './ws.mat';
lbfmodel = train_model_func({ 'afw' });
ranf = lbfmodel.ranf;
ws = lbfmodel.Ws;
save(filepath_ranf, 'ranf');
save(filepath_ws, 'ws');
2)基于train_model.m重新生成train_model_func.m的函数形式;
二者的主体内容完全一样,train_model_func.m只需要在函数开始部分添加一行函数头即可;
function LBFRegModel = train_model_func( dbnames )
然后执行train_3000fps.m文件开始进行训练,训练时间可能会比较长,训练完成之后会得到ranf.mat和ws.mat两个文件.
8.测试结果.
按照步骤6的方法生成要进行测试的数据库的Path_Image.txt文件,然后在matlab工程目录下创建test_3000fps.m文件,
filepath_ranf='./ranf.mat';
filepath_ws='./ws.mat'; r=load(filepath_ranf);
w=load(filepath_ws);
ranf=r.ranf;
ws=w.ws;
t.ranf=ranf;
t.Ws=ws; test_model_func({'ibug'},t);
同时基于test_model.m重新生成test_model_func.m文件,参考步骤7所示,
function test_model_func( dbnames, LBFRegModel )
执行test_3000fps.m文件即可完成测试过程.
9.测试结果的显示;
将测试文件改写为如下,其中文件路径和名称可按照自己的想法进行设置;
filepath_ranf='./ranf.mat';
filepath_ws='./ws.mat'; r=load(filepath_ranf);
w=load(filepath_ws);
ranf=r.ranf;
ws=w.ws;
t.ranf=ranf;
t.Ws=ws; % test_model_func({'ibug'},t);
% %查看结果
[predshapes, Data] = test_model_func({'ibug'}, t);
[X, Y, N] = size( predshapes );
for i=1:N
shapes=predshapes(:,:,i);
img=Data{i}.img_gray;
%drawshapes(img, [shapes,Data{i}.shape_gt]);
drawshapes(img, Data{i}.shape_gt);
rectangle('Position', Data{i}.bbox_facedet, 'EdgeColor', 'b');
name = ['.\ibug\', int2str(i),'_1'];
print(gcf, '-dpng', name);
hold off;
% pause;
end
需要改写以下几处:
1)测试文件的test_model_func.m文件;
function [predshapes, Data] = test_model_func( dbnames, LBFRegModel )
2)test_model_func.m文件中调用globalprediction函数部分的输出格式作出一些修改;
[Data, predshapes] = globalprediction(binfeatures, Ws{min(s, params.max_numstage)}, Data, Param, min(s, params.max_numstage));
3)修改globalprediction.m文件的函数头;
%function Te_Data = globalprediction(binaryfeatures, W, Te_Data, params, stage)
function [Te_Data, predshapes] = globalprediction(binaryfeatures, W, Te_Data, params, stage)
另外,可以更改drawshapes.m文件,得到你想要的显示类型。
实现结果
基于matlab按照以上步骤实现,速度没有论文中的3000fps那么快,当然也可能是系统优化等方面的问题,精度相比sdm稍逊一些;
另外,针对红外图像的landmarks,与一般图像相比,SDM的效果没差,但是LBF的效果就差一些;
接下来也会实现c++版本,测试一下效果;
参考
1.http://blog.csdn.net/wangjian8006/article/details/42004717
2.GitHub:https://github.com/jwyang/face-alignment
3.http://blog.csdn.net/xiamentingtao/article/details/50821972
4.大牛博客
完
人脸对齐matlab实现-FaceAlignment 3000fps的更多相关文章
- 机器学习--详解人脸对齐算法SDM-LBF
引自:http://blog.csdn.net/taily_duan/article/details/54584040 人脸对齐之SDM(Supervised Descent Method) 人脸对齐 ...
- MTCNN算法与代码理解—人脸检测和人脸对齐联合学习
目录 写在前面 算法Pipeline详解 如何训练 损失函数 训练数据准备 多任务学习与在线困难样本挖掘 预测过程 参考 博客:blog.shinelee.me | 博客园 | CSDN 写在前面 主 ...
- 机器学习----人脸对齐的算法-ASM.AAM..CLM.SDM
引自:http://blog.csdn.net/linolzhang/article/details/55271815 人脸检测 早已比较成熟,传统的基于HOG+线性分类器 的方案检测效果已经相当不错 ...
- 人脸对齐SDM原理----Supervised Descent Method and its Applications to Face Alignment
最近组里研究了SDM算法在人脸对齐中的应用,是CMU的论文<Supervised Descent Method and its Applications to Face Alignment> ...
- MTCNN(Multi-task convolutional neural networks)人脸对齐
MTCNN(Multi-task convolutional neural networks)人脸对齐 .
- 基于Landmark的人脸对齐以及裁剪方法
利用Landmarks进行人脸对齐裁剪是人脸检测中重要的一个步骤.效果如下图所示: 基本思路为: a.人脸检测 人脸的检测不必多说了,基本Cascade的方式已经很不错了,或者用基于HOG/FHOG的 ...
- 揭秘人脸对齐之3D变换-Java版(文末赋开源地址)
一.人脸对齐基本概念 人脸对齐通过人脸关键点检测得到人脸的关键点坐标,然后根据人脸的关键点坐标调整人脸的角度,使人脸对齐,由于输入图像的尺寸是大小不一的,人脸区域大小也不相同,角度不一样,所以要通过坐 ...
- 人脸对齐ASM-AAM-CLM的一些总结
源地址:http://blog.csdn.net/piaomiaoju/article/details/8918107 ASM算法相对容易,其中STASM是目前正面脸当中比较好的算法,原作者和CLM比 ...
- python AI换脸 用普氏分析法(Procrustes Analysis)实现人脸对齐
1.图片效果 2.原代码 # !/usr/bin/python # -*- coding: utf-8 -*- # Copyright (c) 2015 Matthew Earl # # Permis ...
随机推荐
- Lua中模块初识
定义了两个文件: Module.lua 和 main.lua 其中,模块的概念,使得Lua工程有了程序主入口的概念,其中main.lua就是用来充当程序主入口的. 工程截图如下: Module.lua ...
- eclipse 里,打开的文件的各个标签,标题乱码。
Eclipse Mars 版本有这个问题. 提交到社区了,也还是没有人回答.Eclipse看来是没落了. https://www.eclipse.org/forums/index.php/t/1072 ...
- ArcGIS API for Silverlight——小滑块
Widgets翻译过来是小玩具.如果使用过Dojo或者ExtJS等js框架肯定会了解到这个“小玩具”也有大用处,能够在很大程度上减少我们的工作量,快速完成功能需求.能减少多大工作量呢?让我们先来,点击 ...
- 20170813pptVBA批量插入图片
Sub AddSldIn() Dim Pre As Presentation Dim NewSld As Slide Set Pre = Application.ActivePresentation ...
- spojPlay on Words
题意:给出几个词语,问能不能接龙. 一开始猜只要所有字母连通,并且只有一个字母出现在开头次数为奇,一个字母末尾为奇,其它偶,就行.后来发现全为偶也行.而且条件也不对,比如ac,ac,ac就不行.实际上 ...
- linux进程原语之fork()
一.用法解析: fork()这个函数,可以说是名如其人了,众所周知fork这个单词本意为叉子,老外取学术名字的时候总会有一些象形的想法,于是就有了下图~ fork()函数是计算机程序设计中的分叉函数. ...
- windows下进程与线程剖析
进程与线程的解析 进程:一个正在运行的程序的实例,由两部分组成: 1.一个内核对象,操作系统用它来管理进程.内核对象也是系统保存进程统计信息的地方. 2.一个地址空间,其中包含所有可执行文件或DLL模 ...
- nyoj 1238(BFSor最短路)
最少换乘 时间限制:2000 ms | 内存限制:65535 KB 难度:3 描述 欧洲某城是一个著名的旅游胜地,每年都有成千上万的人前来观光旅行.Dr. Kong决定利用暑假好好游览一番.. ...
- Oracle解析复杂json的方法(转)
转:Oracle解析复杂json的方法 问题背景: 当前在Oracle数据库(11G之前的版本)解析json没有可以直接使用的系统方法,网上流传的PLSQL脚本大多也只可以解析结构较单一的json串, ...
- OC ARC之循环引用问题(代码分析)
// // main.m // 03-arc-循环引用 // // Created by apple on 13-8-11. // Copyright (c) 2013年 itcast. All ri ...