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

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

merged trunk-jpl and trunk for revision 26742

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