forked from tiepvupsu/FISTA
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdemo_lasso_weighted.m
45 lines (44 loc) · 1.26 KB
/
demo_lasso_weighted.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
function demo_lasso_weighted()
clc
d = 30; % data dimension
N = 70; % number of samples
k = 50; % dictionary size
lambda = 0.01;
Y = normc(rand(d, N));
D = normc(rand(d, k));
lambda = rand(k, 1);
% if size(lambda, 2) == 1
% lambda = repmat(lambda, 1, N);
% end
%% fista solution
opts.pos = true;
opts.lambda = lambda;
opts.check_grad = 0;
X_fista = fista_lasso(Y, D, [], opts);
%% fista solution with backtracking
opts.L0 = 1;
opts.eta = 1.1;
X_fista_bt = fista_lasso_backtracking(Y, D, [], opts);
%% spams solution
param.lambda = 1;
param.lambda2 = 0;
param.numThreads = 1;
param.mode = 2;
param.pos = opts.pos;
W = repmat(opts.lambda, 1, N);
% mex solution and optimal value
X_spams = mexLassoWeighted(Y, D, W, param);
%% compare costs
% cost function
function c = calc_F(X)
c = 1/2*normF2(Y - D*X) + norm1(lambda.*X);
end
cost_spams = calc_F(X_spams);
cost_fista = calc_F(X_fista);
cost_fista_bt = calc_F(X_fista_bt);
fprintf('Test Lasso weighted\n');
fprintf('cost_spams = %.5s\n', cost_spams);
fprintf('cost_fista = %.5s\n', cost_fista);
fprintf('cost_fista_bt = %.5s\n', cost_fista_bt);
% cost_fista - cost_spams
end