source: issm/trunk/src/m/classes/basalforcings.m@ 27035

Last change on this file since 27035 was 27035, checked in by Mathieu Morlighem, 3 years ago

merged trunk-jpl and trunk for revision 27033

File size: 4.0 KB
Line 
1%BASAL FORCINGS class definition
2%
3% Usage:
4% basalforcings=basalforcings();
5
6classdef basalforcings
7 properties (SetAccess=public)
8 groundedice_melting_rate = NaN;
9 floatingice_melting_rate = NaN;
10 geothermalflux = NaN;
11 end
12 methods
13 function self = basalforcings(varargin) % {{{
14 switch nargin
15 case 0
16 self=setdefaultparameters(self);
17 case 1
18 self =structtoobj(basalforcings(),varargin{1});
19 otherwise
20 error('constructor not supported');
21 end
22 end % }}}
23 function disp(self) % {{{
24 disp(sprintf(' basal forcings parameters:'));
25
26 fielddisplay(self,'groundedice_melting_rate','basal melting rate (positive if melting) [m/yr]');
27 fielddisplay(self,'floatingice_melting_rate','basal melting rate (positive if melting) [m/yr]');
28 fielddisplay(self,'geothermalflux','geothermal heat flux [W/m^2]');
29
30 end % }}}
31 function self = extrude(self,md) % {{{
32 self.groundedice_melting_rate=project3d(md,'vector',self.groundedice_melting_rate,'type','node','layer',1);
33 self.floatingice_melting_rate=project3d(md,'vector',self.floatingice_melting_rate,'type','node','layer',1);
34 self.geothermalflux=project3d(md,'vector',self.geothermalflux,'type','node','layer',1); %bedrock only gets geothermal flux
35 end % }}}
36 function self = initialize(self,md) % {{{
37
38 if isnan(self.groundedice_melting_rate),
39 self.groundedice_melting_rate=zeros(md.mesh.numberofvertices,1);
40 disp(' no basalforcings.groundedice_melting_rate specified: values set as zero');
41 end
42
43 if isnan(self.floatingice_melting_rate),
44 self.floatingice_melting_rate=zeros(md.mesh.numberofvertices,1);
45 disp(' no basalforcings.floatingice_melting_rate specified: values set as zero');
46 end
47
48 end % }}}
49 function self = setdefaultparameters(self) % {{{
50
51 end % }}}
52 function md = checkconsistency(self,md,solution,analyses) % {{{
53
54 if ismember('MasstransportAnalysis',analyses) & ~(strcmp(solution,'TransientSolution') & md.transient.ismasstransport==0),
55 md = checkfield(md,'fieldname','basalforcings.groundedice_melting_rate','NaN',1,'Inf',1,'timeseries',1);
56 md = checkfield(md,'fieldname','basalforcings.floatingice_melting_rate','NaN',1,'Inf',1,'timeseries',1);
57 end
58 if ismember('BalancethicknessAnalysis',analyses),
59 md = checkfield(md,'fieldname','basalforcings.groundedice_melting_rate','NaN',1,'Inf',1,'size',[md.mesh.numberofvertices 1]);
60 md = checkfield(md,'fieldname','basalforcings.floatingice_melting_rate','NaN',1,'Inf',1,'size',[md.mesh.numberofvertices 1]);
61 end
62 if ismember('ThermalAnalysis',analyses) & ~(strcmp(solution,'TransientSolution') & md.transient.isthermal==0),
63 md = checkfield(md,'fieldname','basalforcings.groundedice_melting_rate','NaN',1,'Inf',1,'timeseries',1);
64 md = checkfield(md,'fieldname','basalforcings.floatingice_melting_rate','NaN',1,'Inf',1,'timeseries',1);
65 md = checkfield(md,'fieldname','basalforcings.geothermalflux','NaN',1,'Inf',1,'timeseries',1,'>=',0);
66 end
67 end % }}}
68 function marshall(self,prefix,md,fid) % {{{
69
70 yts=md.constants.yts;
71
72 WriteData(fid,prefix,'name','md.basalforcings.model','data',1,'format','Integer');
73 WriteData(fid,prefix,'object',self,'fieldname','groundedice_melting_rate','format','DoubleMat','mattype',1,'scale',1./yts,'timeserieslength',md.mesh.numberofvertices+1,'yts',yts)
74 WriteData(fid,prefix,'object',self,'fieldname','floatingice_melting_rate','format','DoubleMat','mattype',1,'scale',1./yts,'timeserieslength',md.mesh.numberofvertices+1,'yts',yts)
75 WriteData(fid,prefix,'object',self,'fieldname','geothermalflux','format','DoubleMat','mattype',1,'timeserieslength',md.mesh.numberofvertices+1,'yts',yts);
76 end % }}}
77 function savemodeljs(self,fid,modelname) % {{{
78
79 writejs1Darray(fid,[modelname '.basalforcings.groundedice_melting_rate'],self.groundedice_melting_rate);
80 writejs1Darray(fid,[modelname '.basalforcings.floatingice_melting_rate'],self.floatingice_melting_rate);
81 writejs1Darray(fid,[modelname '.basalforcings.geothermalflux'],self.geothermalflux);
82
83 end % }}}
84 end
85end
Note: See TracBrowser for help on using the repository browser.