• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

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

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

PCA检测人脸的简单示例,matlab R2009b上实现
训练:
训练用的20副人脸:



%训练
%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\');
�mean
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
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

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


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
MATLAB提取人脸轮廓 和 五官发布时间:2022-07-18
下一篇:
matlab如何产生均值为0,方差为1的复高斯分布 - 是晓雨呀发布时间:2022-07-18
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap