[26487] | 1 | %Test Name: SquareShelfSMBautoregression
|
---|
| 2 | md=triangle(model(),'../Exp/Square.exp',80000.);
|
---|
| 3 | md=setmask(md,'all','');
|
---|
| 4 | md=parameterize(md,'../Par/SquareShelfConstrained.par');
|
---|
| 5 | md=setflowequation(md,'SSA','all');
|
---|
| 6 | md.cluster=generic('name',oshostname(),'np',3);
|
---|
[26553] | 7 | md.transient.requested_outputs={'default','IceVolume','SmbMassBalance'};
|
---|
[26487] | 8 |
|
---|
| 9 | ymax = max(md.mesh.y);
|
---|
| 10 | xmax = max(md.mesh.x);
|
---|
| 11 | %Generate basin IDs for 3 basins
|
---|
| 12 | idbasin = zeros(md.mesh.numberofelements,1);
|
---|
| 13 | iid1 = find(md.mesh.y>=2/3*ymax);
|
---|
| 14 | iid2 = intersect(find(md.mesh.y<2/3*ymax),find(md.mesh.x>=1/3*xmax));
|
---|
| 15 | iid3 = intersect(find(md.mesh.y<2/3*ymax),find(md.mesh.x<1/3*xmax));
|
---|
| 16 | for ii=1:md.mesh.numberofelements
|
---|
| 17 | for vertex=1:3
|
---|
| 18 | if any(iid1==md.mesh.elements(ii,vertex)) %one vertex in basin 1
|
---|
| 19 | idbasin(ii) = 1;
|
---|
| 20 | end
|
---|
| 21 | end
|
---|
| 22 | if idbasin(ii)==0 %no vertex was found in basin 1
|
---|
| 23 | for vertex=1:3
|
---|
| 24 | if any(iid2==md.mesh.elements(ii,vertex)) %one vertex in basin 2
|
---|
| 25 | idbasin(ii) = 2;
|
---|
| 26 | end
|
---|
| 27 | end
|
---|
| 28 | end
|
---|
| 29 | if idbasin(ii)==0 %no vertex was found in basin 1 and 2
|
---|
| 30 | idbasin(ii) = 3;
|
---|
| 31 | end
|
---|
| 32 | end
|
---|
| 33 |
|
---|
[26495] | 34 | %SMB parameters
|
---|
| 35 | md.timestepping.start_time = 0;
|
---|
| 36 | md.timestepping.time_step = 1;
|
---|
| 37 | md.timestepping.final_time = 5;
|
---|
| 38 | md.smb = SMBautoregression();
|
---|
| 39 | md.smb.num_basins = 3; %number of basins
|
---|
| 40 | md.smb.basin_id = idbasin; %prescribe basin ID number to elements
|
---|
| 41 | md.smb.beta0 = [0.5,1.2,1.5]; %intercept values of SMB in basins [m ice eq./yr]
|
---|
| 42 | md.smb.beta1 = [0.0,0.01,-0.01]; %trend values of SMB in basins [m ice eq./yr^2]
|
---|
| 43 | md.smb.ar_initialtime = md.timestepping.start_time;
|
---|
| 44 | md.smb.ar_order = 4;
|
---|
| 45 | md.smb.ar_timestep = 2.0; %timestep of the autoregressive model [yr]
|
---|
| 46 | md.smb.phi = [[0.2,0.1,0.05,0.01];[0.4,0.2,-0.2,0.1];[0.4,-0.4,0.1,-0.1]];
|
---|
| 47 |
|
---|
[26526] | 48 | %Stochastic forcing
|
---|
| 49 | md.stochasticforcing.isstochasticforcing = 1;
|
---|
| 50 | md.stochasticforcing.fields = [{'SMBautoregression'}];
|
---|
| 51 | md.stochasticforcing.covariance = [[0.15 0.08 -0.02];[0.08 0.12 -0.05];[-0.02 -0.05 0.1]]; %global covariance among- and between-fields
|
---|
| 52 | md.stochasticforcing.randomflag = 0; %fixed random seeds
|
---|
| 53 |
|
---|
[26487] | 54 | md=solve(md,'Transient');
|
---|
| 55 |
|
---|
| 56 | %Fields and tolerances to track changes
|
---|
| 57 | field_names ={'Vx1','Vy1','Vel1','Thickness1','Volume1','SmbMassBalance1','Vx2','Vy2','Vel2','Thickness2','Volume2','SmbMassBalance2','Vx3','Vy3','Vel3','Thickness3','Volume3','SmbMassBalance3'};
|
---|
| 58 | field_tolerances={1e-13,1e-13,1e-13,1e-13,1e-13,1e-13,...
|
---|
| 59 | 1e-13,1e-13,1e-13,1e-13,1e-13,1e-13...
|
---|
| 60 | 1e-13,1e-13,1e-13,1e-13,1e-13,1e-13};
|
---|
| 61 | field_values={...
|
---|
| 62 | (md.results.TransientSolution(1).Vx),...
|
---|
| 63 | (md.results.TransientSolution(1).Vy),...
|
---|
| 64 | (md.results.TransientSolution(1).Vel),...
|
---|
| 65 | (md.results.TransientSolution(1).Thickness),...
|
---|
| 66 | (md.results.TransientSolution(1).IceVolume),...
|
---|
[26553] | 67 | (md.results.TransientSolution(1).SmbMassBalance),...
|
---|
[26487] | 68 | (md.results.TransientSolution(2).Vx),...
|
---|
| 69 | (md.results.TransientSolution(2).Vy),...
|
---|
| 70 | (md.results.TransientSolution(2).Vel),...
|
---|
| 71 | (md.results.TransientSolution(2).Thickness),...
|
---|
| 72 | (md.results.TransientSolution(2).IceVolume),...
|
---|
[26553] | 73 | (md.results.TransientSolution(2).SmbMassBalance),...
|
---|
[26487] | 74 | (md.results.TransientSolution(3).Vx),...
|
---|
| 75 | (md.results.TransientSolution(3).Vy),...
|
---|
| 76 | (md.results.TransientSolution(3).Vel),...
|
---|
| 77 | (md.results.TransientSolution(3).Thickness),...
|
---|
| 78 | (md.results.TransientSolution(3).IceVolume),...
|
---|
[26553] | 79 | (md.results.TransientSolution(3).SmbMassBalance),...
|
---|
[26487] | 80 | };
|
---|