-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathSRKDAtest.m
99 lines (89 loc) · 2.87 KB
/
SRKDAtest.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
function [feaNew] = SRKDAtest(fea, model)
% SRKDAtest: Spectral Regression Kernel Discriminant Analysis Testing
% SRKDAtest uses SRKDA as a dimensionality reduction tool.
%
% [feaNew,elapse] = SRKDAtest(fea, model);
%
% Input:
%
% fea - data matrix. Each row is a data point.
% model - model trained by SRKDAtrain.m
%
% Output:
%
% feaNew - The data in the c-1 SRKDA subspace, where c is the
% number of classes.
%
% Examples:
%
%
% See also SRKDAtrain, SRKDApredict, KSR, KSR_caller
%
%Reference:
%
% [1] Deng Cai, Xiaofei He, and Jiawei Han. "Speed Up Kernel Discriminant
% Analysis", The VLDB Journal, vol. 20, no. 1, pp. 21-33, January, 2011.
%
% [2] Deng Cai, Xiaofei He and Jiawei Han, "SRDA: An Efficient Algorithm for
% Large Scale Discriminant Analysis" IEEE Transactions on Knowledge and
% Data Engineering, vol. 20, no. 1, pp. 1-12, January, 2008.
%
% [3] Deng Cai, "Spectral Regression: A Regression Framework for
% Efficient Regularized Subspace Learning", PhD Thesis, Department of
% Computer Science, UIUC, 2009.
%
% version 3.0 --Jan/2012
% version 2.0 --December/2011
% version 1.0 --May/2006
%
% Written by Deng Cai (dengcai AT gmail.com)
%
MAX_MATRIX_SIZE = 8000; % You can change this number based on your memory.
if ~strcmp(model.TYPE,'SRKDA')
error('model does not match!');
end
nTrain = size(model.fea,1);
nTest = size(fea,1);
nBlock = ceil(MAX_MATRIX_SIZE*MAX_MATRIX_SIZE/nTrain);
if model.LARs
feaNew = cell(length(model.LassoCardi),1);
for i=1:length(model.LassoCardi)
feaNew{i} = zeros(nTest,size(model.projection{i},2));
end
for j = 1:ceil(nTest/nBlock)
if j == ceil(nTest/nBlock)
smpIdx = (j-1)*nBlock+1:nTest;
else
smpIdx = (j-1)*nBlock+1:j*nBlock;
end
KTest= constructKernel(fea(smpIdx,:),model.fea,model.options);
if model.bSemi
KTest = KTest*model.KtestHat;
end
for i=1:length(model.LassoCardi)
if model.bSemi
feaNew{i}(smpIdx,:) = KTest(:,1:model.nLabel)*model.projection{i};
else
feaNew{i}(smpIdx,:) = KTest*model.projection{i};
end
end
clear KTest;
end
else
feaNew = zeros(nTest,size(model.projection,2));
for i = 1:ceil(nTest/nBlock)
if i == ceil(nTest/nBlock)
smpIdx = (i-1)*nBlock+1:nTest;
else
smpIdx = (i-1)*nBlock+1:i*nBlock;
end
KTest= constructKernel(fea(smpIdx,:),model.fea,model.options);
if model.bSemi
KTest = KTest*model.KtestHat;
feaNew(smpIdx,:) = KTest(:,1:model.nLabel)*model.projection;
else
feaNew(smpIdx,:) = KTest*model.projection;
end
clear KTest;
end
end