PCA检测人脸的简单示例_matlab实现
来源:互联网 发布:ubuntu 14.04 需求 编辑:程序博客网 时间:2024/05/21 09:16
%训练%Lx=X'*Xclear;clc;train_path='..\Data\TrainingSet\';phi=zeros(64*64,20);for i=1:20path=strcat(train_path,num2str(i),'.bmp');Image=imread(path);Image=imresize(Image,[64,64]);phi(:,i)=double(reshape(Image,1,[])');end;%meanmean_phi=mean(phi,2);mean_face=reshape(mean_phi,64,64);Image_mean=mat2gray(mean_face);imwrite(Image_mean,'meanface.bmp','bmp');%demeanfor i=1:19X(:,i)=phi(:,i)-mean_phi;endLx=X'*X;tic;[eigenvector,eigenvalue]=eigs(Lx,19);toc;%normalizationfor i=1:19%K-L变换UL(:,i)=X*eigenvector(:,i)/sqrt(eigenvalue(i,i));end%display Eigenfacefor i=1:19Eigenface=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:4path=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 ratee=Face_re-phi_test;%%display figureFace_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 rateerror_rate=error(1,i);display(error_rate);end重建出的测试样本与原样本的对比:
四副测试样本的重建误差分别为:
1.4195e+003
1.9564e+003
4.7337e+003
7.0103e+003
可见测试样本为人脸的样本的重建误差显然小于非人脸的重建误差。
- PCA检测人脸的简单示例_matlab实现
- PCA检测人脸的简单示例_matlab实现
- PCA检测人脸的简单示例_matlab实现
- 【模式识别】PCA检测人脸的简单示例MATLAB实现
- 基于PCA的人脸识别_Matlab实现(个人研读之后的一些总结)
- PCA应用---检测人脸的简单示例 (MATLAB版)
- 边缘检测算子_Matlab
- 基于PCA的人脸检测(Matlab版代码)
- PCA人脸识别的python实现
- 基于PCA简单的人脸识别opencv实现-图像处理学习笔记
- PCA的应用示例
- 简单理解基于PCA的人脸识别
- 【OpenCV】简单的Python实现人脸检测
- 神经网络_Matlab中BP神经网络算法的实现
- Yale人脸数据库、PCA算法实现Matlab中特征脸生成和简单的人脸识别
- PCA的简单理解
- PCA的简单理解
- 基于PCA的人脸识别的Matlab实现代码
- 杭电 1431 素数回文
- 第五周实验报告(4)
- (2012.03.22) 杂想_最近的事情_心绪有点乱
- S3C2440
- wait and notify 例子(yield/join)
- PCA检测人脸的简单示例_matlab实现
- pthread_create如何传递多个参数
- spring+ibatis
- 了解设计模式
- IE主页被自动修改,无法编辑注册表Start Page
- S3C2440 汇编指令
- java线程的简单例子(Thread and runnable)
- 安装示例数据库时找不到Installation Instance
- S3C2440中断跳转分析