-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathPCDOC_classify.m
63 lines (55 loc) · 2.03 KB
/
PCDOC_classify.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
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Copyright (C) Javier Sánchez Monedero (jsanchezm at uco dot es)
%
% This code implements the Pairwise Class Distances (PCD) projection and the
% associated PCD Ordinal Classifier (PCDOC).
%
% The code has been tested with Ubuntu 11.04 x86_64 and Matlab R2009a
%
% If you use this code, please cite the associated paper
% Code updates and citing information:
% http://www.uco.es/grupos/ayrna/neco-pairwisedistances
%
% AYRNA Research group's website:
% http://www.uco.es/ayrna
%
% This program is free software; you can redistribute it and/or
% modify it under the terms of the GNU General Public License
% as published by the Free Software Foundation; either version 3
% of the License, or (at your option) any later version.
%
% This program is distributed in the hope that it will be useful,
% but WITHOUT ANY WARRANTY; without even the implied warranty of
% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
% GNU General Public License for more details.
%
% You should have received a copy of the GNU General Public License
% along with this program; if not, write to the Free Software
% Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
% Licence available at: http://www.gnu.org/licenses/gpl-3.0.html
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Y = PCDOC_classify(Z, pcdocModel.T, Q)
%
% DESCRIPTION:
% This function uses Z latent representation and thressholds for classifying
% patterns according to they latent representation.
% INPUT:
% - Z: patterns latent representation
% - T: thressholds
% - Q: number of classes
% OUTPUT:
% - Y: predicted patterns labels
function Y = PCDOC_classify(Z, T, Q)
Y = zeros(size(Z));
for ii=1:Q-1
if (ii == 1)
indx = Z<=T(ii);
else
indx = and(Z>T(ii-1), Z<=T(ii));
end
Y(indx) = ii;
end
% last class
indx = Z>T(Q-1);
Y(indx) = Q;
end