网站大量收购独家精品文档,联系QQ:2885784924

基于PCA的人脸识别(ORL人脸库)..doc

  1. 1、本文档共6页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
基于PCA的人脸识别(ORL人脸库).

江南大学实验报告 课程名称: 计算机视觉基础 学 院: 物联网工程学院 班 级: 计算机1206 学 号: 1030412612 姓 名: 王成义 同组同学 学号姓名: 付聪+计算机1205+1030412522 实验日期: 2015/5/28 实验名称: PCA人脸识别 . 1、实验目的 1、熟悉人脸识别的方法原理。 2、熟悉特征脸法识别人脸的方法。 3、了解主成分分析在模式识别中的应用。 实验内容/步骤 内容: 1.使用老师提供的人脸库图片(20个人×每人10张图片)。 图片名规则****.bmp, (前2位代表第几个人,后2位代表这个人的第几张图片;例0305.bmp代表第3个人的第5张图片) 2.对于每个人的相片,使用10张中的前7张作为training图片,剩下的3张作为testing图片。 3.利用PCA进行分类识别,给出最后的识别正确率(也即testing图片(20人*3张=60张)有多少张能被正确识别)。 步骤: 将ORL人脸库分成两个库ORL_TRAIN(训练库20*7)和ORL_TEST(测试库20*3)。 将训练库中的图片构造成一个训练集,根据老师所讲的PCA算法原理对训练集进行处理。 对测试图片进行和训练集同过程处理。 用最近邻分类器进行分类。 求出识别率。 实验源程序 3.1、pca_of_wchy_main.m:主函数 function pca_of_wchy_main() %%%%%%%%% 构造训练集 %%%%%%%%%%%%%%%% path=ORL_TRAIN\; File=dir([path,*.bmp]); dsize=length(File); %读取数据库图片数量 pic=zeros(dsize,15*15);% 加载样本图像到 X*(15*15)的矩阵中 for i=1:dsize Image1=imread(strcat(path,File(i).name)); Image2=imresize(Image1,[15,15]); pic(i,:)=double(reshape(Image2,1,[])); end; TrainSamples=pic; smalle = 10.^(-5); % 一个小数字阈值 trsize = size(TrainSamples,2); % 训练样本总数 N x = TrainSamples; xm = mean(x,2); x = x - repmat(xm,1,trsize); % 训练样本及中心化 %%%%%%%%% PCA %%%%%%%%%%%%%%%% [w e explain] = pca_of_wchy(x*x); r = length(find(esmalle)); w = w(:,1:r); e = e(1:r); w = x*w*diag(1./sqrt(e)); % SVD方法求解PCA x0 = w*x; % 将训练样本投影到PCA子空间, 这里,w 即为W_pca %%%%%%%%%%%%%%% 测试 %%%%%%%%%%%%%%%%%%%%% error_recognition=0; right_recognition=0; path_test=ORL_TEST\; File_test=dir([path_test,*.bmp]); dsize_test=length(File_test); %读取数据库图片数量 for i=1:dsize_test Image=imread(strcat(path_test,File_test(i).name)); ImageI=double(imresize(Image,[15,15])); phi_test=zeros(1,15*15); phi_test(1,:)=double(reshape(ImageI,1,[])); TestSamples=phi_test; tesize = size(TestSamples,2); % 测试样本总数 xt0 = w*(TestSamples - repmat(xm,1,tesize)); % 同样地,将测试样本投影到PCA子空间 %%%%%%%%%%%% 用自己写的最近邻分类器进行分类,并计算识别正确和错误的数量 %%%%%%%%%%%%%%%%%% wchy=Min(x0,xt0);%%最近邻分类器函数 Imagess=imread(strcat(path,File(wchy).nam

文档评论(0)

kaiss + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档