Changeset 23781


Ignore:
Timestamp:
03/08/19 13:34:33 (6 years ago)
Author:
Mathieu Morlighem
Message:

CHG: working on ISMIP6 forcing

Location:
issm/trunk-jpl/src/m
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • issm/trunk-jpl/src/m/classes/basalforcingsismip6.m

    r23777 r23781  
    1111                tf                        = NaN;
    1212                tf_depths                 = NaN;
    13                 tf_times                  = NaN;
    1413                delta_t                   = NaN;
    1514                geothermalflux            = NaN;
     
    5453                        md = checkfield(md,'fieldname','basalforcings.basin_id','Inf',1,'>=',0,'<=',md.basalforcings.num_basins,'size',[md.mesh.numberofelements 1]);
    5554                        md = checkfield(md,'fieldname','basalforcings.gamma_0','numel',1,'NaN',1,'Inf',1,'>',0);
    56                         md = checkfield(md,'fieldname','basalforcings.tf_times','NaN',1,'Inf',1);
    5755                        md = checkfield(md,'fieldname','basalforcings.tf_depths','NaN',1,'Inf',1);
    58                         md = checkfield(md,'fieldname','basalforcings.tf','size',[md.mesh.numberofvertices,numel(md.basalforcings.delta_t),numel(md.basalforcings.tf_depths)],'NaN',1,'Inf',1);
    5956                        md = checkfield(md,'fieldname','basalforcings.delta_t','NaN',1,'Inf',1,'numel',md.basalforcings.num_basins);
    6057                        md = checkfield(md,'fieldname','basalforcings.geothermalflux','NaN',1,'Inf',1,'>=',0,'timeseries',1);
    6158                        md = checkfield(md,'fieldname','basalforcings.groundedice_melting_rate','NaN',1,'Inf',1,'timeseries',1);
     59
     60                        md = checkfield(md,'fieldname','basalforcings.tf','size',[1,1,numel(md.basalforcings.tf_depths)]);
     61                        for i=1:numel(md.basalforcings.tf_depths)
     62                                md = checkfield(md,'fieldname',['basalforcings.tf{' num2str(i) '}'],'field',md.basalforcings.tf{i},'size',[md.mesh.numberofvertices+1 NaN],'NaN',1,'Inf',1,'>=',0,'timeseries',1);
     63                        end
    6264
    6365                end % }}}
     
    6870                        fielddisplay(self,'gamma_0','melt rate coefficient (m/yr)');
    6971                        fielddisplay(self,'tf_depths','Number of vertical layers in ocean thermal forcing dataset');
    70                         fielddisplay(self,'tf_times','time for each tf (in yr) ');
    7172                        fielddisplay(self,'tf','thermal forcing (ocean temperature minus freezing point) (degrees C)');
    7273                        fielddisplay(self,'delta_t','Ocean temperature correction per basin (degrees C)');
     
    7778                function marshall(self,prefix,md,fid) % {{{
    7879
    79          %NEED TO ADD TF
    8080                        yts=md.constants.yts;
    8181
    82                         WriteData(fid,prefix,'name','md.basalforcings.model','data',6,'format','Integer');
     82                        WriteData(fid,prefix,'name','md.basalforcings.model','data',7,'format','Integer');
    8383                        WriteData(fid,prefix,'object',self,'fieldname','num_basins','format','Integer');
    8484                        WriteData(fid,prefix,'object',self,'fieldname','basin_id','data',self.basin_id-1,'name','md.basalforcings.basin_id','format','IntMat','mattype',2);   %0-indexed
    8585                        WriteData(fid,prefix,'object',self,'fieldname','gamma_0','format','Double');
    86                         WriteData(fid,prefix,'object',self,'fieldname','tf_depths','format','DoubleMat','name','md.basalforcings.tf_depths','yts',md.constants.yts);
     86                        WriteData(fid,prefix,'object',self,'fieldname','tf_depths','format','DoubleMat','name','md.basalforcings.tf_depths');
     87                        WriteData(fid,prefix,'object',self,'fieldname','tf','format','MatArray','name','md.basalforcings.tf','timeserieslength',md.mesh.numberofvertices+1,'yts',md.constants.yts);
    8788                        WriteData(fid,prefix,'object',self,'fieldname','delta_t','format','DoubleMat','name','md.basalforcings.delta_t','timeserieslength',md.mesh.numberofvertices+1,'yts',md.constants.yts);
    8889                        WriteData(fid,prefix,'object',self,'fieldname','geothermalflux','format','DoubleMat','name','md.basalforcings.geothermalflux','mattype',1,'timeserieslength',md.mesh.numberofelements+1,'yts',md.constants.yts);
  • issm/trunk-jpl/src/m/solve/WriteData.m

    r23767 r23781  
    3333
    3434%Scale data if necesarry
    35 if exist(options,'scale'),
    36         scale = getfieldvalue(options,'scale');
    37         if size(data,1)==timeserieslength,
    38                 data(1:end-1,:) = scale.*data(1:end-1,:);
    39         else
    40                 data  = scale.*data;
    41         end
    42 end
    43 if(size(data,1)==timeserieslength),
    44         yts = getfieldvalue(options,'yts');
    45         data(end,:) = data(end,:)*yts;
     35if strcmpi(format,'MatArray')
     36        for i=1:numel(data)
     37                if exist(options,'scale'),
     38                        scale = getfieldvalue(options,'scale');
     39                        if size(data{i},1)==timeserieslength,
     40                                data{i}(1:end-1,:) = scale.*data{i}(1:end-1,:);
     41                        else
     42                                data{i} = scale.*data{i};
     43                        end
     44                end
     45                if size(data{i},1)==timeserieslength,
     46                        yts = getfieldvalue(options,'yts');
     47                        data{i}(end,:) = data{i}(end,:)*yts;
     48                end
     49        end
     50else
     51        if exist(options,'scale'),
     52                scale = getfieldvalue(options,'scale');
     53                if size(data,1)==timeserieslength,
     54                        data(1:end-1,:) = scale.*data(1:end-1,:);
     55                else
     56                        data  = scale.*data;
     57                end
     58        end
     59        if(size(data,1)==timeserieslength),
     60                yts = getfieldvalue(options,'yts');
     61                data(end,:) = data(end,:)*yts;
     62        end
    4663end
    4764
     
    148165        %Get size
    149166        s=size(data);
     167
     168        if numel(s)~=2
     169                error('matrices that that have more than 2 dimensions are not supported');
     170        end
     171
    150172        %if matrix = NaN, then do not write anything
    151173        if (s(1)==1 & s(2)==1 & isnan(data)),
Note: See TracChangeset for help on using the changeset viewer.