Advertisement
manageryzy

pca_face

Oct 3rd, 2015
120
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
MatLab 3.00 KB | None | 0 0
  1. %一个修改后的PCA进行人脸识别的Matlab代码
  2.  
  3. clear;
  4.  
  5. % calc xmean,sigma and its eigen decomposition
  6.  
  7. allsamples=[];%所有训练图像
  8.  
  9. for i=1:40
  10.  
  11.     for j=1:5
  12.  
  13.       a=imread(strcat('C:\Documents and Settings\Foreigners\桌面\ORL\s',num2str(i),'\',num2str(j),'.bmp'));
  14.  
  15.       % imshow(a);
  16.  
  17.       b=a(1:112*92); % b是行矢量 1×N,其中N=10304,提取顺序是先列后行,即从上到下,从左到右
  18.  
  19.       b=double(b);
  20.  
  21.       allsamples=[allsamples; b];  % allsamples 是一个M * N 矩阵,allsamples 中每一行数据代表一张图片,其中M=200
  22.  
  23.   end
  24.  
  25. end
  26.  
  27. samplemean=mean(allsamples); % 平均图片,1 × N
  28.  
  29. for i=1:200 xmean(i,:)=allsamples(i,:)-samplemean; % xmean是一个M × N矩阵,xmean每一行保存的数据是“每个图片数据-平均图片”
  30.  
  31. end;
  32.  
  33.  
  34.  
  35. sigma=xmean*xmean';   % M * M 阶矩阵
  36.  
  37. [v d]=eig(sigma);
  38.  
  39. d1=diag(d);
  40.  
  41. [d2 index]=sort(d1); %以升序排序
  42.  
  43. cols=size(v,2);% 特征向量矩阵的列数
  44.  
  45. for i=1:cols
  46.  
  47.     vsort(:,i) = v(:, index(cols-i+1) ); % vsort 是一个M*col(注:col一般等于M)阶矩阵,保存的是按降序排列的特征向量,每一列构成一个特征向量
  48.  
  49.     dsort(i)   = d1( index(cols-i+1) );  % dsort 保存的是按降序排列的特征值,是一维行向量
  50.  
  51. end  %完成降序排列
  52.  
  53. %以下选择90%的能量
  54.  
  55. dsum = sum(dsort);
  56.  
  57.     dsum_extract = 0;
  58.  
  59.     p = 0;
  60.  
  61.     while( dsum_extract/dsum < 0.90)
  62.  
  63.         p = p + 1;
  64.  
  65.         dsum_extract = sum(dsort(1:p));
  66.  
  67.     end
  68.  
  69. i=1;
  70.  
  71. % (训练阶段)计算特征脸形成的坐标系
  72.  
  73. while (i<=p && dsort(i)>0)
  74.  
  75.     base(:,i) = dsort(i)^(-1/2) * xmean' * vsort(:,i);   % base是N×p阶矩阵,除以dsort(i)^(1/2)是对人脸图像的标准化,详见《基于PCA的人脸识别算法研究》p31
  76.  
  77.     i = i + 1;
  78.  
  79. end
  80.  
  81.  
  82.  
  83. % add by wolfsky 就是下面两行代码,将训练样本对坐标系上进行投影,得到一个 M*p 阶矩阵allcoor
  84.  
  85. allcoor = allsamples * base;
  86.  
  87. accu = 0;
  88.  
  89.  
  90.  
  91. % 测试过程
  92.  
  93. for i=1:40
  94.  
  95.     for j=6:10 %读入40 x 5 副测试图像
  96.  
  97.         a=imread(strcat('C:\Documents and Settings\Foreigners\桌面\ORL\s',num2str(i),'\',num2str(j),'.bmp'));
  98.  
  99.         b=a(1:10304);
  100.  
  101.         b=double(b);
  102.  
  103.         tcoor= b * base; %计算坐标,是1×p阶矩阵
  104.  
  105.         for k=1:200
  106.  
  107.                 mdist(k)=norm(tcoor-allcoor(k,:));
  108.  
  109.         end;
  110.  
  111.         %三阶近邻
  112.  
  113.          
  114.  
  115.         [dist,index2]=sort(mdist);
  116.  
  117.         class1=floor( index2(1)/5 )+1;
  118.  
  119.         class2=floor(index2(2)/5)+1;
  120.  
  121.         class3=floor(index2(3)/5)+1;
  122.  
  123.         %class=class1;%%blue_lg
  124.  
  125.         if class1~=class2 && class2~=class3
  126.  
  127.             class="class1";
  128.  
  129.         elseif class1==class2
  130.  
  131.             class="class1";
  132.  
  133.             %elseif class2==class3
  134.  
  135.           %  class="class2";
  136.  
  137.         end;
  138.  
  139.         if class==i
  140.  
  141.             accu=accu+1;
  142.  
  143.         end;
  144.  
  145.     end;
  146.  
  147. end;
  148.  
  149. accuracy=accu/200 %输出识别率
  150.  
  151. %zuobiao=[1:100];
  152.  
  153. %plot(zuobiao,accuracy);
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement