SURFEX  V8_0
Surfex V8_0 release
 All Classes Files Functions Variables
modd_snow_par.F90
Go to the documentation of this file.
1 !SFX_LIC Copyright 1994-2014 CNRS, Meteo-France and Universite Paul Sabatier
2 !SFX_LIC This is part of the SURFEX software governed by the CeCILL-C licence
3 !SFX_LIC version 1. See LICENSE, CeCILL-C_V1-en.txt and CeCILL-C_V1-fr.txt
4 !SFX_LIC for details. version 1.
5 ! ######################
6  MODULE modd_snow_par
7 ! ######################
8 !
9 !!**** *MODD_SNOW_PAR* - declaration of parameters related
10 !! to the snow parameterization
11 !!
12 !! PURPOSE
13 !! -------
14 ! The purpose of this declarative module is to specify the
15 ! parameters related to the surface parameterization of snow.
16 !
17 !!
18 !!** IMPLICIT ARGUMENTS
19 !! ------------------
20 !! None
21 !!
22 !! REFERENCE
23 !! ---------
24 !!
25 !!
26 !! AUTHOR
27 !! ------
28 !! V. Masson *Meteo France*
29 !!
30 !! MODIFICATIONS
31 !! -------------
32 !! Original 01/2004
33 !! P. Samuelsson 10/2014 MEB complements
34 !-------------------------------------------------------------------------------
35 !
36 !* 0. DECLARATIONS
37 ! ------------
38 !
39 IMPLICIT NONE
40 !
41 !--------------------------------------------------------------------------------
42 ! Snow on the ground: Given in ini_surf_csts and/or in NAM_SURF_CSTS
43 !--------------------------------------------------------------------------------
44 !
45 ! Snow emissivity:
46 !
47 REAL, SAVE :: XEMISSN
48 !
49 ! Minimum and maximum values of the albedo of snow:
50 !
51 REAL, SAVE :: XANSMIN
52 REAL, SAVE :: XANSMAX
53 !
54 ! Minimum and maximum values of the albedo of permanet snow/ice:
55 !
56 REAL, SAVE :: XAGLAMIN
57 REAL, SAVE :: XAGLAMAX
58 !
59 ! Use recommended settings for snow albedo (FALSE = ISBA default)
60 !
61 LOGICAL,SAVE :: LMEBREC
62 !
63 ! Fraction of maximum value of the albedo of snow that is reached for melting
64 ! snow
65 !
66 REAL, SAVE :: XANSFRACMEL
67 !
68 ! Threeshold temperature above which the snow albedo starts to decrease
69 !
70 REAL, SAVE :: XTEMPANS
71 !
72 ! Minimum value of the albedo of snow reached under canopy vegetation:
73 !
74 REAL, SAVE :: XANSMINMEB
75 !
76 ! Prescribed ice albedo in 3 spectral bands for glacier simulation with CROCUS scheme.
77 REAL, SAVE :: XALBICE1,XALBICE2,XALBICE3
78 !
79 
80 ! Density threshold for ice detection in CROCUS scheme.
81 REAL, SAVE :: XRHOTHRESHOLD_ICE
82 
83 !for ageing effects
84 REAL, SAVE :: XVAGING_NOGLACIER, XVAGING_GLACIER
85 
86 ! percentage of the total pore volume to compute the max liquid water holding capacity
87 REAL, SAVE :: XPERCENTAGEPORE
88 
89 ! Height (m) of aged snow in glacier case (allows Pn=1)
90 !
91 REAL, SAVE :: XHGLA
92 !
93 ! Coefficient for calculation of snow fraction over vegetation
94 !
95 REAL, SAVE :: XWSNV
96 !
97 ! Roughness length of pure snow surface (m)
98 !
99 REAL, SAVE :: XZ0SN
100 !
101 ! Roughness length for heat of pure snow surface (m)
102 !
103 REAL, SAVE :: XZ0HSN
104 !
105 ! Roughness length ratio between ice and snow
106 REAL, SAVE :: XZ0ICEZ0SNOW
107 !
108 ! Snow Melt timescale with D95 (s): needed to prevent time step
109 ! dependence of melt when snow fraction < unity.
110 !
111 REAL, SAVE :: XTAU_SMELT
112 !
113 !--------------------------------------------------------------------------------
114 ! Snow on the ground: PARAMETER
115 !--------------------------------------------------------------------------------
116 !
117 ! Critical value of the equivalent water content
118 ! of the snow reservoir for snow fractional coverage and albedo computations
119 !
120 REAL, PARAMETER :: XWCRN = 10.0 ! (kg m-2) Veg (default value)
121 REAL, PARAMETER :: XWCRN_EXPL = 1.0 ! (kg m-2) Veg explicit
122 REAL, PARAMETER :: XWCRN_ROOF = 1.0 ! (kg m-2) Roofs
123 REAL, PARAMETER :: XWCRN_ROAD = 1.0 ! (kg m-2) Roads
124 REAL, PARAMETER :: XWCRN_VEG = 1.0 ! (kg m-2) Urban veg
125 !
126 ! Critical value of the total snow depth for ground snow fractional coverage
127 !
128 REAL, PARAMETER :: XDCRN_EXPL = 0.01 ! (m) Veg explicit
129 !
130 ! Critical value of snow emissivity
131 !
132 REAL, PARAMETER :: XEMCRIN = 0.98
133 !
134 ! Minimum and maximum values of the albedo of snow:
135 !
136 REAL, PARAMETER :: XANSMIN_ROOF = 0.30 ! (-) Roofs
137 REAL, PARAMETER :: XANSMIN_ROAD = 0.15 ! (-) Roads
138 !
139 REAL, PARAMETER :: XANSMAX_ROOF = 0.85 ! (-) Roofs
140 REAL, PARAMETER :: XANSMAX_ROAD = 0.85 ! (-) Roads
141 !
142 ! Snow aging coefficients (albedo and Force-Restore density):
143 !
144 REAL, PARAMETER :: XANS_TODRY = 0.008 ! (-) Veg (default value)
145 REAL, PARAMETER :: XANS_TODRY_ROOF = 0.008 ! (-) Roofs
146 REAL, PARAMETER :: XANS_TODRY_ROAD = 0.008 ! (-) Roads
147 REAL, PARAMETER :: XANS_TODRY_MEB = 0.016 ! (-) Surface under canopy vegetation
148 !
149 REAL, PARAMETER :: XANS_T = 0.240 ! (-) Veg (default value)
150 REAL, PARAMETER :: XANS_T_ROOF = 0.174 ! (-) Roofs
151 REAL, PARAMETER :: XANS_T_ROAD = 0.174 ! (-) Roads (alley simul)
152 REAL, PARAMETER :: XANS_T_MEB = 0.480 ! (-) Surface under canopy vegetation
153 !
154 ! Minimum and maximum values of the density of snow
155 ! for Force-Restore snow option
156 !
157 REAL, PARAMETER :: XRHOSMIN = 100. ! (kg m-3) Veg (Default value)
158 REAL, PARAMETER :: XRHOSMIN_ROOF = 100. ! (kg m-3) Roofs
159 REAL, PARAMETER :: XRHOSMIN_ROAD = 100. ! (kg m-3) Roads
160 !
161 REAL, PARAMETER :: XRHOSMAX = 300. ! (kg m-3) Veg (Default value)
162 REAL, PARAMETER :: XRHOSMAX_ROOF = 300. ! (kg m-3) Roofs
163 REAL, PARAMETER :: XRHOSMAX_ROAD = 350. ! (kg m-3) Roads
164 !
165 ! Minimum and maximum values of the density of snow
166 ! for ISBA-ES snow option
167 !
168 REAL, PARAMETER :: XRHOSMIN_ES = 50. ! (kg m-3)
169 REAL, PARAMETER :: XRHOSMAX_ES = 750. ! (kg m-3)
170 !
171 ! ISBA-ES Critical snow depth at which snow grid thicknesses constant
172 !
173 REAL, PARAMETER :: XSNOWCRITD = 0.03 ! (m)
174 !
175 ! ISBA-ES Minimum total snow depth for thermal calculations.
176 ! Used to prevent numerical problems as snow becomes vanishingly thin.
177 !
178 REAL, PARAMETER :: XSNOWDMIN = 0.000001 ! (m)
179 !
180 ! Maximum Richardson number limit for very stable conditions using the ISBA-ES 'RIL' option
181 !
182 REAL, PARAMETER :: X_RI_MAX = 0.20
183 !
184 ! ISBA-ES Maximum snow liquid water holding capacity (fraction by mass) parameters:
185 !
186 REAL, PARAMETER :: XWSNOWHOLDMAX2 = 0.10 ! (-)
187 REAL, PARAMETER :: XWSNOWHOLDMAX1 = 0.03 ! (-)
188 REAL, PARAMETER :: XSNOWRHOHOLD = 200.0 ! (kg/m3)
189 !
190 ! ISBA-ES arameters for grain size computation :
191 !
192 REAL, PARAMETER :: XSNOW_AGRAIN = 1.6e-4 ! (m)
193 REAL, PARAMETER :: XSNOW_BGRAIN = 1.1e-13 ! (m13/kg4)
194 REAL, PARAMETER :: XSNOW_CGRAIN = 0.5e-4 ! (m)
195 REAL, PARAMETER :: XDSGRAIN_MAX = 2.796e-3 ! m
196 !
197 !--------------------------------------------------------------------------------
198 ! Calibration coefficients for CROCUS and ES albedo computation
199 !--------------------------------------------------------------------------------
200 !
201 REAL, PARAMETER :: XD1 = 1., XD2 = 3., XD3 = 4., XX = 99., &
202  XVALB2 = .96, XVALB3 = 1.58, XVALB4 = .92, XVALB5 = .90, &
203  XVALB6 = 15.4, XVALB7 = 346.3, XVALB8 = 32.31, XVALB9 = .88, &
204  XVALB10 = .200, XVALB11 = .6, XVDIOP1 = 2.3E-3, XVRPRE1 = .5, &
205  XVRPRE2=1.5
206 !
207 ! for ageing effects:
208 REAL, PARAMETER :: XVPRES1 = 87000.
209 !
210 ! spectral bands
211 !
212 INTEGER, PARAMETER :: NSPEC_BAND_SNOW = 3
213 !
214 ! for spectral distribution and thickness effects
215 REAL, PARAMETER :: XVSPEC1 = .71, XVSPEC2 = .21, XVSPEC3 = .08
216 !
217 ! for thickness effects
218 REAL, PARAMETER :: XVW1 = .80, XVW2 = .20 , XVD1 = .02, XVD2 = .01
219 !
220 !--------------------------------------------------------------------------------
221 ! calibration coefficients for exctinction computation
222 REAL, PARAMETER :: XVBETA1 = 1.92E-3, XVBETA2 = 40., XVBETA3 = 1.098E-2, &
223  XVBETA4 = 100., XVBETA5 = 2000.
224 !
225 ! ISBA-ES minimum cosinus of zenithal angle
226 REAL, PARAMETER :: XMINCOSZEN = 0.01
227 !
228 !--------------------------------------------------------------------------------
229 ! ISBA-ES Thermal conductivity coefficients from Anderson (1976):
230 ! see Boone, Meteo-France/CNRM Note de Centre No. 70 (2002)
231 !
232 REAL, PARAMETER :: XSNOWTHRMCOND1 = 0.02 ! [W/(m K)]
233 REAL, PARAMETER :: XSNOWTHRMCOND2 = 2.5E-6 ! [W m5/(kg2 K)]
234 !
235 ! ISBA-ES Thermal conductivity: Implicit vapor diffn effects
236 ! (sig only for new snow OR high altitudes)
237 ! from Sun et al. (1999): based on data from Jordan (1991)
238 ! see Boone, Meteo-France/CNRM Note de Centre No. 70 (2002)
239 !
240 REAL, PARAMETER :: XSNOWTHRMCOND_AVAP = -0.06023 ! [W/(m K)]
241 REAL, PARAMETER :: XSNOWTHRMCOND_BVAP = -2.5425 ! (W/m)
242 REAL, PARAMETER :: XSNOWTHRMCOND_CVAP = -289.99 ! (K)
243 !
244 ! Crocus thermal conducitivity coefficient from Yen (1981)
245 REAL, PARAMETER :: XVRKZ6 = 1.88
246 !
247 !--------------------------------------------------------------------------------
248 ! ISBA-ES CROCUS (Pahaut 1976): snowfall density coefficients:
249 !
250 REAL, PARAMETER :: XSNOWFALL_A_SN = 109.0 ! kg/m3
251 REAL, PARAMETER :: XSNOWFALL_B_SN = 6.0 ! kg/(m3 K)
252 REAL, PARAMETER :: XSNOWFALL_C_SN = 26.0 ! kg/(m7/2 s1/2)
253 !
254 ! Coefficients for the optimal vertical grid calculation
255 REAL, PARAMETER :: XDZ1 = 0.01
256 REAL, PARAMETER :: XDZ2 = 0.0125
257 REAL, PARAMETER :: XDZ3 = 0.015
258 REAL, PARAMETER :: XDZ3_BIS = 0.03
259 REAL, PARAMETER :: XDZ4 = 0.04
260 REAL, PARAMETER :: XDZ5 = 0.05
261 REAL, PARAMETER :: XDZ_BASE = 0.02
262 REAL, PARAMETER :: XDZ_INTERNAL = 0.07
263 REAL, PARAMETER :: XSCALE_CM = 100.
264 REAL,DIMENSION(5), PARAMETER :: XDZMAX_INTERNAL = (/0.5,1.,2.,4.,10./)
265 REAL, PARAMETER :: XDZMIN_TOP_EXTREM = 0.0001
266 !
267 ! Below this threshold of snowfall, new snowfall are aggregated with surface layer to avoid numerical problems
268 ! (0.03 mm/h)
269 REAL,PARAMETER :: XSNOWFALL_THRESHOLD = 0.0333/3600.
270 
271 ! The ratio between a new surface layer thickness and the second layer surface thickness is limited to 1/10
272 REAL,PARAMETER :: XRATIO_NEWLAYER = 0.1
273 
274 ! Coefficients for cases with very thick snowpacks
275 REAL, PARAMETER :: XDEPTH_THRESHOLD1 = 3.
276 REAL, PARAMETER :: XDEPTH_THRESHOLD2 = 20.
277 REAL, PARAMETER :: XDEPTH_SURFACE = 3.
278 !
279 ! Coefficients for computing the difference in 2 snow layer characteristics
280 REAL, PARAMETER :: XDIFF_1 = 20.
281 REAL, PARAMETER :: XDIFF_MAX = 200.
282 REAL, PARAMETER :: XSCALE_DIFF = 25.
283 !
284 ! Coeefficients for snow layer splitting
285 REAL, PARAMETER :: XDZMIN_TOP = 0.01
286 REAL, PARAMETER :: XDZMIN_TOP_BIS = 0.005
287 REAL, PARAMETER :: XDZMIN_BOT = 0.02
288 REAL, PARAMETER :: XSPLIT_COEF = 8.
289 !
290 ! Coeefficients for snow layer agregation
291 REAL, PARAMETER :: XAGREG_COEF_1 = 5.
292 REAL, PARAMETER :: XAGREG_COEF_2 = 4.5
293 !
294 !--------------------------------------------------------------------------------
295 !
296 ! Calibration coefficients
297 REAL, PARAMETER :: XVTIME = 48*3600. ! characteristic time for
298 !compaction and metamorphism by wind drift
299 !
300 REAL, PARAMETER :: XVROMAX = 350. ! maximum density for
301 ! drift compaction UNIT : kg m-3
302 REAL, PARAMETER :: XVROMIN = 50. ! minimum density for
303 ! mobility computation UNIT : kg m-3
304 REAL, PARAMETER :: XVMOB1 = 0.295 ! coefficient for computing
305 ! the mobility index
306 REAL, PARAMETER :: XVMOB2 = 0.833 ! coefficient for computing
307 ! the mobility index
308 REAL, PARAMETER :: XVMOB3 = 0.583 ! coefficient for computing
309 ! the mobility index
310 REAL, PARAMETER :: XVMOB4 = -0.0583 ! coefficient for computing
311 ! the mobility index
312 REAL, PARAMETER :: XVDRIFT1 = 2.868 ! coefficient for computing
313 ! the drift index
314 REAL, PARAMETER :: XVDRIFT2 = 0.085 ! coefficient for computing
315 ! the drift index
316 REAL, PARAMETER :: XVDRIFT3 = 3.25 ! coefficient for computing
317 ! the drift index
318 REAL, PARAMETER :: XVSIZEMIN = 3.E-4 ! minimum size decrease
319 ! by drift UNIT = m
320 !
321 ! modif_EB pour sublim
322 ! a pour but de tenir compte du fait que le vent moyen est > rafales
323 ! on en tient compte egalement pour diminuer la duree de l'effet
324 REAL, PARAMETER :: XCOEF_FF = 1.25 ! coefficient for gust diagnosis from average wind
325 REAL, PARAMETER :: XCOEF_EFFECT = 1.0 ! coefficient for impact on density du drift
326 REAL, PARAMETER :: XQS_REF = 2.E-5 ! valeur de reference de ZQS pour effet neige
327 !
328 !--------------------------------------------------------------------------------
329 !
330 ! ISBA-ES snow grid parameters
331 !
332 REAL, PARAMETER, DIMENSION(3) :: XSGCOEF1 = (/0.25, 0.50, 0.25/)
333 REAL, PARAMETER, DIMENSION(2) :: XSGCOEF2 = (/0.05, 0.34/)
334 REAL, PARAMETER, DIMENSION(10) :: XSGCOEF3 = (/0.025, 0.033, 0.043, &
335  0.055, 0.071, 0.091, 0.117, 0.150, &
336  0.193, 0.247/)
337 !
338 ! Minimum total snow depth at which surface layer thickness is constant:
339 !
340 REAL, PARAMETER :: XSNOWTRANS = 0.20 ! (m)
341 REAL, PARAMETER :: XSNOWTRANS1 = 0.40 ! (m)
342 REAL, PARAMETER :: XSNOWTRANS2 = 0.6061 ! (m)
343 REAL, PARAMETER :: XSNOWTRANS3 = 0.7143 ! (m)
344 REAL, PARAMETER :: XSNOWTRANS4 = 0.9259 ! (m)
345 REAL, PARAMETER :: XSNOWTRANS5 = 1.4493 ! (m)
346 !
347 !------------------------------------------------------------------------------
348 !
349 END MODULE modd_snow_par
350 
351 
352 
353 
354 
355 
356 
357 
358 
359 
360 
361