Changeset 2092
- Timestamp:
- Feb 7, 2019, 11:33:33 AM (6 years ago)
- Location:
- trunk/LMDZ.GENERIC
- Files:
-
- 3 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/LMDZ.GENERIC/README
r2071 r2092 1444 1444 - remove useless flag "iflag_thermals_alim" in thermcell_alim, thermcell_mod and thermcell_plume 1445 1445 - replace watersat subroutine by Psat_water in the thermal plume model, cf. revision 1993 or 29/08/2018 JL comment. 1446 1447 ==07/02/2018 == AB 1448 - uncomment two "corrections" in thermcell_flux. They are used only if iflag_thermals_optflux is set to 0 1449 - remove useless parameter fact_shell in thermcell_mod -
trunk/LMDZ.GENERIC/libf/phystd/thermcell_flux.F90
r2060 r2092 159 159 160 160 !~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 161 ! AB : I commentthe correction and replace it by an uncompromising test.161 ! AB : I remove the correction and replace it by an uncompromising test. 162 162 ! According to the previous derivations, we MUST have positive mass flux 163 163 ! everywhere! Indeed, as soon as fm becomes negative, the plume stops. … … 186 186 ! Test sur fraca constante ou croissante au-dessus de lalim 187 187 !------------------------------------------------------------------------------ 188 ! AB : do we have to decree that?189 ! IF (iflag_thermals_optflux.eq.0) THEN190 !DO ig=1,ngrid191 !IF (l.ge.lalim(ig).and.l.le.lmax(ig).and.(zw2(ig,l+1).gt.1.e-10).and.(zw2(ig,l).gt.1.e-10) ) THEN192 !zzz = fm(ig,l) * rhobarz(ig,l+1) * zw2(ig,l+1) &193 !& / (rhobarz(ig,l) * zw2(ig,l))194 !195 !IF (fm(ig,l+1).gt.zzz) THEN196 !detr(ig,l) = detr(ig,l) + fm(ig,l+1) - zzz197 !fm(ig,l+1) = zzz198 !ncorecfm4 = ncorecfm4 + 1199 !ENDIF200 !ENDIF201 !ENDDO202 !ENDIF188 ! AB : Do we have to decree that? If so, set iflag_thermals_optflux to 0 189 IF (iflag_thermals_optflux==0) THEN 190 DO ig=1,ngrid 191 IF (l.ge.lalim(ig).and.l.le.lmax(ig).and.(zw2(ig,l+1).gt.1.e-10).and.(zw2(ig,l).gt.1.e-10) ) THEN 192 zzz = fm(ig,l) * rhobarz(ig,l+1) * zw2(ig,l+1) & 193 & / (rhobarz(ig,l) * zw2(ig,l)) 194 195 IF (fm(ig,l+1).gt.zzz) THEN 196 detr(ig,l) = detr(ig,l) + fm(ig,l+1) - zzz 197 fm(ig,l+1) = zzz 198 ncorecfm4 = ncorecfm4 + 1 199 ENDIF 200 ENDIF 201 ENDDO 202 ENDIF 203 203 204 204 !------------------------------------------------------------------------------ 205 205 ! Test sur flux de masse constant ou decroissant au-dessus de lalim 206 206 !------------------------------------------------------------------------------ 207 ! AB : do we have to decree that?208 !IF (iflag_thermals_optflux==0) THEN209 !DO ig=1,ngrid210 !IF ((fm(ig,l+1).gt.fm(ig,l)).and.(l.gt.lalim(ig))) then211 !f_old = fm(ig,l+1)212 !fm(ig,l+1) = fm(ig,l)213 !detr(ig,l) = detr(ig,l) + f_old - fm(ig,l+1)214 !ncorecfm5 = ncorecfm5 + 1215 !ENDIF216 !ENDDO217 !ENDIF207 ! AB : Do we have to decree that? If so, set iflag_thermals_optflux to 0 208 IF (iflag_thermals_optflux==0) THEN 209 DO ig=1,ngrid 210 IF ((fm(ig,l+1).gt.fm(ig,l)).and.(l.gt.lalim(ig))) then 211 f_old = fm(ig,l+1) 212 fm(ig,l+1) = fm(ig,l) 213 detr(ig,l) = detr(ig,l) + f_old - fm(ig,l+1) 214 ncorecfm5 = ncorecfm5 + 1 215 ENDIF 216 ENDDO 217 ENDIF 218 218 219 219 !------------------------------------------------------------------------------ … … 488 488 489 489 !~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 490 ! AB : test added to avoid problem when lmax = 0, which is not a 491 ! fortran array index. 490 ! AB : test added to avoid problem when lmax = 0, which is not a fortran index. 492 491 !~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 493 492 IF (lmax(ig).gt.0) THEN … … 505 504 IF (prt_level.ge.1) THEN 506 505 507 ! AB : those tests were removed for their uselessness.506 ! AB : those outputs are commented for their uselessness. 508 507 ! IF (ncorecfm2.ge.1) THEN 509 508 ! print *, 'WARNING: Outgoing mass flux has negative value(s)!' … … 511 510 ! ENDIF 512 511 513 ! AB : those tests were removed because I don't know if we should decree them. 514 ! IF (ncorecfm4.ge.1) THEN 515 ! print *, 'WARNING: Deacreasing updraft fraction above lalim!'516 ! print *, 'in', ncorecfm4, 'point(s)' 517 ! ENDIF 518 !IF (ncorecfm5.ge.1) THEN519 !print *, 'WARNING: Increasing mass flux above lalim!'520 !print *, 'in', ncorecfm5, 'point(s)'521 !ENDIF512 IF (ncorecfm4.ge.1) THEN 513 print *, 'WARNING: Deacreasing updraft fraction above lalim!' 514 print *, 'in', ncorecfm4, 'point(s)' 515 ENDIF 516 517 IF (ncorecfm5.ge.1) THEN 518 print *, 'WARNING: Increasing mass flux above lalim!' 519 print *, 'in', ncorecfm5, 'point(s)' 520 ENDIF 522 521 523 522 IF (ncorecfm6.ge.1) THEN … … 526 525 ENDIF 527 526 528 ! AB : th at test was removed because I don't know if we should decree it.527 ! AB : those outputs are commented because corresponding test is also commented. 529 528 ! IF (ncorecfm7.ge.1) THEN 530 529 ! print *, 'WARNING: Detrainment is greater than mass flux!' -
trunk/LMDZ.GENERIC/libf/phystd/thermcell_mod.F90
r2069 r2092 1 1 MODULE thermcell_mod 2 3 IMPLICIT NONE4 5 2 3 IMPLICIT NONE 4 5 6 6 ! Flags for computations 7 !default8 INTEGER,PARAMETER :: iflag_thermals_optflux = 0 ! 0 9 INTEGER,PARAMETER :: iflag_thermals_closure = 2 ! 2 10 INTEGER,PARAMETER :: iflag_thermals = 18 ! 18 11 12 ! Flags for diagnoses13 14 LOGICAL,PARAMETER :: sorties = .false. !false15 INTEGER,PARAMETER :: iflag_trig_bl = 1 !116 INTEGER,PARAMETER :: iflag_clos_bl = 1 !117 INTEGER,PARAMETER :: iflag_coupl = 5 !518 7 ! default 8 INTEGER,PARAMETER :: iflag_thermals_optflux = 1 ! 0 ! 9 INTEGER,PARAMETER :: iflag_thermals_closure = 2 ! 2 ! 10 INTEGER,PARAMETER :: iflag_thermals = 18 ! 18 ! 11 12 ! Flags for (terrestrial) diagnoses 13 14 LOGICAL,PARAMETER :: sorties = .false. ! false 15 INTEGER,PARAMETER :: iflag_trig_bl = 1 ! 1 16 INTEGER,PARAMETER :: iflag_clos_bl = 1 ! 1 17 INTEGER,PARAMETER :: iflag_coupl = 5 ! 5 18 19 19 ! Physical parameters 20 21 REAL,PARAMETER :: fact_thermals_ed_dz = 0.007 ! 0.007 22 REAL,PARAMETER :: r_aspect_thermals = 2.0 ! 23 REAL,PARAMETER :: tau_thermals = 0. ! 0. 24 REAL,PARAMETER :: betalpha = 0.9 ! 0.9 25 REAL,PARAMETER :: afact = 2./3. ! 2./3. 26 REAL,PARAMETER :: fact_epsilon = 0.000 ! 0.002 27 REAL,PARAMETER :: detr_q_power = 0.5 ! 0.5 28 REAL,PARAMETER :: detr_q_coef = 0.012 ! 0.012 29 REAL,PARAMETER :: mix0 = 0. ! 0. 30 REAL,PARAMETER :: detr_min = 1.d-5 ! 1.e-5 31 REAL,PARAMETER :: entr_min = 1.d-5 ! 1.e-5 32 REAL,PARAMETER :: alphamax = 0.7 ! 33 REAL,PARAMETER :: fomass_max = 0.5 ! 34 REAL,PARAMETER :: fact_shell = 1. ! 1. 35 REAL,PARAMETER :: pres_limit = 1.e5 ! 1.e5 36 20 21 REAL,PARAMETER :: fact_thermals_ed_dz = 0.007 ! 0.007 ! 22 REAL,PARAMETER :: r_aspect_thermals = 1.0 ! Aspect ratio of the thermals (width / height) 23 REAL,PARAMETER :: tau_thermals = 0. ! 0. Relaxation time 24 REAL,PARAMETER :: betalpha = 0.9 ! 0.9 ! 25 REAL,PARAMETER :: afact = 2./3. ! 2./3. ! 26 REAL,PARAMETER :: fact_epsilon = 0.000 ! 0.002 ! 27 REAL,PARAMETER :: detr_q_power = 0.5 ! 0.5 ! 28 REAL,PARAMETER :: detr_q_coef = 0.012 ! 0.012 ! 29 REAL,PARAMETER :: mix0 = 0. ! 0. ! 30 REAL,PARAMETER :: detr_min = 1.d-5 ! 1.e-5 Minimal detrainment value 31 REAL,PARAMETER :: entr_min = 1.d-5 ! 1.e-5 Maximal detrainment value 32 REAL,PARAMETER :: alphamax = 0.7 ! Maximal permitted updraft fraction 33 REAL,PARAMETER :: fomass_max = 0.5 ! Maximal permitted outgoing layer mass fraction 34 REAL,PARAMETER :: pres_limit = 1.e5 ! 1.e5 ! 35 37 36 !~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 38 37 ! AB : linf is used to set the lowest possible first level because we allow it … … 40 39 ! first layer for gas giant. 41 40 ! If there is a surface, it has to be set to 1. 42 ! If someone want to call more than once the thermal plume model in one43 ! or more grid point, this variable must become a saved array of INTEGER44 ! with sizengrid.41 ! If someone want to call more than once the thermal plume model in some 42 ! grid points, this variable may become a saved array of INTEGER with size 43 ! ngrid. 45 44 !~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 46 INTEGER,PARAMETER :: linf = 2 47 45 INTEGER,PARAMETER :: linf = 2 ! 1 46 48 47 !~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 49 ! AB : d_temp is an artificial virtual potential temperature added in layer50 ! l inf which can be used to force convection to begin in it.48 ! AB : d_temp is an artificial virtual potential temperature offset added in 49 ! layer linf which can be used to force convection to begin in it. 51 50 !~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 52 REAL,PARAMETER :: d_temp = 10.! 0.53 51 REAL,PARAMETER :: d_temp = 0. ! 0. 52 54 53 ! Parameters for diagnoses 55 56 REAL,PARAMETER :: alp_bl_k = 0.5 ! 0.557 54 55 REAL,PARAMETER :: alp_bl_k = 0.5 ! 0.5 56 58 57 ! Physical constants 59 60 REAL,SAVE :: RTT61 REAL,SAVE :: RG62 REAL,SAVE :: RKAPPA63 REAL,SAVE :: RPI64 REAL,SAVE :: RD65 58 59 REAL,SAVE :: RTT 60 REAL,SAVE :: RG 61 REAL,SAVE :: RKAPPA 62 REAL,SAVE :: RPI 63 REAL,SAVE :: RD 64 66 65 !$OMP THREADPRIVATE(RTT, RG, RKAPPA, RPI, RD) 67 66 68 67 !~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 69 68 ! AB : Parameters needed only for a loop in thermcell_alp (diagnoses). 70 69 ! Maybe to be removed. 71 70 !~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 72 INTEGER,PARAMETER :: nbsrf = 173 74 75 CONTAINS71 INTEGER,PARAMETER :: nbsrf = 1 72 73 74 CONTAINS 76 75 77 76 SUBROUTINE init_thermcell_mod(g, rcp, r, pi, T_h2o_ice_liq, RV) 77 78 IMPLICIT NONE 79 80 REAL g 81 REAL rcp 82 REAL r 83 REAL pi 84 REAL T_h2o_ice_liq 85 REAL RV 86 87 RTT = T_h2o_ice_liq 88 RG = g 89 RKAPPA = rcp 90 RPI = pi 91 RD = r 92 93 RETURN 94 END SUBROUTINE init_thermcell_mod 78 95 79 IMPLICIT NONE80 81 REAL g82 REAL rcp83 REAL r84 REAL pi85 REAL T_h2o_ice_liq86 REAL RV87 88 RTT = T_h2o_ice_liq89 RG = g90 RKAPPA = rcp91 RPI = pi92 RD = r93 94 RETURN95 END SUBROUTINE init_thermcell_mod96 97 96 END MODULE thermcell_mod
Note: See TracChangeset
for help on using the changeset viewer.