forked from wardvp/EBFM-glacier
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathINIT_variables.m
78 lines (69 loc) · 5.07 KB
/
INIT_variables.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%% INITIAL CONDITIONS:
%%% Read initial conditions at starting time from restart file or set
%%% manually
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function [OUT,IN,OUTFILE] = INIT_variables(C,grid,io)
OUT = struct; % structure containing model output variables
IN = struct; % structure containing model input variables
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%% SET INITIAL CONDITIONS AT START OF SIMULATION
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Start from restart file
if (io.readbootfile)
disp('Initialize from restart file...');
cd(io.rebootdir);
load(io.bootfilein);
OUT = boot;
cd(io.homedir);
% Start from preset initial conditions
else
disp('Initialize from manually set conditions...');
OUT.Tsurf(1:grid.gpsum,1) = 273.15; % surface temperature (K)
OUT.subT(1:grid.gpsum,1:grid.nl) = 265.0; % vertical temperatures (K)
OUT.subW(1:grid.gpsum,1:grid.nl) = 0.0; % vertical irreducible water content (kg)
OUT.subS(1:grid.gpsum,1:grid.nl) = 0.0; % vertical slush water content (kg)
OUT.subD(1:grid.gpsum,1:grid.nl) = C.Dice; % vertical densities (kg m-3)
OUT.subTmean = OUT.subT; % vertical annual mean layer temperature (K)
OUT.timelastsnow(1:grid.gpsum,1) = 1.0; % timestep of last snow fall (days)
OUT.ys(1:grid.gpsum,1) = 500.0; % annual snow fall (mm w.e.)
OUT.subZ(1:grid.gpsum,1:grid.nl) = grid.max_subZ;
OUT.alb_snow(1:grid.gpsum,1) = C.alb_fresh; % snow albedo
OUT.snowmass(1:grid.gpsum,1) = 0.0; % snow mass (m w.e.)
if grid.doubledepth % vertical layer depths (m)
OUT.subZ(grid.mask==1,1:grid.split(1)-1) = grid.max_subZ;
if length(grid.split)>1
for n=2:length(grid.split)
OUT.subZ(grid.mask==1,grid.split(n-1): ...
grid.split(n)-1) = (2.0^(n-1))*grid.max_subZ;
end
end
OUT.subZ(grid.mask==1,grid.split(end):grid.nl) = ...
(2.0^length(grid.split))*grid.max_subZ;
end
end
% Declare non-initialized variables
OUT.cmb_cumulative(1:grid.gpsum,1) = 0.0; % cumulative climatic mass balance (m w.e.)
OUT.cmb(1:grid.gpsum,1) = 0.0; % climatic mass balance (m w.e.)
OUT.subK(1:grid.gpsum,1:grid.nl) = 0.0; % vertical conductivity (m2 s-1)
OUT.subCeff(1:grid.gpsum,1:grid.nl) = 0.0; % vertical effective heat capacity (J m-3 K)
OUT.subWvol(1:grid.gpsum,1:grid.nl) = 0.0; % vertical volumetric water content (fraction)
OUT.surfH(1:grid.gpsum,1) = 0.0; % surface height (m)
OUT.Dfreshsnow(1:grid.gpsum,1) = 0.0; % fresh snow density (kg m-3)
OUT.tstar(1:grid.gpsum,1) = 0.0; % albedo decay timescale (days)
OUT.runoff_irr_deep_mean(1:grid.gpsum,1) = 0.0; % runoff of irreducible water below base of the model (m w.e.)
IN.T(1:grid.gpsum,1) = 0.0; % air temperature (K)
IN.P(1:grid.gpsum,1) = 0.0; % precipitation (m w.e.)
IN.snow(1:grid.gpsum,1) = 0.0; % snow precip (m w.e.)
IN.rain(1:grid.gpsum) = 0.0; % rain precip (m w.e.)
IN.yearsnow(1:grid.gpsum,1:grid.nl) = 0.0; % annual snow precip (m w.e.)
IN.logyearsnow(1:grid.gpsum,1:grid.nl) = 0.0; % annual snow precip (log m w.e.)
IN.C(1:grid.gpsum,1) = 0.0; % cloud cover (fraction)
IN.WS(1:grid.gpsum,1) = 0.0; % wind speed (m s-1)
IN.RH(1:grid.gpsum,1) = 0.0; % relative humidity (fraction)
IN.q(1:grid.gpsum,1) = 0.0; % specific humidity (g kg-1)
IN.VP(1:grid.gpsum,1) = 0.0; % vapor pressure (Pa)
IN.Dair(1:grid.gpsum,1) = 0.0; % air density (kg m-3)
IN.Pres(1:grid.gpsum,1) = 0.0; % air pressure (Pa)
OUTFILE = struct; % output to be saved to files
end