-
Notifications
You must be signed in to change notification settings - Fork 35
/
Copy pathtrain_liblinear.m
103 lines (95 loc) · 3.87 KB
/
train_liblinear.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
95
96
97
98
99
100
101
102
function cf = train_liblinear(param,X,clabel)
% Trains a linear support vector machine or logistic regression using
% LIBLINEAR. For installation details and further information see
% https://github.com/cjlin1/liblinear and
% https://www.csie.ntu.edu.tw/~cjlin/liblinear/
%
% Usage:
% cf = train_liblinear(param,X,clabel)
%
%Parameters:
% X - [samples x features] matrix of training samples
% clabel - [samples x 1] vector of class labels
%
% param - struct with hyperparameters passed on to the train
% function of LIBLINEAR
%
% .type : set type of solver (default 0)
% for multi-class classification
% 0 -- L2-regularized logistic regression (primal)
% 1 -- L2-regularized L2-loss support vector classification (dual)
% 2 -- L2-regularized L2-loss support vector classification (primal)
% 3 -- L2-regularized L1-loss support vector classification (dual)
% 4 -- support vector classification by Crammer and Singer
% 5 -- L1-regularized L2-loss support vector classification
% 6 -- L1-regularized logistic regression
% 7 -- L2-regularized logistic regression (dual)
% for regression
% 11 -- L2-regularized L2-loss support vector regression (primal)
% 12 -- L2-regularized L2-loss support vector regression (dual)
% 13 -- L2-regularized L1-loss support vector regression (dual)
% .cost : set the parameter C (default 1)
% .epsilon : set the epsilon in loss function of epsilon-SVR (default 0.1)
% .eps: set tolerance of termination criterion
% -s 0 and 2
% |f'(w)|_2 <= eps*min(pos,neg)/l*|f'(w0)|_2,
% where f is the primal function and pos/neg are # of
% positive/negative data (default 0.01)
% -s 11
% |f'(w)|_2 <= eps*|f'(w0)|_2 (default 0.001)
% -s 1, 3, 4 and 7
% Dual maximal violation <= eps; similar to libsvm (default 0.1)
% -s 5 and 6
% |f'(w)|_1 <= eps*min(pos,neg)/l*|f'(w0)|_1,
% where f is the primal function (default 0.01)
% -s 12 and 13\n"
% |f'(alpha)|_1 <= eps |f'(alpha0)|,
% where f is the dual function (default 0.1)
% .bias : if bias >= 0, sample x becomes [x; bias]; if < 0, no bias term added (default -1)
% .weight: weights adjust the parameter C of different classes (see README for details)
% .cv: n-fold cross validation mode
% .c : find parameter C using grid search (only for -s 0 and 2)
% .quiet : quiet mode (no outputs)
%
%Output:
% cf - [struct] specifying the classifier. The result of train is stored
% in cf.model
%
% Reference:
% R.-E. Fan, K.-W. Chang, C.-J. Hsieh, X.-R. Wang, and C.-J. Lin.
% LIBLINEAR: A Library for Large Linear Classification, Journal of
% Machine Learning Research 9(2008), 1871-1874. Software available at
% http://www.csie.ntu.edu.tw/~cjlin/liblinear
%
if ~any(param.type == [0,2]) && any(param.c==1)
error('Warm-start parameter search only available for type 0 and type 2')
end
% convert params struct to LIBLINEAR style name-value pairs
liblinear_options = sprintf('-s %d -p %d -B %d', ...
param.type, param.epsilon, param.bias);
if ~isempty(param.eps)
liblinear_options= [liblinear_options ' -e ' num2str(param.eps)];
end
if ~isempty(param.weight)
liblinear_options= [liblinear_options ' -wi ' num2str(param.weight)];
end
if ~isempty(param.cv)
liblinear_options= [liblinear_options ' -v ' num2str(param.cv)];
end
if param.quiet
liblinear_options= [liblinear_options ' -q' ];
end
if ~isempty(param.c)
% First run cross-validation to find best cost parameter C
param.cost = train(double(clabel(:)), sparse(X), [liblinear_options ' -C']);
end
if ~isempty(param.cost)
% Set cost parameter to either default or to the cross-validated
% version
liblinear_options= [liblinear_options ' -c ' num2str(param.cost(1))];
end
% class labels formatted as 0, 1, 2, ...
clabel = double(clabel-1);
% Call LIBLINEAR training function
% cf.model = train(double(clabel(:)==1), sparse(X), liblinear_options);
cf.model = train(clabel, sparse(X), liblinear_options);