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

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

?? pca.m

?? 流形學習代碼
?? 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一区二区三区免费野_久草精品视频
久久99国产精品久久99果冻传媒| 日韩av不卡在线观看| 精品久久久久久久久久久久久久久| 欧美三级日韩三级国产三级| 在线一区二区三区| 欧美三级视频在线| 3atv一区二区三区| 精品国产乱码久久久久久久久| 欧美成人福利视频| 国产欧美日韩精品在线| 日本一区二区免费在线观看视频| 久久精品亚洲麻豆av一区二区 | 亚洲国产成人自拍| 国产清纯美女被跳蛋高潮一区二区久久w| 久久综合久久99| 中文字幕在线观看一区| 亚洲激情图片一区| 日本视频一区二区三区| 国产一区二区不卡| 97久久超碰国产精品电影| 欧美亚洲综合在线| 精品国产免费一区二区三区香蕉 | eeuss鲁片一区二区三区在线观看| 高清视频一区二区| 日本乱人伦一区| 日韩视频免费观看高清完整版 | 欧美一级高清片| 久久九九全国免费| 一区二区三区四区国产精品| 天天影视涩香欲综合网| 国产经典欧美精品| 欧美日韩高清一区二区三区| 久久综合色婷婷| 一区二区三区中文免费| 经典一区二区三区| 91麻豆免费看| 久久综合九色综合97婷婷女人 | 国产日韩欧美制服另类| 亚洲精品免费在线观看| 寂寞少妇一区二区三区| 一本大道久久a久久综合| 欧美电影免费观看高清完整版在线 | 亚洲色图一区二区| 久88久久88久久久| 91久久精品一区二区三| 久久伊人中文字幕| 日韩在线一区二区| 色综合天天视频在线观看| 亚洲精品一区二区三区99| 亚洲成人资源网| a级高清视频欧美日韩| 欧美大白屁股肥臀xxxxxx| 亚洲色图欧美偷拍| 国产福利电影一区二区三区| 91麻豆精品91久久久久久清纯 | 午夜精品久久久| 91视频精品在这里| 欧美国产乱子伦| 国产一区二区三区四区五区入口| 欧美视频在线播放| 亚洲精品免费在线播放| 99久久精品国产网站| 欧美国产精品一区二区| 国产一区二区三区最好精华液| 欧美肥妇毛茸茸| 亚洲国产成人porn| 欧洲一区在线电影| 亚洲综合视频在线| 97超碰欧美中文字幕| 久久久久久免费网| 国产精品一二三四区| 久久精品人人做人人综合| 老司机免费视频一区二区三区| 在线免费不卡视频| 亚洲午夜久久久久中文字幕久| 99精品久久只有精品| 日本一区二区电影| 丁香激情综合五月| 无码av免费一区二区三区试看 | 蜜臀久久99精品久久久久久9| 在线中文字幕一区二区| 一区二区三区四区乱视频| 在线观看日韩电影| 日韩av电影免费观看高清完整版在线观看| 欧美性猛片xxxx免费看久爱| 一级日本不卡的影视| 欧洲视频一区二区| 日韩福利视频网| 日韩精品在线一区二区| 国产麻豆成人传媒免费观看| 久久久精品影视| proumb性欧美在线观看| 一区二区三区精品| 日韩一区二区在线观看视频| 久久av中文字幕片| 国产精品电影院| 欧美综合一区二区三区| 麻豆国产91在线播放| 久久久精品2019中文字幕之3| 粉嫩蜜臀av国产精品网站| 亚洲免费观看高清完整| 337p亚洲精品色噜噜噜| 福利91精品一区二区三区| 一区二区三区久久| 精品久久99ma| 91在线丨porny丨国产| 热久久久久久久| 国产精品美女久久久久久久| 欧美人伦禁忌dvd放荡欲情| 国产在线精品一区二区| 中文字幕一区不卡| 欧美精品丝袜久久久中文字幕| 国产一区二区三区综合| 亚洲亚洲精品在线观看| 欧美激情一区二区| 欧美一区二区三区视频免费播放 | 一本久久a久久精品亚洲| 免费人成网站在线观看欧美高清| 欧美激情综合五月色丁香小说| 欧美性xxxxx极品少妇| 成人午夜伦理影院| 青娱乐精品在线视频| 亚洲日本电影在线| 久久久不卡网国产精品一区| 欧美色精品在线视频| 99久久夜色精品国产网站| 麻豆传媒一区二区三区| 亚洲一区免费观看| 成人免费视频在线观看| 亚洲精品一区二区精华| 91.成人天堂一区| 在线亚洲免费视频| 成人的网站免费观看| 寂寞少妇一区二区三区| 日韩电影在线一区| 一区二区在线观看视频| 国产精品天美传媒| 久久久九九九九| 久久午夜老司机| 日韩一级完整毛片| 91精品欧美一区二区三区综合在 | 精品久久人人做人人爽| 欧美喷潮久久久xxxxx| 91极品视觉盛宴| 色婷婷激情一区二区三区| 国产成人啪午夜精品网站男同| 男女男精品视频网| 热久久免费视频| 日产国产高清一区二区三区| 亚洲第一狼人社区| 亚洲电影欧美电影有声小说| 亚洲图片自拍偷拍| 三级久久三级久久| 午夜a成v人精品| 日韩黄色一级片| 免费人成黄页网站在线一区二区| 亚洲成人黄色影院| 午夜精品久久久久久久99水蜜桃| 亚洲成人在线免费| 蜜芽一区二区三区| 国产在线精品一区二区不卡了| 韩国女主播成人在线观看| 国产精品性做久久久久久| 国产传媒欧美日韩成人| 懂色av噜噜一区二区三区av| 99久久婷婷国产综合精品电影| 97国产一区二区| 欧美午夜视频网站| 日韩免费成人网| 国产欧美日韩精品a在线观看| 中文天堂在线一区| 亚洲自拍偷拍综合| 精品综合免费视频观看| 不卡视频在线观看| 欧美日韩一区二区三区免费看| 337p亚洲精品色噜噜| 久久综合久久99| 亚洲激情五月婷婷| 久久 天天综合| 色婷婷国产精品久久包臀 | 精品无人码麻豆乱码1区2区 | 日韩精品中文字幕一区| 国产农村妇女精品| 亚洲综合一二三区| 国产自产2019最新不卡| www.亚洲免费av| 欧美一区二区三区四区高清| 国产日本欧美一区二区| 亚洲综合色成人| 国产精品91一区二区| 欧美在线不卡视频| 久久久久久久久久久黄色| 日韩美女视频一区二区 | 亚洲天堂网中文字| 蜜桃传媒麻豆第一区在线观看| www.爱久久.com| www国产精品av| 天堂久久久久va久久久久| av在线不卡免费看| 亚洲精品一区二区三区影院|