-
Notifications
You must be signed in to change notification settings - Fork 42
/
Copy pathbookkeeping.m
executable file
·60 lines (52 loc) · 1.75 KB
/
bookkeeping.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
% BOOKKEEPING - Updates the status of example indss and modifies the corresponding
% coefficient a(indss) in certain cases to avoid numerical errors.
%
% Syntax: [indco,i] = bookkeeping(indss,cstatus,nstatus)
%
% indco: matrix row/col to remove from Rs and Q if removing a margin vector
% i: when i > 0, the i-th element was removed from ind{RESERVE}
% indss: the example changing status
% cstatus: current status of the example
% nstatus: new status of the example
%
% example status values:
% 1: margin vector
% 2: error vector
% 3: reserve vector
% 4: unlearned vector
%
% Version 3.22 -- Comments to [email protected]
%
function [indco,i] = bookkeeping(indss,cstatus,nstatus)
indco = -1;
i = 0;
if (cstatus ~= nstatus)
% flags for example state
MARGIN = 1;
ERROR = 2;
RESERVE = 3;
UNLEARNED = 4;
% define global variables
global a; % the alpha coefficients
global C; % regularization parameters
global ind; % cell array containing indices of margin, error, reserve and unlearned vectors
% adjust coefficient to avoid numerical errors if necessary
switch nstatus
case RESERVE
a(indss) = 0;
case ERROR
a(indss) = C(indss);
end;
% if the example is currently a margin vector, determine the row
% in the extended kernel matrix inverse that needs to be removed
if (cstatus == MARGIN)
indco = find(indss == ind{MARGIN}) + 1;
end;
% change the status of the example
switch nstatus
case RESERVE
[ind{cstatus},i] = move_indr(ind{cstatus},indss);
otherwise
[ind{cstatus},ind{nstatus}] = move_ind(ind{cstatus},ind{nstatus},indss);
end;
end;