pcaknnrloo.m

来自「一个关于数据聚类和模式识别的程序,在生物化学,化学中因该都可以用到.希望对大家有」· M 代码 · 共 28 行

M
28
字号
function recogRate=pcaKnnrLoo(DS, plotOpt)
% ldaKnnrLoo: PCA analysis using KNNR and LOO

%	Roger Jang, 20060507

if nargin<1, selfdemo; return; end
if nargin<2, plotOpt=0; end

[featureNum, dataNum] = size(DS.input);
DS2 = pca(DS);
recogRate=[];
for i = 1:featureNum
	DS3=DS2; DS3.input=DS2.input(1:i, :);
	[recogRate(i), hitIndex] = knnrLoo(DS3);
	hitCount=length(hitIndex);
%	fprintf('\t\tLOO recog. rate = %d/%d = %g%%\n', hitCount, dataNum, 100*recogRate(i));
end

if plotOpt
	plot(1:featureNum, 100*recogRate, 'o-'); grid on
	xlabel('No. of projected features based on PCA');
	ylabel('LOO recognition rates using KNNR (%)');
end

% ====== Self demo
function selfdemo
DS=prData('wine');
feval(mfilename, DS, 1);

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?