-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathrun_inversions_c.m
61 lines (46 loc) · 1.45 KB
/
run_inversions_c.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
% RUN_INVERSIONS_C Shorter implementation with customizable regularization parameters.
% Author: Timothy Sipkens, 2019-05-28
%=========================================================================%
%%
% Initial guess for iterative schemes
x_init = interp2(grid_b.edges{2}',grid_b.edges{1}',...
reshape(full(b)./(A*ones(size(x0))),grid_b.ne),...
grid_x.elements(:,2),grid_x.elements(:,1));
x_init(isnan(x_init)) = 0;
x_init(isinf(x_init)) = 0;
x_init = sparse(max(0,x_init));
eps.init = norm(x0-x_init);
%%
% Tikhonov (0th) implementation
disp('Running Tikhonov (0th) ...');
lambda_tk0 = 0.419941123497942;
[x_tk0,D_tk0,L_tk0,Gpo_tk0] = invert.tikhonov(...
Lb*A,Lb*b,lambda_tk0,0,n_x(1),[],'non-neg');
tools.textdone();
disp(' ');
eps.tk0 = norm(x0-x_tk0);
%%
% Tikhonov (1st) implementation
disp('Running Tikhonov (1st) ...');
lambda_tk1 = 0.935436889902617;
[x_tk1,D_tk1,L_tk1,Gpo_tk1] = invert.tikhonov(...
Lb*A,Lb*b,lambda_tk1,1,n_x(1),[],'non-neg');
tools.textdone();
disp(' ');
eps.tk1 = norm(x0-x_tk1);
%%
% Tikhonov (2nd) implementation
disp('Running Tikhonov (2nd) ...');
lambda_tk2 = 1.069019204603001;
[x_tk2,D_tk2,L_tk2] = invert.tikhonov(...
Lb*A,Lb*b,lambda_tk2,2,n_x(1),[],'non-neg');
tools.textdone();
disp(' ');
eps.tk2 = norm(x0-x_tk2);
%%
% Twomey
%-- Perform Twomey algorithm ----------------------------%
disp('Running Twomey ...');
x_two = invert.twomey(A,b,x_init,500,[],[],1);
disp(' ');
eps.two = norm(x0-x_two);