-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathtrain_EN_logreg.m
29 lines (21 loc) · 1.11 KB
/
train_EN_logreg.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
function [mdl, cfs]=train_EN_logreg(training_data, training_labels); % [mdl, cfs]=train_EN_logreg(training_data, training_labels);
% deBettencourt used just L2 with alpha=1
[B,FitInfo] = lassoglm(training_data,training_labels','binomial','NumLambda',100, 'Alpha',1.0, 'LambdaRatio',1e-4,'CV', 10, 'Standardize',false); %(training_data,training_labels','binomial','NumLambda',100, 'Alpha',0.9,'LambdaRatio',1e-4,'CV', 10); %, 'Standardize',false);
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
lassoPlot(B,FitInfo,'PlotType','CV');
lassoPlot(B,FitInfo,'PlotType','Lambda','XScale','log');
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
indx = FitInfo.Index1SE;
B0 = B(:,indx);
%nonzeros = sum(B0 ~= 0);
cnst = FitInfo.Intercept(indx);
cfs = [cnst;B0];
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
preds = glmval(cfs,training_data,'logit');
histogram(training_labels' - preds); % plot residuals
title('Residuals from lassoglm model')
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
predictors = find(B0); % indices of nonzero predictors
mdl = fitglm(training_data,training_labels,'linear',...
'Distribution','binomial','PredictorVars',predictors);
return;