[19105] | 1 | %Test Name: SquareShelfTranIspddIsdeltaSSA3d
|
---|
[13975] | 2 | md=triangle(model(),'../Exp/Square.exp',600000.);%180000
|
---|
[12891] | 3 | md=setmask(md,'all','');
|
---|
[19105] | 4 | md=parameterize(md,'../Par/SquareShelf.par');
|
---|
[12891] | 5 |
|
---|
[19105] | 6 | %md.verbose=verbose('all');
|
---|
| 7 |
|
---|
| 8 | % Use of ispdd methods
|
---|
[20500] | 9 | md.smb = SMBpdd();
|
---|
| 10 | md.smb.isdelta18o=0;
|
---|
| 11 | md.smb.ismungsm=1;
|
---|
[12891] | 12 |
|
---|
[20500] | 13 | % time steps and resolution
|
---|
| 14 | md.timestepping.time_step=20;
|
---|
| 15 | md.settings.output_frequency=1;
|
---|
| 16 | md.timestepping.final_time=60;
|
---|
[12891] | 17 |
|
---|
| 18 | % creating Present day and lgm temperatures
|
---|
[13975] | 19 | % Same temperature over the all region:
|
---|
| 20 | tmonth(1:12)=238.15+20.;
|
---|
[12891] | 21 | for imonth=0:11
|
---|
[20500] | 22 | md.smb.temperatures_presentday(1:md.mesh.numberofvertices,imonth+1)=tmonth(imonth+1);
|
---|
| 23 | md.smb.temperatures_lgm(1:md.mesh.numberofvertices,imonth+1)=tmonth(imonth+1)-20.;
|
---|
[12891] | 24 | % Time for the last line:
|
---|
[20500] | 25 | md.smb.temperatures_presentday(md.mesh.numberofvertices+1,imonth+1)=((imonth+1)/12);
|
---|
| 26 | md.smb.temperatures_lgm(md.mesh.numberofvertices+1,imonth+1)=((imonth+1)/12);
|
---|
[12891] | 27 | end
|
---|
| 28 |
|
---|
| 29 | % creating initialization and spc temperatures initialization and spc
|
---|
[20500] | 30 | md.thermal.spctemperature=mean(md.smb.temperatures_lgm(1:md.mesh.numberofvertices,1:12),2); %-10*ones(md.mesh.numberofvertices,1);
|
---|
[12891] | 31 | md.thermal.spctemperature=repmat(md.thermal.spctemperature,1,md.timestepping.final_time/md.timestepping.time_step);
|
---|
[13975] | 32 | itemp=0:md.timestepping.time_step:md.timestepping.final_time-md.timestepping.time_step;
|
---|
[12891] | 33 | md.thermal.spctemperature(md.mesh.numberofvertices+1,:)=itemp;
|
---|
| 34 |
|
---|
[20500] | 35 | md.initialization.temperature=md.smb.temperatures_lgm(1:md.mesh.numberofvertices,1); %*ones(md.mesh.numberofvertices,1);
|
---|
| 36 | md.smb = initialize(md.smb,md);
|
---|
[12891] | 37 |
|
---|
| 38 | % creating precipitation
|
---|
| 39 | for imonth=0:11
|
---|
[20500] | 40 | md.smb.precipitations_presentday(1:md.mesh.numberofvertices,imonth+1)=-0.4*10^(-6)*md.mesh.y+0.5;
|
---|
| 41 | md.smb.precipitations_lgm(1:md.mesh.numberofvertices,imonth+1)=-0.4*10^(-6)*md.mesh.y+0.5;
|
---|
[19105] | 42 | % Time for the last line:
|
---|
[20500] | 43 | md.smb.precipitations_presentday(md.mesh.numberofvertices+1,imonth+1)=((imonth+1)/12);
|
---|
| 44 | md.smb.precipitations_lgm(md.mesh.numberofvertices+1,imonth+1)=((imonth+1)/12);
|
---|
[12891] | 45 | end
|
---|
| 46 |
|
---|
[20500] | 47 | for iint=1:(md.timestepping.final_time/md.timestepping.time_step)+1
|
---|
| 48 | md.smb.Pfac(1,iint)=0.15*iint;
|
---|
| 49 | md.smb.Tdiff(1,iint)=0.15*iint;
|
---|
| 50 | md.smb.sealev(1,iint)=0.15*iint;
|
---|
| 51 | % Year of each data point
|
---|
| 52 | md.smb.Pfac(2,iint)=(iint-1)*20;
|
---|
| 53 | md.smb.Tdiff(2,iint)=(iint-1)*20;
|
---|
| 54 | md.smb.sealev(2,iint)=(iint-1)*20;
|
---|
| 55 | end
|
---|
[19105] | 56 |
|
---|
[12891] | 57 | %
|
---|
[20500] | 58 | md.transient.requested_outputs={'default','SmbMonthlytemperatures'};
|
---|
[19105] | 59 | md=extrude(md,3,1);
|
---|
| 60 |
|
---|
[16137] | 61 | md=setflowequation(md,'SSA','all');
|
---|
[19105] | 62 | md.cluster=generic('name',oshostname(),'np',1); % 3 for the cluster
|
---|
| 63 | md=solve(md,TransientSolutionEnum);
|
---|
[12891] | 64 |
|
---|
| 65 | %Fields and tolerances to track changes
|
---|
[20500] | 66 | field_names ={'Vx1','Vy1','Vz1','Vel1','Pressure1','Bed1','Surface1','Thickness1','Temperature1','BasalforcingsGroundediceMeltingRate1','SmbMonthlytemperatures1','SmbMassBalance1',...
|
---|
| 67 | 'Vx2','Vy2','Vz2','Vel2','Pressure2','Bed2','Surface2','Thickness2','Temperature2','BasalforcingsGroundediceMeltingRate2','SmbMonthlytemperatures2','SmbMassBalance2',...
|
---|
| 68 | 'Vx3','Vy3','Vz3','Vel3','Pressure3','Bed3','Surface3','Thickness3','Temperature3','BasalforcingsGroundediceMeltingRate3','SmbMonthlytemperatures3','SmbMassBalance3'};
|
---|
[12891] | 69 | field_tolerances={...
|
---|
[20500] | 70 | 1e-13,1e-13,1e-13,1e-13,1e-13,1e-8,1e-8,1e-8,1e-13,1e-8,1e-13,1e-13,...
|
---|
| 71 | 1e-13,1e-13,1e-13,1e-13,1e-13,1e-8,1e-8,1e-8,1e-13,1e-7,1e-13,1e-13,...
|
---|
| 72 | 1e-13,1e-13,1e-08,1e-13,1e-13,1e-8,1e-8,1e-8,1e-13,5e-7,1e-13,1e-13};
|
---|
[12891] | 73 | field_values={...
|
---|
| 74 | (md.results.TransientSolution(1).Vx),...
|
---|
| 75 | (md.results.TransientSolution(1).Vy),...
|
---|
| 76 | (md.results.TransientSolution(1).Vz),...
|
---|
| 77 | (md.results.TransientSolution(1).Vel),...
|
---|
| 78 | (md.results.TransientSolution(1).Pressure),...
|
---|
[17806] | 79 | (md.results.TransientSolution(1).Base),...
|
---|
[12891] | 80 | (md.results.TransientSolution(1).Surface),...
|
---|
| 81 | (md.results.TransientSolution(1).Thickness),...
|
---|
| 82 | (md.results.TransientSolution(1).Temperature),...
|
---|
[18301] | 83 | (md.results.TransientSolution(1).BasalforcingsGroundediceMeltingRate),...
|
---|
[20500] | 84 | (md.results.TransientSolution(1).SmbMonthlytemperatures),...
|
---|
| 85 | (md.results.TransientSolution(1).SmbMassBalance),...
|
---|
[12891] | 86 | (md.results.TransientSolution(2).Vx),...
|
---|
| 87 | (md.results.TransientSolution(2).Vy),...
|
---|
| 88 | (md.results.TransientSolution(2).Vz),...
|
---|
| 89 | (md.results.TransientSolution(2).Vel),...
|
---|
| 90 | (md.results.TransientSolution(2).Pressure),...
|
---|
[17806] | 91 | (md.results.TransientSolution(2).Base),...
|
---|
[12891] | 92 | (md.results.TransientSolution(2).Surface),...
|
---|
| 93 | (md.results.TransientSolution(2).Thickness),...
|
---|
| 94 | (md.results.TransientSolution(2).Temperature),...
|
---|
[18301] | 95 | (md.results.TransientSolution(2).BasalforcingsGroundediceMeltingRate),...
|
---|
[20500] | 96 | (md.results.TransientSolution(2).SmbMonthlytemperatures),...
|
---|
| 97 | (md.results.TransientSolution(2).SmbMassBalance),...
|
---|
[12891] | 98 | (md.results.TransientSolution(3).Vx),...
|
---|
| 99 | (md.results.TransientSolution(3).Vy),...
|
---|
| 100 | (md.results.TransientSolution(3).Vz),...
|
---|
| 101 | (md.results.TransientSolution(3).Vel),...
|
---|
| 102 | (md.results.TransientSolution(3).Pressure),...
|
---|
[17806] | 103 | (md.results.TransientSolution(3).Base),...
|
---|
[12891] | 104 | (md.results.TransientSolution(3).Surface),...
|
---|
| 105 | (md.results.TransientSolution(3).Thickness),...
|
---|
| 106 | (md.results.TransientSolution(3).Temperature),...
|
---|
[18301] | 107 | (md.results.TransientSolution(3).BasalforcingsGroundediceMeltingRate),...
|
---|
[20500] | 108 | (md.results.TransientSolution(3).SmbMonthlytemperatures),...
|
---|
| 109 | (md.results.TransientSolution(3).SmbMassBalance),...
|
---|
[12891] | 110 | };
|
---|