亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? pca.m

?? 這是一個PCA用于人臉識別的程序
?? M
字號:
function [eigvector, eigvalue, meanData, new_data] = PCA(data, options)
%PCA	Principal component analysis
%	Usage:
%	[EIGVECTOR, EIGVALUE, MEANDATA, NEW_DATA] = PCA(DATA, OPTIONS)
%
%	DATA: Rows of vectors of data points
%   options - Struct value in Matlab. The fields in options
%             that can be set:
%           ReducedDim   -  The dimensionality of the
%                           reduced subspace. If 0,
%                           all the dimensions will be
%                           kept. Default is 0.
%           PCARatio     -  The percentage of principal
%                           component kept. The percentage is
%                           calculated based on the
%                           eigenvalue. Default is 1
%                           (100%, all the non-zero
%                           eigenvalues will be kept.
%          Please do not set both these two fields. If both of them are
%          set, PCARatio will be used. 
%          
%   MEANDATA: Mean of all the data. 
%	NEW_DATA: The data after projection (mean removed)
%	EIGVECTOR: Each column of this matrix is a eigenvector of DATA'*DATA
%	EIGVALUE: Eigenvalues of DATA'*DATA
%
%	Examples:
% 			data = rand(7,10);
% 			options = [];
% 			options.ReducedDim = 4;
% 			[eigvector,eigvalue,meanData,new_data] = PCA(data,options);
% 
% 			data = rand(7,10);
% 			options = [];
% 			options.PCARatio = 0.98;
% 			[eigvector,eigvalue,meanData,new_data] = PCA(data,options);
%
%
% Note: Be aware of the "mean". For classification, you can use this code by:
% 	
%			fea_Train = fea(trainIdx,:);
%
%			[eigvector, eigvalue] = PCA(fea_Train, options)
%			fea_New = fea*eigvector;
%		or
%			[eigvector, eigvalue, meanData] = PCA(fea_Train, options)
%			fea_New_2 = (fea - repmat(meanData,nSmp,1))*eigvector;
%
%	 Then classification is then performed on "fea_new" or "fea_new_2". 
%	 Since we use Euclidean distance, the result will be the same for 
%	 nearest neighbor classifier on "fea_new" or "fea_new_2". 
%
%    If you call PCA by:
%			[eigvector, eigvalue, meanData, fea_Train_new] = PCA(fea_Train, options);
%	  Since "fea_Train_new" is "mean removed", you should also subtract the "meanData" 
%	  from each testing example, like
%			fea_Test = fea(testIdx,:);
%			fea_Test_new = (fea_Test - repmat(meanData,nSmpTest,1))*eigvector;

%
% 
%    Written by Deng Cai (dengcai@gmail.com), April/2004, Feb/2006

if (~exist('options','var'))
   options = [];
else
   if ~strcmpi(class(options),'struct') 
       error('parameter error!');
   end
end

bRatio = 0;
if isfield(options,'PCARatio')
    bRatio = 1;
    eigvector_n = min(size(data));
elseif isfield(options,'ReducedDim')
    eigvector_n = options.ReducedDim;
else
    eigvector_n = min(size(data));
end
    

[nSmp, nFea] = size(data);

meanData = mean(data);
data = data - repmat(meanData,nSmp,1);

if nSmp >= nFea
    ddata = data'*data;
    ddata = (ddata + ddata')/2;
    if issparse(ddata)
        ddata = full(ddata);
    end

    if size(ddata, 1) > 100 & eigvector_n < size(ddata, 1)/2  % using eigs to speed up!
        option = struct('disp',0);
        [eigvector, d] = eigs(ddata,eigvector_n,'la',option);
        eigvalue = diag(d);
    else
        [eigvector, d] = eig(ddata);
        eigvalue = diag(d);
        % ====== Sort based on descending order
        [junk, index] = sort(-eigvalue);
        eigvalue = eigvalue(index);
        eigvector = eigvector(:, index);
    end
    
    clear ddata;
    maxEigValue = max(abs(eigvalue));
    eigIdx = find(abs(eigvalue)/maxEigValue < 1e-12);
    eigvalue (eigIdx) = [];
    eigvector (:,eigIdx) = [];

else	% This is an efficient method which computes the eigvectors of
	% of A*A^T (instead of A^T*A) first, and then convert them back to
	% the eigenvectors of A^T*A.
    if nSmp > 700
        ddata = zeros(nSmp,nSmp);
        for i = 1:ceil(nSmp/100)
            if i == ceil(nSmp/100)
                ddata((i-1)*100+1:end,:) = data((i-1)*100+1:end,:)*data';
            else
                ddata((i-1)*100+1:i*100,:) = data((i-1)*100+1:i*100,:)*data';
            end
        end
    elseif nSmp > 400
        ddata = zeros(nSmp,nSmp);
        for i = 1:ceil(nSmp/200)
            if i == ceil(nSmp/200)
                ddata((i-1)*200+1:end,:) = data((i-1)*200+1:end,:)*data';
            else
                ddata((i-1)*200+1:i*200,:) = data((i-1)*200+1:i*200,:)*data';
            end
        end
    else
        ddata = data*data';
    end
   
    ddata = (ddata + ddata')/2;
    if issparse(ddata)
        ddata = full(ddata);
    end
    
    if size(ddata, 1) > 100 & eigvector_n < size(ddata, 1)/2  % using eigs to speed up!
        option = struct('disp',0);
        [eigvector1, d] = eigs(ddata,eigvector_n,'la',option);
        eigvalue = diag(d);
    else
        [eigvector1, d] = eig(ddata);
        
        eigvalue = diag(d);
        % ====== Sort based on descending order
        [junk, index] = sort(-eigvalue);
        eigvalue = eigvalue(index);
        eigvector1 = eigvector1(:, index);
    end

    clear ddata;
    
    maxEigValue = max(abs(eigvalue));
    eigIdx = find(abs(eigvalue)/maxEigValue < 1e-12);
    eigvalue (eigIdx) = [];
    eigvector1 (:,eigIdx) = [];

    eigvector = data'*eigvector1;		% Eigenvectors of A^T*A
    clear eigvector1;
	eigvector = eigvector*diag(1./(sum(eigvector.^2).^0.5)); % Normalization

end

if bRatio
    if options.PCARatio >= 1 | options.PCARatio <= 0
        idx = length(eigvalue);
    else
        sumEig = sum(eigvalue);
        sumEig = sumEig*options.PCARatio;
        sumNow = 0;
        for idx = 1:length(eigvalue)
            sumNow = sumNow + eigvalue(idx);
            if sumNow >= sumEig
                break;
            end
        end
    end

    eigvalue = eigvalue(1:idx);
    eigvector = eigvector(:,1:idx);
else
    if eigvector_n < length(eigvalue)
        eigvalue = eigvalue(1:eigvector_n);
        eigvector = eigvector(:, 1:eigvector_n);
    end
end

if nargout == 4
    new_data = data*eigvector;
end

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
麻豆成人久久精品二区三区小说| 欧美日韩国产高清一区二区三区 | 国产剧情一区二区| √…a在线天堂一区| 欧美一区二区日韩一区二区| 成人av动漫网站| 天堂在线一区二区| 亚洲精品视频免费看| 精品国产亚洲在线| 欧美麻豆精品久久久久久| 99久久99久久精品免费看蜜桃 | 婷婷开心久久网| 中文字幕欧美三区| 日韩一区和二区| 欧美视频一区在线| 成人福利视频网站| 韩国女主播成人在线观看| 亚洲成av人片| 玉足女爽爽91| 亚洲色欲色欲www| 国产女同互慰高潮91漫画| 日韩视频一区二区三区 | 欧美伊人久久大香线蕉综合69 | 欧美一区二区视频观看视频 | 精品福利av导航| 欧美喷潮久久久xxxxx| 91麻豆精东视频| 成人av网站在线观看| 国产成人综合网站| 国产主播一区二区| 精品在线亚洲视频| 美女视频黄 久久| 青青草国产成人av片免费| 亚洲6080在线| 亚洲国产一区视频| 亚洲精品少妇30p| 亚洲品质自拍视频| 国产精品美女一区二区| 国产精品免费视频网站| 国产精品欧美久久久久一区二区| 国产亚洲va综合人人澡精品| 久久亚洲欧美国产精品乐播| 精品美女一区二区| 久久夜色精品国产噜噜av| 久久久久亚洲综合| 久久精品夜夜夜夜久久| 国产日韩欧美一区二区三区综合| 久久久蜜桃精品| 国产精品伦理在线| 国产精品免费免费| 国产精品美女久久福利网站| 国产精品美女久久福利网站| 国产精品区一区二区三| 一区二区在线观看不卡| 亚洲成a人片在线观看中文| 人人狠狠综合久久亚洲| 狠狠色丁香九九婷婷综合五月| 韩国精品一区二区| 岛国av在线一区| 99精品国产99久久久久久白柏| 一本色道久久综合精品竹菊| 在线免费精品视频| 欧美二区在线观看| 精品成a人在线观看| 国产欧美精品一区二区色综合朱莉| 亚洲国产精品成人综合色在线婷婷| 自拍偷拍亚洲欧美日韩| 亚洲国产综合人成综合网站| 精品亚洲免费视频| 成人免费av在线| 欧美日韩国产综合草草| 日韩精品影音先锋| 欧美激情中文不卡| 午夜精品福利视频网站| 国模大尺度一区二区三区| 播五月开心婷婷综合| 欧美日韩激情一区| 亚洲国产成人在线| 丝袜诱惑制服诱惑色一区在线观看| 久久国产麻豆精品| 一本一道久久a久久精品综合蜜臀| 欧美美女bb生活片| 欧美国产精品中文字幕| 亚洲成人福利片| 国产精品自拍一区| 欧美日韩在线三级| 欧美激情中文字幕| 日本少妇一区二区| 97久久精品人人做人人爽50路| 制服.丝袜.亚洲.另类.中文| 国产精品蜜臀av| 蜜臀av亚洲一区中文字幕| 成人h版在线观看| 欧美精品aⅴ在线视频| 国产女人18毛片水真多成人如厕| 亚洲国产精品视频| 高清国产一区二区| 91精品国产一区二区三区| 日韩毛片一二三区| 国产一区在线观看视频| 欧美人与z0zoxxxx视频| 国产精品久久一级| 激情综合网天天干| 欧美日韩国产欧美日美国产精品| 国产精品女人毛片| 黑人精品欧美一区二区蜜桃| 欧洲精品一区二区| 国产精品美女久久福利网站| 韩国毛片一区二区三区| 欧美一区二区美女| 一区二区激情视频| www.激情成人| 国产亚洲成aⅴ人片在线观看| 蜜臀精品久久久久久蜜臀| 欧美日韩国产高清一区二区| 洋洋av久久久久久久一区| a亚洲天堂av| 精品福利二区三区| 精品午夜一区二区三区在线观看| 欧美性视频一区二区三区| 中文字幕一区二区三区四区不卡| 国产一区二区网址| 精品少妇一区二区三区免费观看 | 欧美sm美女调教| 日本不卡一区二区三区 | 国产女人aaa级久久久级| 国产专区欧美精品| 精品99一区二区三区| 麻豆精品久久精品色综合| 91精品国产一区二区人妖| 青青草原综合久久大伊人精品优势| 欧美在线观看18| 亚洲一区二区三区四区在线免费观看| 99久久婷婷国产综合精品电影| 欧美激情一区二区三区蜜桃视频 | 欧美久久久久久久久中文字幕| 亚洲黄网站在线观看| 91最新地址在线播放| 亚洲欧美另类久久久精品| 91在线高清观看| ●精品国产综合乱码久久久久| 成+人+亚洲+综合天堂| 国产精品久久久久永久免费观看| 丰满亚洲少妇av| 中文字幕精品三区| 99re成人在线| 亚洲男人都懂的| 欧美中文字幕一区| 婷婷成人综合网| 欧美美女网站色| 久久国产麻豆精品| 国产欧美综合在线| 99久久免费视频.com| 亚洲国产精品一区二区www在线| 欧美日韩成人在线一区| 奇米影视在线99精品| 欧美精品一区二区三区高清aⅴ | 久久久久国产精品厨房| 国产99久久久国产精品| 自拍偷拍亚洲综合| 欧美久久久久久蜜桃| 韩日精品视频一区| 亚洲丝袜制服诱惑| 欧美一区二区三区小说| 国产乱码精品一区二区三区av | 国产精品高清亚洲| 欧美性色综合网| 蜜臀av性久久久久蜜臀aⅴ| 国产亚洲欧美日韩俺去了| 99九九99九九九视频精品| 亚洲成人黄色影院| 国产亚洲欧美日韩俺去了| 欧美制服丝袜第一页| 国产资源在线一区| 一区二区三区国产| 欧美sm极限捆绑bd| 91老师片黄在线观看| 久久国产福利国产秒拍| 欧美国产乱子伦 | 欧美美女直播网站| 国产成人aaaa| 亚洲成人自拍偷拍| 国产人成一区二区三区影院| 日本高清不卡在线观看| 国产一区二区三区香蕉| 亚洲精品你懂的| 久久久蜜桃精品| 欧美久久久一区| 99久久婷婷国产精品综合| 精品在线播放免费| 亚洲综合成人在线视频| 精品国产91乱码一区二区三区 | 国产一区二区三区精品欧美日韩一区二区三区 | 欧美国产成人精品| 欧美日韩五月天| 成人午夜激情视频| 美女www一区二区| 一区二区三区中文免费| 久久精品欧美日韩| 91精品国产免费|