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

Last change on this file since 21341 was 21341, checked in by Mathieu Morlighem, 8 years ago

merged trunk-jpl and trunk for revision 21337

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 = extrude(self,md) % {{{
14 self.groundedice_melting_rate=project3d(md,'vector',self.groundedice_melting_rate,'type','node','layer',1);
15 self.floatingice_melting_rate=project3d(md,'vector',self.floatingice_melting_rate,'type','node','layer',1);
16 self.geothermalflux=project3d(md,'vector',self.geothermalflux,'type','node','layer',1); %bedrock only gets geothermal flux
17 end % }}}
18 function self = basalforcings(varargin) % {{{
19 switch nargin
20 case 0
21 self=setdefaultparameters(self);
22 otherwise
23 error('constructor not supported');
24 end
25 end % }}}
26 function self = initialize(self,md) % {{{
27
28 if isnan(self.groundedice_melting_rate),
29 self.groundedice_melting_rate=zeros(md.mesh.numberofvertices,1);
30 disp(' no basalforcings.groundedice_melting_rate specified: values set as zero');
31 end
32
33 if isnan(self.floatingice_melting_rate),
34 self.floatingice_melting_rate=zeros(md.mesh.numberofvertices,1);
35 disp(' no basalforcings.floatingice_melting_rate specified: values set as zero');
36 end
37
38 end % }}}
39 function self = setdefaultparameters(self) % {{{
40
41 end % }}}
42 function md = checkconsistency(self,md,solution,analyses) % {{{
43
44 if ismember('MasstransportAnalysis',analyses) & ~(strcmp(solution,'TransientSolution') & md.transient.ismasstransport==0),
45 md = checkfield(md,'fieldname','basalforcings.groundedice_melting_rate','NaN',1,'Inf',1,'timeseries',1);
46 md = checkfield(md,'fieldname','basalforcings.floatingice_melting_rate','NaN',1,'Inf',1,'timeseries',1);
47 end
48 if ismember('BalancethicknessAnalysis',analyses),
49 md = checkfield(md,'fieldname','basalforcings.groundedice_melting_rate','NaN',1,'Inf',1,'size',[md.mesh.numberofvertices 1]);
50 md = checkfield(md,'fieldname','basalforcings.floatingice_melting_rate','NaN',1,'Inf',1,'size',[md.mesh.numberofvertices 1]);
51 end
52 if ismember('ThermalAnalysis',analyses) & ~(strcmp(solution,'TransientSolution') & md.transient.isthermal==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 md = checkfield(md,'fieldname','basalforcings.geothermalflux','NaN',1,'Inf',1,'timeseries',1,'>=',0);
56 end
57 end % }}}
58 function disp(self) % {{{
59 disp(sprintf(' basal forcings parameters:'));
60
61 fielddisplay(self,'groundedice_melting_rate','basal melting rate (positive if melting) [m/yr]');
62 fielddisplay(self,'floatingice_melting_rate','basal melting rate (positive if melting) [m/yr]');
63 fielddisplay(self,'geothermalflux','geothermal heat flux [W/m^2]');
64
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',md.constants.yts)
72 WriteData(fid,prefix,'object',self,'fieldname','floatingice_melting_rate','format','DoubleMat','mattype',1,'scale',1./yts,'timeserieslength',md.mesh.numberofvertices+1,'yts',md.constants.yts)
73 WriteData(fid,prefix,'object',self,'fieldname','geothermalflux','format','DoubleMat','mattype',1,'timeserieslength',md.mesh.numberofvertices+1,'yts',md.constants.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.