




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、人臉識別% FaceRec.m% PCA 人臉識別修訂版,識別率88% calc xmean,sigma and its eigen decompositionallsamples=;%所有訓(xùn)練圖像for i=1:40for j=1:5a=imread(strcat('e:ORLs',num2str(i),'',num2str(j),'.jpg');% imshow(a);b=a(1:112*92); % b 是行矢量 1×N,其中N10304,提取順序是先列后行,即從上到下,從左到右b=double(b);allsamples=all
2、samples; b; % allsamples 是一個M * N 矩陣,allsamples 中每一行數(shù)據(jù)代表一張圖片,其中M200endendsamplemean=mean(allsamples); % 平均圖片,1 × Nfor i=1:200 xmean(i,:)=allsamples(i,:)-samplemean; % xmean 是一個M × N 矩陣,xmean每一行保存的數(shù)據(jù)是“每個圖片數(shù)據(jù)-平均圖片”end;% 獲取特征值及特征向量sigma=xmean*xmean' % M * M 階矩陣v d=eig(sigma);d1=diag(d);%
3、按特征值大小以降序排列dsort = flipud(d1);vsort = fliplr(v);%以下選擇90%的能量dsum = sum(dsort);dsum_extract = 0;p = 0;while( dsum_extract/dsum < 0.9)p = p + 1;dsum_extract = sum(dsort(1:p);endi=1;% (訓(xùn)練階段)計算特征臉形成的坐標系base = xmean' * vsort(:,1:p) * diag(dsort(1:p).(-1/2);% base 是N×p 階矩陣,除以dsort(i)(1/2)是對人臉圖像
4、的標準化(使其方差為1)% 詳見基于PCA 的人臉識別算法研究p31% xmean' * vsort(:,i)是小矩陣的特征向量向大矩陣特征向量轉(zhuǎn)換的過程%while (i<=p && dsort(i)>0)% base(:,i) = dsort(i)(-1/2) * xmean' * vsort(:,i); % base 是N×p 階矩陣,除以dsort(i)(1/2)是對人臉圖像的標準化(使其方差為1)% 詳見基于PCA 的人臉識別算法研究p31% i = i + 1; % xmean' * vsort(:,i)是小矩陣的特征向
5、量向大矩陣特征向量轉(zhuǎn)換的過程%end% 以下兩行add by gongxun 將訓(xùn)練樣本對坐標系上進行投影,得到一個 M*p 階矩陣allcoorallcoor = allsamples * base; % allcoor 里面是每張訓(xùn)練人臉圖片在M*p 子空間中的一個點,即在子空間中的組合系數(shù),accu = 0; % 下面的人臉識別過程中就是利用這些組合系數(shù)來進行識別% 測試過程for i=1:40for j=6:10 %讀入40 x 5 副測試圖像a=imread(strcat('e:ORLs',num2str(i),'',num2str(j),'.
6、jpg');b=a(1:10304);b=double(b);tcoor= b * base; %計算坐標,是1×p 階矩陣for k=1:200mdist(k)=norm(tcoor-allcoor(k,:);end;%三階近鄰dist,index2=sort(mdist);class1=floor( (index2(1)-1)/5 )+1;class2=floor(index2(2)-1)/5)+1;class3=floor(index2(3)-1)/5)+1;if class1=class2 && class2=class3class=class1;el
7、seif class1=class2class=class1;elseif class2=class3class=class2;end;if class=iaccu=accu+1;end;end;end;accuracy=accu/200 %輸出識別率特征人臉% eigface.mfunction = eigface()% calc xmean,sigma and its eigen decompositionallsamples=;%所有訓(xùn)練圖像for i=1:40for j=1:5a=imread(strcat('e:ORLs',num2str(i),'',
8、num2str(j),'.jpg');% imshow(a);b=a(1:112*92); % b 是行矢量 1×N,其中N10304,提取順序是先列后行,即從上到下,從左到右b=double(b);allsamples=allsamples; b; % allsamples 是一個M * N 矩陣,allsamples 中每一行數(shù)據(jù)代表一張圖片,其中M200endendsamplemean=mean(allsamples); % 平均圖片,1 × Nfor i=1:200 xmean(i,:)=allsamples(i,:)-samplemean; % x
9、mean 是一個M × N 矩陣,xmean每一行保存的數(shù)據(jù)是“每個圖片數(shù)據(jù)-平均圖片”end;% 獲取特征值及特征向量sigma=xmean*xmean' % M * M 階矩陣v d=eig(sigma);d1=diag(d);% 按特征值大小以降序排列dsort = flipud(d1);vsort = fliplr(v);%以下選擇90%的能量dsum = sum(dsort);dsum_extract = 0;p = 0;while( dsum_extract/dsum < 0.9)p = p + 1;dsum_extract = sum(dsort(1:p)
10、;endp = 199;% (訓(xùn)練階段)計算特征臉形成的坐標系%while (i<=p && dsort(i)>0)% base(:,i) = dsort(i)(-1/2) * xmean' * vsort(:,i); % base 是N×p 階矩陣,除以dsort(i)(1/2)是對人臉圖像的標準化,詳見基于PCA 的人臉識別算法研究p31% i = i + 1; % xmean' * vsort(:,i)是小矩陣的特征向量向大矩陣特征向量轉(zhuǎn)換的過程%endbase = xmean' * vsort(:,1:p) * diag(d
11、sort(1:p).(-1/2);% 生成特征臉for (k=1:p),temp = reshape(base(:,k), 112,92);newpath = 'd:test' int2str(k) '.jpg'imwrite(mat2gray(temp), newpath);endavg = reshape(samplemean, 112,92);imwrite(mat2gray(avg), 'd:testaverage.jpg');% 將模型保存save('e:ORLmodel.mat', 'base',
12、39;samplemean');人臉重建% Reconstruct.mfunction = reconstruct()load e:ORLmodel.mat;% 計算新圖片在特征子空間中的系數(shù)img = 'D:test210.jpg'a=imread(img);b=a(1:112*92); % b 是行矢量 1×N,其中N10304,提取順序是先列后行,即從上到下,從左到右b=double(b);b=b-samplemean;c = b * base; % c 是圖片a 在子空間中的系數(shù), 是1*p 行矢量% 根據(jù)特征系數(shù)及特征臉重建圖% 前15 個t = 1
13、5;temp = base(:,1:t) * c(1:t)'temp = temp + samplemean'imwrite(mat2gray(reshape(temp, 112,92),'d:test2t1.jpg');% 前50 個t = 50;temp = base(:,1:t) * c(1:t)'temp = temp + samplemean'imwrite(mat2gray(reshape(temp, 112,92),'d:test2t2.jpg');% 前100 個t = 100;temp = base(:,1:t) * c(1:t)'temp = temp + samplemean'imwrite(mat2gray(reshape(temp, 112,92),'d:test2t3.jpg');% 前150 個t = 150;temp = base(:,1:t) * c(1:t)'temp = temp + samplemean'imwrite(mat2gray
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 四川傳媒學(xué)院《影視欄目包裝專題設(shè)計》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣西壯族河池市金城江區(qū)2024-2025學(xué)年數(shù)學(xué)四下期末綜合測試模擬試題含解析
- 馬鞍山職業(yè)技術(shù)學(xué)院《材質(zhì)渲染綜合應(yīng)用》2023-2024學(xué)年第二學(xué)期期末試卷
- 中國2025年黃金產(chǎn)業(yè)布局:供需兩端驅(qū)動產(chǎn)業(yè)升級
- 丙烷管道跨接施工方案
- 上海市浦東新區(qū)2024-2025學(xué)年八年級(上)月考生物試卷(12份)(含解析)
- 路燈安裝工程施工方案
- 彩磚鋪設(shè)施工方案
- 廣東省佛山市2024-2025學(xué)年高二上學(xué)期1月期末英語試題【含答案】
- 廣州塔施工方案
- 2025年安徽財貿(mào)職業(yè)學(xué)院單招職業(yè)技能考試題庫標準卷
- 2025年2月時事政治100題及參考答案
- 2025中小學(xué)植樹節(jié)主題班會
- 2025年江蘇揚州市儀征市眾鑫建設(shè)開發(fā)有限公司招聘筆試參考題庫附帶答案詳解
- 學(xué)校招生預(yù)約與咨詢服務(wù)
- 腦卒中患者漸進式分級康復(fù)護理的臨床效果觀察
- 瘋狂動物城賞析課件
- 塑料包裝知識培訓(xùn)課件
- 古法拓印(非遺課程)
- 2025年無線電管理局招聘(10人)高頻重點提升(共500題)附帶答案詳解
- 2025浙江慈溪市水務(wù)集團限公司招聘國企業(yè)人員19人高頻重點提升(共500題)附帶答案詳解
評論
0/150
提交評論