source: issm/trunk-jpl/src/m/classes/solidearthsettings.m@ 27131

Last change on this file since 27131 was 27131, checked in by caronlam, 3 years ago

CHG: Memory and runtime optimization of sealevelchange core.

File size: 10.9 KB
Line 
1%SOLIDEARTHSETTINGS class definition
2%
3% Usage:
4% solidearthsettings=solidearthsettings();
5
6classdef solidearthsettings
7 properties (SetAccess=public)
8 reltol = 0;
9 abstol = 0;
10 maxiter = 0;
11 selfattraction = 1;
12 elastic = 1;
13 viscous = 1;
14 rotation = 1;
15 grdocean = 1;
16 ocean_area_scaling = 0;
17 runfrequency = 1; %how many time steps we skip before we run grd_core
18 sealevelloading = 1; %will sea-level loads be computed?
19 isgrd = 0; %will GRD patterns be computed?
20 compute_bp_grd = 0; %will GRD patterns for bottom pressures be computed?
21 degacc = 0; %degree increment for resolution of Green tables.
22 timeacc = 1; %time step accuracy required to compute Green tables
23 horiz = 0; %compute horizontal deformation
24 grdmodel = 1; %grd model (0 by default, 1 for (visco-)elastic, 2 for Ivins)
25 cross_section_shape = 0; %cross section only used when grd model is Ivins
26 end
27 methods (Static)
28 function self = loadobj(self) % {{{
29 % This function is directly called by matlab when a model object is
30 % loaded. If the input is a struct it is an old version of this class and
31 % old fields must be recovered (make sure they are in the deprecated
32 % model properties)
33
34 if isstruct(self)
35 % 2021, Jun 4
36 if isfield(self,'rigid')
37 self.selfattraction = self.rigid;
38 end
39 if isfield(self,'computesealevelchange')
40 self.sealevelloading = self.computesealevelchange;
41 end
42 self = structtoobj(solidearthsettings(),self);
43
44 end
45 end% }}}
46 end
47 methods
48
49 function self = solidearthsettings(varargin) % {{{
50 switch nargin
51 case 0
52 self=setdefaultparameters(self);
53 otherwise
54 error('constructor not supported');
55 end
56 end % }}}
57 function self = setdefaultparameters(self) % {{{
58
59 %Convergence criterion: absolute, relative and residual
60 self.reltol=0.01; % 1 percent
61 self.abstol=NaN; % default
62
63 %maximum of non-linear iterations.
64 self.maxiter=5;
65
66 %computational flags:
67 self.selfattraction=1;
68 self.elastic=1;
69 self.viscous=1;
70 self.rotation=1;
71 self.grdocean=1;
72 self.ocean_area_scaling=0;
73 self.compute_bp_grd=0;
74 self.isgrd=0;
75 self.sealevelloading=1;
76
77 %numerical discretization accuracy
78 self.degacc=.01;
79 self.timeacc=1;
80
81 %how many time steps we skip before we run solidearthsettings solver during transient
82 self.runfrequency=1;
83
84 %horizontal displacement? (not on by default)
85 self.horiz=0;
86
87 %cross section for Ivins model
88 self.cross_section_shape=1; %square as default (see iedge in GiaDeflectionCorex)
89
90 %no grd model by default:
91 self.grdmodel=1;
92
93 end % }}}
94 function disp(self) % {{{
95 disp(sprintf(' solidearth settings:'));
96 disp(sprintf(' core:'));
97 fielddisplay(self,'isgrd','compute GRD patterns (default: 1)');
98 fielddisplay(self,'grdmodel','type of deformation model, 0 for no GRD, 1 for spherical GRD model (SESAW model), 2 for half-space planar GRD (visco-elastic model from Ivins)');
99 fielddisplay(self,'runfrequency','How many time steps we let masstransport core accumulate changes before each run of the sealevelchange core (default: 1, i.e run slc every time step)');
100 disp(sprintf(' computational flags:'));
101 fielddisplay(self,'selfattraction','enables surface mass load to perturb the gravity field');
102 fielddisplay(self,'elastic','enables elastic deformation from surface loading');
103 fielddisplay(self,'viscous','enables viscous deformation from surface loading');
104 fielddisplay(self,'rotation','enables polar motion to feedback on the GRD fields');
105 fielddisplay(self,'compute_bp_grd','compute GRD patterns for bottom pressure loads (default: 1)');
106 fielddisplay(self,'cross_section_shape','1: square-edged (default). 2: elliptical. See iedge in GiaDeflectionCore. Used only for grdmodel=2 only');
107 disp(sprintf(' resolution:'));
108 fielddisplay(self,'degacc','spatial accuracy (default: .01 deg) for numerical discretization of the Green''s functions');
109 fielddisplay(self,'timeacc','time accuracy (default: 1 yr) for numerical discretization of the Green''s functions');
110 disp(sprintf(' sea-level equation:'));
111 fielddisplay(self,'grdocean','does this planet have an ocean, if set to 1: global water mass is conserved in GRD module (default: 1)');
112 fielddisplay(self,'sealevelloading','enables surface loading from sea-level change (default: 1)');
113 fielddisplay(self,'maxiter','maximum number of nonlinear iterations');
114 fielddisplay(self,'reltol','sea level change relative convergence criterion (default, NaN: not applied)');
115 fielddisplay(self,'abstol','sea level change absolute convergence criterion(default, NaN: not applied)');
116 fielddisplay(self,'ocean_area_scaling','correction for model representation of ocean area (default: No correction)');
117
118 end % }}}
119 function md = checkconsistency(self,md,solution,analyses) % {{{
120
121 if ~ismember('SealevelchangeAnalysis',analyses) | (strcmp(solution,'TransientSolution') & md.transient.isslc==0),
122 return;
123 end
124 md = checkfield(md,'fieldname','solidearth.settings.reltol','size',[1 1]);
125 md = checkfield(md,'fieldname','solidearth.settings.abstol','size',[1 1]);
126 md = checkfield(md,'fieldname','solidearth.settings.maxiter','size',[1 1],'>=',1);
127 md = checkfield(md,'fieldname','solidearth.settings.runfrequency','size',[1 1],'>=',1);
128 md = checkfield(md,'fieldname','solidearth.settings.degacc','size',[1 1],'>=',1e-10);
129 md = checkfield(md,'fieldname','solidearth.settings.timeacc','size',[1 1],'>',0);
130 md = checkfield(md,'fieldname','solidearth.settings.horiz','NaN',1,'Inf',1,'values',[0 1]);
131 md = checkfield(md,'fieldname','solidearth.settings.grdmodel','>=',0,'<=',2);
132 md = checkfield(md,'fieldname','solidearth.settings.cross_section_shape','numel',[1],'values',[1,2]);
133
134 if self.elastic==1 & self.selfattraction==0,
135 error('solidearthsettings checkconsistency error message: need selfattraction on if elastic flag is set');
136 end
137 if self.viscous==1 & self.elastic==0,
138 error('solidearthsettings checkconsistency error message: need elastic on if viscous flag is set');
139 end
140 if self.rotation==1 & self.elastic==0,
141 error('solidearthsettings checkconsistency error message: need elastic on if rotation flag is set');
142 end
143
144 %a GRD computation has been requested, make some checks on the nature of the meshes provided.
145 if self.isgrd,
146 if strcmpi(class(md.mesh),'mesh3dsurface'),
147 if self.grdmodel==2,
148 error('model requires a 2D mesh to run gia Ivins computations (change mesh from mesh3dsurface to mesh2d)');
149 end
150 else
151 if self.grdmodel==1,
152 error('model requires a 3D surface mesh to run GRD computations (change mesh from mesh2d to mesh3dsurface)');
153 end
154 end
155 if self.sealevelloading==1 & self.grdocean==0
156 error('solidearthsettings checkconsistency error message: need grdocean on if sealevelloading flag is set');
157 end
158 end
159
160 if self.compute_bp_grd==1 & md.solidearth.settings.isgrd==0,
161 error('solidearthsettings checkconsistency error message; if bottom pressure grd patterns are requested, solidearth settings class should have isgrd flag on');
162 end
163
164 end % }}}
165 function marshall(self,prefix,md,fid) % {{{
166 WriteData(fid,prefix,'object',self,'fieldname','reltol','name','md.solidearth.settings.reltol','format','Double');
167 WriteData(fid,prefix,'object',self,'fieldname','abstol','name','md.solidearth.settings.abstol','format','Double');
168 WriteData(fid,prefix,'object',self,'fieldname','maxiter','name','md.solidearth.settings.maxiter','format','Integer');
169 WriteData(fid,prefix,'object',self,'fieldname','selfattraction','name','md.solidearth.settings.selfattraction','format','Boolean');
170 WriteData(fid,prefix,'object',self,'fieldname','elastic','name','md.solidearth.settings.elastic','format','Boolean');
171 WriteData(fid,prefix,'object',self,'fieldname','viscous','name','md.solidearth.settings.viscous','format','Boolean');
172 WriteData(fid,prefix,'object',self,'fieldname','rotation','name','md.solidearth.settings.rotation','format','Boolean');
173 WriteData(fid,prefix,'object',self,'fieldname','rotation','name','md.solidearth.settings.satellitegravity','format','Boolean');
174 WriteData(fid,prefix,'object',self,'fieldname','grdocean','name','md.solidearth.settings.grdocean','format','Boolean');
175 WriteData(fid,prefix,'object',self,'fieldname','ocean_area_scaling','name','md.solidearth.settings.ocean_area_scaling','format','Boolean');
176 WriteData(fid,prefix,'object',self,'fieldname','runfrequency','name','md.solidearth.settings.runfrequency','format','Integer');
177 WriteData(fid,prefix,'object',self,'fieldname','degacc','name','md.solidearth.settings.degacc','format','Double');
178 WriteData(fid,prefix,'object',self,'fieldname','timeacc','name','md.solidearth.settings.timeacc','format','Double','scale',md.constants.yts);
179 WriteData(fid,prefix,'object',self,'fieldname','horiz','name','md.solidearth.settings.horiz','format','Integer');
180 WriteData(fid,prefix,'object',self,'fieldname','sealevelloading','name','md.solidearth.settings.sealevelloading','format','Integer');
181 WriteData(fid,prefix,'object',self,'fieldname','isgrd','name','md.solidearth.settings.isgrd','format','Integer');
182 WriteData(fid,prefix,'object',self,'fieldname','compute_bp_grd','name','md.solidearth.settings.compute_bp_grd','format','Integer');
183 WriteData(fid,prefix,'object',self,'fieldname','grdmodel','name','md.solidearth.settings.grdmodel','format','Integer');
184 WriteData(fid,prefix,'object',self,'fieldname','cross_section_shape','name','md.solidearth.settings.cross_section_shape','format','Integer');
185 end % }}}
186 function self = extrude(self,md) % {{{
187 end % }}}
188 function savemodeljs(self,fid,modelname) % {{{
189 % TODO: Update the following fields so that coverage is complete
190 writejsdouble(fid,[modelname '.solidearth.settings.maxiter'],self.maxiter);
191 writejsdouble(fid,[modelname '.solidearth.settings.reltol'],self.reltol);
192 writejsdouble(fid,[modelname '.solidearth.settings.abstol'],self.abstol);
193 writejsdouble(fid,[modelname '.solidearth.settings.selfattraction'],self.selfattraction);
194 writejsdouble(fid,[modelname '.solidearth.settings.elastic'],self.elastic);
195 writejsdouble(fid,[modelname '.solidearth.settings.viscous'],self.viscous);
196 writejsdouble(fid,[modelname '.solidearth.settings.rotation'],self.rotation);
197 writejsdouble(fid,[modelname '.solidearth.settings.grdocean'],self.grdocean);
198 writejsdouble(fid,[modelname '.solidearth.settings.ocean_area_scaling'],self.ocean_area_scaling);
199 writejsdouble(fid,[modelname '.solidearth.settings.run_frequency'],self.run_frequency);
200 writejsdouble(fid,[modelname '.solidearth.settings.degacc'],self.degacc);
201 writejsdouble(fid,[modelname '.solidearth.settings.timeacc'],self.timeacc);
202 writejsdouble(fid,[modelname '.solidearth.settings.cross_section_shape'],self.cross_section_shape);
203 end % }}}
204 end
205end
Note: See TracBrowser for help on using the repository browser.