PCA检测人脸的简单示例_matlab实现

原创 2012年03月23日 00:06:50
%训练
%Lx=X'*X
clear;
clc;
train_path='..\Data\TrainingSet\';
phi=zeros(64*64,20);
for i=1:20
path=strcat(train_path,num2str(i),'.bmp');
Image=imread(path);
Image=imresize(Image,[64,64]);
phi(:,i)=double(reshape(Image,1,[])');
end;
%mean
mean_phi=mean(phi,2);
mean_face=reshape(mean_phi,64,64);
Image_mean=mat2gray(mean_face);
imwrite(Image_mean,'meanface.bmp','bmp');
%demean
for i=1:19
X(:,i)=phi(:,i)-mean_phi;
end
Lx=X'*X;
tic;
[eigenvector,eigenvalue]=eigs(Lx,19);
toc;
%normalization
for i=1:19
%K-L变换
UL(:,i)=X*eigenvector(:,i)/sqrt(eigenvalue(i,i));
end
%display Eigenface
for i=1:19
Eigenface=reshape(UL(:,i),[64,64]);
figure(i);
imshow(mat2gray(Eigenface));
end

得到的均值图像mean_face:

前19个最大主元对应的“特征脸”

测试
测试用样本:

%使用测试样本进行测试
clc;
test_path='..\Data\TestingSet\';
error=zeros([1,4]);
for i=1:4
path=strcat(test_path,num2str(i),'.bmp');
Image=imread(path);
Image=double(imresize(Image,[64,64]));
phi_test=zeros(64*64,1);
phi_test(:,1)=double(reshape(Image,1,[])');
X_test=phi_test-mean_phi;
Y_test=UL'*X_test;
X_test_re=UL*Y_test;
Face_re=X_test_re+mean_phi;
calculate error rate
e=Face_re-phi_test;


%%display figure
Face_re_2=reshape(Face_re(:,1),[64,64]);
figure(i);

imshow(mat2gray(Image));
title('Original');
figure(10+i);
imshow(mat2gray(Face_re_2));
title('Reconstruct');
error(1,i)=norm(e);

%dispaly error rate
error_rate=error(1,i);
display(error_rate);
end
重建出的测试样本与原样本的对比:

四副测试样本的重建误差分别为:
1.4195e+003
1.9564e+003
4.7337e+003
7.0103e+003

可见测试样本为人脸的样本的重建误差显然小于非人脸的重建误差。


主成分分析(PCA)原理详解

机器学习中有关特征选择的问题,其实就是要剔除和类标签无关的特征,去除噪声或者冗余。在这种情况下,需要一种特征降维的方法来减少特征数,减少噪音和冗余,减少过度拟合的可能性。PCA的思想是将n维特征映射到...

主成分分析(PCA)最大方差解释最小平方误差解释

在这一篇之前的内容是《Factor Analysis》,由于非常理论,打算学完整个课程后再写。在写这篇之前,我阅读了PCA、SVD和LDA。这几个模型相近,却都有自己的特点。本篇打算先介绍PCA,至于...

基于PCA的人脸特征提取及人脸重建

应用背景:我们知道,在特征提取中,主成分分析是一种重要的线性变换方法,这里通过实例来说明主成分分析方法提取人脸特征以及利用这些特征进行人脸重建的过程。...

基于RGB描述的PCA局部人脸重建的实验与局限性

基于RGB描述的PCA局部人脸重建的实验与局限性 原创 学术 笔记 FER PCA 创新项目 机器视觉 *****2012-04-17 12:21:06 privacy:1 ...

PCA实验人脸库-人脸识别(四)

一):人脸数据库 AR人脸库(包含50位男性和50位女性每人26张人脸共2600张人脸图片 ): http://www.datatang.com/data/46195 ORL人脸库(包含40...
  • on2way
  • on2way
  • 2015年01月04日 13:32
  • 5638

PCA人脸识别详解——初学者必看

做人脸识别快3年了,从本科大三到现在研一,看了很多别人的博客,一直忙于学习和研究,今天第一次写个博客,关于“PCA人脸识别的”,打算今后把关于人脸识别的经典方法都在我的博客里面介绍一遍,有机会的话,把...

PCA与奇异值分解用于人脸检测

基于PCA+SVM的人脸识别算法流程: (1)输入训练数据,数据预处理; (2)进行PCA降维; (3)进行多分类的SVM训练(人脸识别为多分类问题,可分为多个二分类SVM分类器); (4)输入检测数...

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

PCA原理及特征脸

PCA 推导 PCA的matlab实现和特征脸这是之前的文章,一直没有誊过来。1. PCA 推导PCA是主成分分析,推导其实很简单。 假设有N维数据M个,组成N*M的矩阵X,希望投射到另一个空间使得...

基于MATLAB,运用PCA+SVM的特征脸方法人脸识别

概述:
  • yb536
  • yb536
  • 2014年10月29日 15:13
  • 13418
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:PCA检测人脸的简单示例_matlab实现
举报原因:
原因补充:

(最多只允许输入30个字)