Changeset 4590
- Timestamp:
- Jun 29, 2023, 3:03:15 AM (17 months ago)
- Location:
- LMDZ6/trunk/libf/phylmd
- Files:
-
- 1 deleted
- 3 edited
- 17 moved
Legend:
- Unmodified
- Added
- Removed
-
LMDZ6/trunk/libf/phylmd/calltherm.F90
r4143 r4590 29 29 USE indice_sol_mod 30 30 USE print_control_mod, ONLY: prt_level,lunout 31 USE lmdz_thermcell_alp, ONLY: thermcell_alp 32 USE lmdz_thermcell_main, ONLY: thermcell_main 33 USE lmdz_thermcell_old, ONLY: thermcell, thermcell_2002, thermcell_eau, calcul_sec, thermcell_sec 31 34 #ifdef ISO 32 35 use infotrac_phy, ONLY: ntiso -
LMDZ6/trunk/libf/phylmd/lmdz_thermcell_alim.F90
r4589 r4590 1 MODULE lmdz_thermcell_alim 1 2 ! 2 3 ! $Id: thermcell_plume.F90 2311 2015-06-25 07:45:24Z emillour $ 3 4 ! 5 CONTAINS 6 4 7 SUBROUTINE thermcell_alim(flag,ngrid,klev,ztv,d_temp,zlev,alim_star,lalim) 5 8 IMPLICIT NONE … … 122 125 RETURN 123 126 END 127 END MODULE lmdz_thermcell_alim -
LMDZ6/trunk/libf/phylmd/lmdz_thermcell_alp.F90
r4589 r4590 1 MODULE lmdz_thermcell_alp 1 2 ! $Id: thermcell_main.F90 2351 2015-08-25 15:14:59Z emillour $ 2 3 ! 4 CONTAINS 5 3 6 SUBROUTINE thermcell_alp(ngrid,nlay,ptimestep & ! in 4 7 & ,pplay,pplev & ! in … … 17 20 18 21 USE indice_sol_mod 22 USE lmdz_thermcell_main, ONLY : thermcell_tke_transport 19 23 IMPLICIT NONE 20 24 … … 399 403 return 400 404 end 405 END MODULE lmdz_thermcell_alp -
LMDZ6/trunk/libf/phylmd/lmdz_thermcell_closure.F90
r4589 r4590 1 MODULE lmdz_thermcell_closure 1 2 ! 2 3 ! $Header$ 3 4 ! 5 CONTAINS 6 4 7 SUBROUTINE thermcell_closure(ngrid,nlay,r_aspect,ptimestep,rho, & 5 8 & zlev,lalim,alim_star,zmax,wmax,f) … … 70 73 RETURN 71 74 end 75 END MODULE lmdz_thermcell_closure -
LMDZ6/trunk/libf/phylmd/lmdz_thermcell_down.F90
r4589 r4590 1 MODULE lmdz_thermcell_down 2 CONTAINS 3 1 4 SUBROUTINE thermcell_updown_dq(ngrid,nlay,ptimestep,lmax,eup,dup,edn,ddn,masse,trac,dtrac) 2 5 3 USE thermcell_ini_mod, ONLY: iflag_thermals_down6 USE lmdz_thermcell_ini, ONLY: iflag_thermals_down 4 7 5 8 … … 223 226 224 227 225 USE thermcell_ini_mod, ONLY : prt_level,RLvCp,RKAPPA,RETV,fact_thermals_down228 USE lmdz_thermcell_ini, ONLY : prt_level,RLvCp,RKAPPA,RETV,fact_thermals_down 226 229 IMPLICIT NONE 227 230 … … 299 302 RETURN 300 303 END 304 END MODULE lmdz_thermcell_down -
LMDZ6/trunk/libf/phylmd/lmdz_thermcell_dq.F90
r4589 r4590 1 MODULE lmdz_thermcell_dq 2 CONTAINS 3 1 4 subroutine thermcell_dq(ngrid,nlay,impl,ptimestep,fm,entr, & 2 5 & masse,q,dq,qa,lev_out) 3 6 USE print_control_mod, ONLY: prt_level 7 4 8 implicit none 5 9 … … 325 329 return 326 330 end 331 END MODULE lmdz_thermcell_dq -
LMDZ6/trunk/libf/phylmd/lmdz_thermcell_dry.F90
r4589 r4590 1 MODULE lmdz_thermcell_dry 1 2 ! 2 3 ! $Id$ 3 4 ! 5 CONTAINS 6 4 7 SUBROUTINE thermcell_dry(ngrid,nlay,zlev,pphi,ztv,alim_star, & 5 8 & lalim,lmin,zmax,wmax) … … 14 17 ! la temperature potentielle virtuelle pondérée par alim_star. 15 18 !-------------------------------------------------------------------------- 16 USE thermcell_ini_mod, ONLY: prt_level, RG19 USE lmdz_thermcell_ini, ONLY: prt_level, RG 17 20 IMPLICIT NONE 18 21 … … 164 167 RETURN 165 168 END 169 END MODULE lmdz_thermcell_dry -
LMDZ6/trunk/libf/phylmd/lmdz_thermcell_dtke.F90
r4589 r4590 1 MODULE lmdz_thermcell_dtke 2 CONTAINS 3 1 4 subroutine thermcell_dtke(ngrid,nlay,nsrf,ptimestep,fm0,entr0, & 2 5 & rg,pplev,tke) … … 122 125 return 123 126 end 127 END MODULE lmdz_thermcell_dtke -
LMDZ6/trunk/libf/phylmd/lmdz_thermcell_dv2.F90
r4589 r4590 1 MODULE lmdz_thermcell_dv2 2 CONTAINS 3 1 4 subroutine thermcell_dv2(ngrid,nlay,ptimestep,fm,entr,masse & 2 5 & ,fraca,larga & … … 192 195 return 193 196 end 197 END MODULE lmdz_thermcell_dv2 -
LMDZ6/trunk/libf/phylmd/lmdz_thermcell_env.F90
r4589 r4590 1 MODULE lmdz_thermcell_env 2 CONTAINS 3 1 4 SUBROUTINE thermcell_env(ngrid,nlay,po,pt,pu,pv,pplay, & 2 5 & pplev,zo,zh,zl,ztv,zthl,zu,zv,zpspsk,pqsat,lev_out) … … 8 11 9 12 10 USE thermcell_ini_mod, ONLY : prt_level,RLvCp,RKAPPA,RETV 13 USE lmdz_thermcell_ini, ONLY : prt_level,RLvCp,RKAPPA,RETV 14 USE lmdz_thermcell_qsat, ONLY : thermcell_qsat 11 15 IMPLICIT NONE 12 16 … … 77 81 RETURN 78 82 END 83 END MODULE lmdz_thermcell_env -
LMDZ6/trunk/libf/phylmd/lmdz_thermcell_flux2.F90
r4589 r4590 1 MODULE lmdz_thermcell_flux2 1 2 ! 2 3 ! $Id$ 3 4 ! 5 CONTAINS 6 4 7 SUBROUTINE thermcell_flux2(ngrid,nlay,ptimestep,masse, & 5 8 & lalim,lmax,alim_star, & … … 13 16 !--------------------------------------------------------------------------- 14 17 15 USE thermcell_ini_mod, ONLY : prt_level,iflag_thermals_optflux18 USE lmdz_thermcell_ini, ONLY : prt_level,iflag_thermals_optflux 16 19 IMPLICIT NONE 17 20 … … 510 513 RETURN 511 514 end 515 END MODULE lmdz_thermcell_flux2 -
LMDZ6/trunk/libf/phylmd/lmdz_thermcell_height.F90
r4589 r4590 1 MODULE lmdz_thermcell_height 2 CONTAINS 3 1 4 SUBROUTINE thermcell_height(ngrid,nlay,lalim,lmin,linter,lmix, & 2 5 & zw2,zlev,lmax,zmax,zmax0,zmix,wmax) … … 158 161 RETURN 159 162 end 163 END MODULE lmdz_thermcell_height -
LMDZ6/trunk/libf/phylmd/lmdz_thermcell_ini.F90
r4589 r4590 1 MODULE thermcell_ini_mod 1 MODULE lmdz_thermcell_ini 2 2 3 IMPLICIT NONE 3 4 … … 111 112 112 113 END SUBROUTINE thermcell_ini 113 END MODULE thermcell_ini_mod114 END MODULE lmdz_thermcell_ini -
LMDZ6/trunk/libf/phylmd/lmdz_thermcell_main.F90
r4589 r4590 1 MODULE lmdz_thermcell_main 1 2 ! $Id$ 2 3 ! 4 CONTAINS 5 3 6 subroutine thermcell_main(itap,ngrid,nlay,ptimestep & 4 7 & ,pplay,pplev,pphi,debut & … … 16 19 17 20 18 USE thermcell_ini_mod, ONLY: thermcell_ini,dqimpl,dvdq,prt_level,lunout,prt_level 19 USE thermcell_ini_mod, ONLY: iflag_thermals_closure,iflag_thermals_ed,tau_thermals,r_aspect_thermals 20 USE thermcell_ini_mod, ONLY: iflag_thermals_down, fact_thermals_down 21 USE thermcell_ini_mod, ONLY: RD,RG 21 USE lmdz_thermcell_ini, ONLY: thermcell_ini,dqimpl,dvdq,prt_level,lunout,prt_level 22 USE lmdz_thermcell_ini, ONLY: iflag_thermals_closure,iflag_thermals_ed,tau_thermals,r_aspect_thermals 23 USE lmdz_thermcell_ini, ONLY: iflag_thermals_down,fact_thermals_down 24 USE lmdz_thermcell_ini, ONLY: RD,RG 25 26 USE lmdz_thermcell_down, ONLY: thermcell_updown_dq 27 USE lmdz_thermcell_closure, ONLY: thermcell_closure 28 USE lmdz_thermcell_dq, ONLY: thermcell_dq 29 USE lmdz_thermcell_dry, ONLY: thermcell_dry 30 USE lmdz_thermcell_dv2, ONLY: thermcell_dv2 31 USE lmdz_thermcell_env, ONLY: thermcell_env 32 USE lmdz_thermcell_flux2, ONLY: thermcell_flux2 33 USE lmdz_thermcell_height, ONLY: thermcell_height 34 USE lmdz_thermcell_plume, ONLY: thermcell_plume 35 USE lmdz_thermcell_plume_6A, ONLY: thermcell_plume_6A,thermcell_plume_5B 22 36 23 37 #ifdef ISO … … 89 103 integer, intent(in) :: itap,ngrid,nlay 90 104 real, intent(in) :: ptimestep 91 real, intent(in), dimension(ngrid,nlay) :: pt,pu,pv,po,pplay,pphi,zpspsk 105 real, intent(in), dimension(ngrid,nlay) :: pt,pu,pv,pplay,pphi 106 ! ATTENTION : po et zpspsk sont inout et out mais c'est pas forcement pour de bonnes raisons (FH, 2023) 107 real, intent(inout), dimension(ngrid,nlay) :: po 108 real, intent(out), dimension(ngrid,nlay) :: zpspsk 92 109 real, intent(in), dimension(ngrid,nlay+1) :: pplev 93 110 integer, intent(out), dimension(ngrid) :: lmax … … 727 744 & zqla,f_star,zw2,comment) ! in 728 745 !============================================================================= 729 USE thermcell_ini_mod, ONLY: prt_level746 USE lmdz_thermcell_ini, ONLY: prt_level 730 747 IMPLICIT NONE 731 748 … … 771 788 & ngrid,nlay,ptimestep,fm0,entr0,rg,pplev, & ! in 772 789 & therm_tke_max) ! out 773 USE thermcell_ini_mod, ONLY: prt_level790 USE lmdz_thermcell_ini, ONLY: prt_level 774 791 implicit none 775 792 … … 885 902 end 886 903 904 END MODULE lmdz_thermcell_main -
LMDZ6/trunk/libf/phylmd/lmdz_thermcell_old.F90
r4589 r4590 1 MODULE lmdz_thermcell_old 2 CONTAINS 3 1 4 SUBROUTINE thermcell_2002(ngrid, nlay, ptimestep, iflag_thermals, pplay, & 2 5 pplev, pphi, pu, pv, pt, po, pduadj, pdvadj, pdtadj, pdoadj, fm0, entr0, & … … 5 8 USE dimphy 6 9 USE write_field_phy 10 USE lmdz_thermcell_dv2, ONLY : thermcell_dv2 11 USE lmdz_thermcell_dq, ONLY : thermcell_dq 7 12 IMPLICIT NONE 8 13 … … 5340 5345 END SUBROUTINE thermcell_sec 5341 5346 5347 SUBROUTINE calcul_sec(ngrid, nlay, ptimestep, pplay, pplev, pphi, zlev, pu, & 5348 pv, pt, po, zmax, wmax, zw2, lmix & ! s 5349 ! ,pu_therm,pv_therm 5350 , r_aspect, l_mix, w2di, tho) 5351 5352 USE dimphy 5353 IMPLICIT NONE 5354 5355 ! ======================================================================= 5356 5357 ! Calcul du transport verticale dans la couche limite en presence 5358 ! de "thermiques" explicitement representes 5359 5360 ! Réécriture à partir d'un listing papier à Habas, le 14/02/00 5361 5362 ! le thermique est supposé homogène et dissipé par mélange avec 5363 ! son environnement. la longueur l_mix contrôle l'efficacité du 5364 ! mélange 5365 5366 ! Le calcul du transport des différentes espèces se fait en prenant 5367 ! en compte: 5368 ! 1. un flux de masse montant 5369 ! 2. un flux de masse descendant 5370 ! 3. un entrainement 5371 ! 4. un detrainement 5372 5373 ! ======================================================================= 5374 5375 ! ----------------------------------------------------------------------- 5376 ! declarations: 5377 ! ------------- 5378 5379 include "YOMCST.h" 5380 5381 ! arguments: 5382 ! ---------- 5383 5384 INTEGER ngrid, nlay, w2di 5385 REAL tho 5386 REAL ptimestep, l_mix, r_aspect 5387 REAL pt(ngrid, nlay), pdtadj(ngrid, nlay) 5388 REAL pu(ngrid, nlay), pduadj(ngrid, nlay) 5389 REAL pv(ngrid, nlay), pdvadj(ngrid, nlay) 5390 REAL po(ngrid, nlay), pdoadj(ngrid, nlay) 5391 REAL pplay(ngrid, nlay), pplev(ngrid, nlay+1) 5392 REAL pphi(ngrid, nlay) 5393 5394 INTEGER idetr 5395 SAVE idetr 5396 DATA idetr/3/ 5397 !$OMP THREADPRIVATE(idetr) 5398 ! local: 5399 ! ------ 5400 5401 INTEGER ig, k, l, lmaxa(klon), lmix(klon) 5402 REAL zsortie1d(klon) 5403 ! CR: on remplace lmax(klon,klev+1) 5404 INTEGER lmax(klon), lmin(klon), lentr(klon) 5405 REAL linter(klon) 5406 REAL zmix(klon), fracazmix(klon) 5407 ! RC 5408 REAL zmax(klon), zw, zw2(klon, klev+1), ztva(klon, klev) 5409 5410 REAL zlev(klon, klev+1), zlay(klon, klev) 5411 REAL zh(klon, klev), zdhadj(klon, klev) 5412 REAL ztv(klon, klev) 5413 REAL zu(klon, klev), zv(klon, klev), zo(klon, klev) 5414 REAL wh(klon, klev+1) 5415 REAL wu(klon, klev+1), wv(klon, klev+1), wo(klon, klev+1) 5416 REAL zla(klon, klev+1) 5417 REAL zwa(klon, klev+1) 5418 REAL zld(klon, klev+1) 5419 ! real zwd(klon,klev+1) 5420 REAL zsortie(klon, klev) 5421 REAL zva(klon, klev) 5422 REAL zua(klon, klev) 5423 REAL zoa(klon, klev) 5424 5425 REAL zha(klon, klev) 5426 REAL wa_moy(klon, klev+1) 5427 REAL fraca(klon, klev+1) 5428 REAL fracc(klon, klev+1) 5429 REAL zf, zf2 5430 REAL thetath2(klon, klev), wth2(klon, klev) 5431 ! common/comtherm/thetath2,wth2 5432 5433 REAL count_time 5434 ! integer isplit,nsplit 5435 INTEGER isplit, nsplit, ialt 5436 PARAMETER (nsplit=10) 5437 DATA isplit/0/ 5438 SAVE isplit 5439 !$OMP THREADPRIVATE(isplit) 5440 5441 LOGICAL sorties 5442 REAL rho(klon, klev), rhobarz(klon, klev+1), masse(klon, klev) 5443 REAL zpspsk(klon, klev) 5444 5445 ! real wmax(klon,klev),wmaxa(klon) 5446 REAL wmax(klon), wmaxa(klon) 5447 REAL wa(klon, klev, klev+1) 5448 REAL wd(klon, klev+1) 5449 REAL larg_part(klon, klev, klev+1) 5450 REAL fracd(klon, klev+1) 5451 REAL xxx(klon, klev+1) 5452 REAL larg_cons(klon, klev+1) 5453 REAL larg_detr(klon, klev+1) 5454 REAL fm0(klon, klev+1), entr0(klon, klev), detr(klon, klev) 5455 REAL pu_therm(klon, klev), pv_therm(klon, klev) 5456 REAL fm(klon, klev+1), entr(klon, klev) 5457 REAL fmc(klon, klev+1) 5458 5459 ! CR:nouvelles variables 5460 REAL f_star(klon, klev+1), entr_star(klon, klev) 5461 REAL entr_star_tot(klon), entr_star2(klon) 5462 REAL zalim(klon) 5463 INTEGER lalim(klon) 5464 REAL norme(klon) 5465 REAL f(klon), f0(klon) 5466 REAL zlevinter(klon) 5467 LOGICAL therm 5468 LOGICAL first 5469 DATA first/.FALSE./ 5470 SAVE first 5471 !$OMP THREADPRIVATE(first) 5472 ! RC 5473 5474 CHARACTER *2 str2 5475 CHARACTER *10 str10 5476 5477 CHARACTER (LEN=20) :: modname = 'calcul_sec' 5478 CHARACTER (LEN=80) :: abort_message 5479 5480 5481 ! LOGICAL vtest(klon),down 5482 5483 EXTERNAL scopy 5484 5485 INTEGER ncorrec 5486 SAVE ncorrec 5487 DATA ncorrec/0/ 5488 !$OMP THREADPRIVATE(ncorrec) 5489 5490 5491 ! ----------------------------------------------------------------------- 5492 ! initialisation: 5493 ! --------------- 5494 5495 sorties = .TRUE. 5496 IF (ngrid/=klon) THEN 5497 PRINT * 5498 PRINT *, 'STOP dans convadj' 5499 PRINT *, 'ngrid =', ngrid 5500 PRINT *, 'klon =', klon 5501 END IF 5502 5503 ! ----------------------------------------------------------------------- 5504 ! incrementation eventuelle de tendances precedentes: 5505 ! --------------------------------------------------- 5506 5507 ! print*,'0 OK convect8' 5508 5509 DO l = 1, nlay 5510 DO ig = 1, ngrid 5511 zpspsk(ig, l) = (pplay(ig,l)/pplev(ig,1))**rkappa 5512 zh(ig, l) = pt(ig, l)/zpspsk(ig, l) 5513 zu(ig, l) = pu(ig, l) 5514 zv(ig, l) = pv(ig, l) 5515 zo(ig, l) = po(ig, l) 5516 ztv(ig, l) = zh(ig, l)*(1.+0.61*zo(ig,l)) 5517 END DO 5518 END DO 5519 5520 ! print*,'1 OK convect8' 5521 ! -------------------- 5522 5523 5524 ! + + + + + + + + + + + 5525 5526 5527 ! wa, fraca, wd, fracd -------------------- zlev(2), rhobarz 5528 ! wh,wt,wo ... 5529 5530 ! + + + + + + + + + + + zh,zu,zv,zo,rho 5531 5532 5533 ! -------------------- zlev(1) 5534 ! \\\\\\\\\\\\\\\\\\\\ 5535 5536 5537 5538 ! ----------------------------------------------------------------------- 5539 ! Calcul des altitudes des couches 5540 ! ----------------------------------------------------------------------- 5541 5542 DO l = 2, nlay 5543 DO ig = 1, ngrid 5544 zlev(ig, l) = 0.5*(pphi(ig,l)+pphi(ig,l-1))/rg 5545 END DO 5546 END DO 5547 DO ig = 1, ngrid 5548 zlev(ig, 1) = 0. 5549 zlev(ig, nlay+1) = (2.*pphi(ig,klev)-pphi(ig,klev-1))/rg 5550 END DO 5551 DO l = 1, nlay 5552 DO ig = 1, ngrid 5553 zlay(ig, l) = pphi(ig, l)/rg 5554 END DO 5555 END DO 5556 5557 ! print*,'2 OK convect8' 5558 ! ----------------------------------------------------------------------- 5559 ! Calcul des densites 5560 ! ----------------------------------------------------------------------- 5561 5562 DO l = 1, nlay 5563 DO ig = 1, ngrid 5564 rho(ig, l) = pplay(ig, l)/(zpspsk(ig,l)*rd*zh(ig,l)) 5565 END DO 5566 END DO 5567 5568 DO l = 2, nlay 5569 DO ig = 1, ngrid 5570 rhobarz(ig, l) = 0.5*(rho(ig,l)+rho(ig,l-1)) 5571 END DO 5572 END DO 5573 5574 DO k = 1, nlay 5575 DO l = 1, nlay + 1 5576 DO ig = 1, ngrid 5577 wa(ig, k, l) = 0. 5578 END DO 5579 END DO 5580 END DO 5581 5582 ! print*,'3 OK convect8' 5583 ! ------------------------------------------------------------------ 5584 ! Calcul de w2, quarre de w a partir de la cape 5585 ! a partir de w2, on calcule wa, vitesse de l'ascendance 5586 5587 ! ATTENTION: Dans cette version, pour cause d'economie de memoire, 5588 ! w2 est stoke dans wa 5589 5590 ! ATTENTION: dans convect8, on n'utilise le calcule des wa 5591 ! independants par couches que pour calculer l'entrainement 5592 ! a la base et la hauteur max de l'ascendance. 5593 5594 ! Indicages: 5595 ! l'ascendance provenant du niveau k traverse l'interface l avec 5596 ! une vitesse wa(k,l). 5597 5598 ! -------------------- 5599 5600 ! + + + + + + + + + + 5601 5602 ! wa(k,l) ---- -------------------- l 5603 ! /\ 5604 ! /||\ + + + + + + + + + + 5605 ! || 5606 ! || -------------------- 5607 ! || 5608 ! || + + + + + + + + + + 5609 ! || 5610 ! || -------------------- 5611 ! ||__ 5612 ! |___ + + + + + + + + + + k 5613 5614 ! -------------------- 5615 5616 5617 5618 ! ------------------------------------------------------------------ 5619 5620 ! CR: ponderation entrainement des couches instables 5621 ! def des entr_star tels que entr=f*entr_star 5622 DO l = 1, klev 5623 DO ig = 1, ngrid 5624 entr_star(ig, l) = 0. 5625 END DO 5626 END DO 5627 ! determination de la longueur de la couche d entrainement 5628 DO ig = 1, ngrid 5629 lentr(ig) = 1 5630 END DO 5631 5632 ! on ne considere que les premieres couches instables 5633 therm = .FALSE. 5634 DO k = nlay - 2, 1, -1 5635 DO ig = 1, ngrid 5636 IF (ztv(ig,k)>ztv(ig,k+1) .AND. ztv(ig,k+1)<=ztv(ig,k+2)) THEN 5637 lentr(ig) = k + 1 5638 therm = .TRUE. 5639 END IF 5640 END DO 5641 END DO 5642 ! limitation de la valeur du lentr 5643 ! do ig=1,ngrid 5644 ! lentr(ig)=min(5,lentr(ig)) 5645 ! enddo 5646 ! determination du lmin: couche d ou provient le thermique 5647 DO ig = 1, ngrid 5648 lmin(ig) = 1 5649 END DO 5650 DO ig = 1, ngrid 5651 DO l = nlay, 2, -1 5652 IF (ztv(ig,l-1)>ztv(ig,l)) THEN 5653 lmin(ig) = l - 1 5654 END IF 5655 END DO 5656 END DO 5657 ! initialisations 5658 DO ig = 1, ngrid 5659 zalim(ig) = 0. 5660 norme(ig) = 0. 5661 lalim(ig) = 1 5662 END DO 5663 DO k = 1, klev - 1 5664 DO ig = 1, ngrid 5665 zalim(ig) = zalim(ig) + zlev(ig, k)*max(0., (ztv(ig,k)-ztv(ig, & 5666 k+1))/(zlev(ig,k+1)-zlev(ig,k))) 5667 ! s *(zlev(ig,k+1)-zlev(ig,k)) 5668 norme(ig) = norme(ig) + max(0., (ztv(ig,k)-ztv(ig,k+1))/(zlev(ig, & 5669 k+1)-zlev(ig,k))) 5670 ! s *(zlev(ig,k+1)-zlev(ig,k)) 5671 END DO 5672 END DO 5673 DO ig = 1, ngrid 5674 IF (norme(ig)>1.E-10) THEN 5675 zalim(ig) = max(10.*zalim(ig)/norme(ig), zlev(ig,2)) 5676 ! zalim(ig)=min(zalim(ig),zlev(ig,lentr(ig))) 5677 END IF 5678 END DO 5679 ! détermination du lalim correspondant 5680 DO k = 1, klev - 1 5681 DO ig = 1, ngrid 5682 IF ((zalim(ig)>zlev(ig,k)) .AND. (zalim(ig)<=zlev(ig,k+1))) THEN 5683 lalim(ig) = k 5684 END IF 5685 END DO 5686 END DO 5687 5688 ! definition de l'entrainement des couches 5689 DO l = 1, klev - 1 5690 DO ig = 1, ngrid 5691 IF (ztv(ig,l)>ztv(ig,l+1) .AND. l>=lmin(ig) .AND. l<lentr(ig)) THEN 5692 entr_star(ig, l) = max((ztv(ig,l)-ztv(ig,l+1)), 0.) & ! s 5693 ! *(zlev(ig,l+1)-zlev(ig,l)) 5694 *sqrt(zlev(ig,l+1)) 5695 ! autre def 5696 ! entr_star(ig,l)=zlev(ig,l+1)*(1.-(zlev(ig,l+1) 5697 ! s /zlev(ig,lentr(ig)+2)))**(3./2.) 5698 END IF 5699 END DO 5700 END DO 5701 ! nouveau test 5702 ! if (therm) then 5703 DO l = 1, klev - 1 5704 DO ig = 1, ngrid 5705 IF (ztv(ig,l)>ztv(ig,l+1) .AND. l>=lmin(ig) .AND. l<=lalim(ig) .AND. & 5706 zalim(ig)>1.E-10) THEN 5707 ! if (l.le.lentr(ig)) then 5708 ! entr_star(ig,l)=zlev(ig,l+1)*(1.-(zlev(ig,l+1) 5709 ! s /zalim(ig)))**(3./2.) 5710 ! write(10,*)zlev(ig,l),entr_star(ig,l) 5711 END IF 5712 END DO 5713 END DO 5714 ! endif 5715 ! pas de thermique si couche 1 stable 5716 DO ig = 1, ngrid 5717 IF (lmin(ig)>5) THEN 5718 DO l = 1, klev 5719 entr_star(ig, l) = 0. 5720 END DO 5721 END IF 5722 END DO 5723 ! calcul de l entrainement total 5724 DO ig = 1, ngrid 5725 entr_star_tot(ig) = 0. 5726 END DO 5727 DO ig = 1, ngrid 5728 DO k = 1, klev 5729 entr_star_tot(ig) = entr_star_tot(ig) + entr_star(ig, k) 5730 END DO 5731 END DO 5732 ! Calcul entrainement normalise 5733 DO ig = 1, ngrid 5734 IF (entr_star_tot(ig)>1.E-10) THEN 5735 ! do l=1,lentr(ig) 5736 DO l = 1, klev 5737 ! def possibles pour entr_star: zdthetadz, dthetadz, zdtheta 5738 entr_star(ig, l) = entr_star(ig, l)/entr_star_tot(ig) 5739 END DO 5740 END IF 5741 END DO 5742 5743 ! print*,'fin calcul entr_star' 5744 DO k = 1, klev 5745 DO ig = 1, ngrid 5746 ztva(ig, k) = ztv(ig, k) 5747 END DO 5748 END DO 5749 ! RC 5750 ! print*,'7 OK convect8' 5751 DO k = 1, klev + 1 5752 DO ig = 1, ngrid 5753 zw2(ig, k) = 0. 5754 fmc(ig, k) = 0. 5755 ! CR 5756 f_star(ig, k) = 0. 5757 ! RC 5758 larg_cons(ig, k) = 0. 5759 larg_detr(ig, k) = 0. 5760 wa_moy(ig, k) = 0. 5761 END DO 5762 END DO 5763 5764 ! print*,'8 OK convect8' 5765 DO ig = 1, ngrid 5766 linter(ig) = 1. 5767 lmaxa(ig) = 1 5768 lmix(ig) = 1 5769 wmaxa(ig) = 0. 5770 END DO 5771 5772 ! CR: 5773 DO l = 1, nlay - 2 5774 DO ig = 1, ngrid 5775 IF (ztv(ig,l)>ztv(ig,l+1) .AND. entr_star(ig,l)>1.E-10 .AND. & 5776 zw2(ig,l)<1E-10) THEN 5777 f_star(ig, l+1) = entr_star(ig, l) 5778 ! test:calcul de dteta 5779 zw2(ig, l+1) = 2.*rg*(ztv(ig,l)-ztv(ig,l+1))/ztv(ig, l+1)* & 5780 (zlev(ig,l+1)-zlev(ig,l))*0.4*pphi(ig, l)/(pphi(ig,l+1)-pphi(ig,l)) 5781 larg_detr(ig, l) = 0. 5782 ELSE IF ((zw2(ig,l)>=1E-10) .AND. (f_star(ig,l)+entr_star(ig, & 5783 l)>1.E-10)) THEN 5784 f_star(ig, l+1) = f_star(ig, l) + entr_star(ig, l) 5785 ztva(ig, l) = (f_star(ig,l)*ztva(ig,l-1)+entr_star(ig,l)*ztv(ig,l))/ & 5786 f_star(ig, l+1) 5787 zw2(ig, l+1) = zw2(ig, l)*(f_star(ig,l)/f_star(ig,l+1))**2 + & 5788 2.*rg*(ztva(ig,l)-ztv(ig,l))/ztv(ig, l)*(zlev(ig,l+1)-zlev(ig,l)) 5789 END IF 5790 ! determination de zmax continu par interpolation lineaire 5791 IF (zw2(ig,l+1)<0.) THEN 5792 ! test 5793 IF (abs(zw2(ig,l+1)-zw2(ig,l))<1E-10) THEN 5794 ! print*,'pb linter' 5795 END IF 5796 linter(ig) = (l*(zw2(ig,l+1)-zw2(ig,l))-zw2(ig,l))/(zw2(ig,l+1)-zw2( & 5797 ig,l)) 5798 zw2(ig, l+1) = 0. 5799 lmaxa(ig) = l 5800 ELSE 5801 IF (zw2(ig,l+1)<0.) THEN 5802 ! print*,'pb1 zw2<0' 5803 END IF 5804 wa_moy(ig, l+1) = sqrt(zw2(ig,l+1)) 5805 END IF 5806 IF (wa_moy(ig,l+1)>wmaxa(ig)) THEN 5807 ! lmix est le niveau de la couche ou w (wa_moy) est maximum 5808 lmix(ig) = l + 1 5809 wmaxa(ig) = wa_moy(ig, l+1) 5810 END IF 5811 END DO 5812 END DO 5813 ! print*,'fin calcul zw2' 5814 5815 ! Calcul de la couche correspondant a la hauteur du thermique 5816 DO ig = 1, ngrid 5817 lmax(ig) = lentr(ig) 5818 ! lmax(ig)=lalim(ig) 5819 END DO 5820 DO ig = 1, ngrid 5821 DO l = nlay, lentr(ig) + 1, -1 5822 ! do l=nlay,lalim(ig)+1,-1 5823 IF (zw2(ig,l)<=1.E-10) THEN 5824 lmax(ig) = l - 1 5825 END IF 5826 END DO 5827 END DO 5828 ! pas de thermique si couche 1 stable 5829 DO ig = 1, ngrid 5830 IF (lmin(ig)>5) THEN 5831 lmax(ig) = 1 5832 lmin(ig) = 1 5833 lentr(ig) = 1 5834 lalim(ig) = 1 5835 END IF 5836 END DO 5837 5838 ! Determination de zw2 max 5839 DO ig = 1, ngrid 5840 wmax(ig) = 0. 5841 END DO 5842 5843 DO l = 1, nlay 5844 DO ig = 1, ngrid 5845 IF (l<=lmax(ig)) THEN 5846 IF (zw2(ig,l)<0.) THEN 5847 ! print*,'pb2 zw2<0' 5848 END IF 5849 zw2(ig, l) = sqrt(zw2(ig,l)) 5850 wmax(ig) = max(wmax(ig), zw2(ig,l)) 5851 ELSE 5852 zw2(ig, l) = 0. 5853 END IF 5854 END DO 5855 END DO 5856 5857 ! Longueur caracteristique correspondant a la hauteur des thermiques. 5858 DO ig = 1, ngrid 5859 zmax(ig) = 0. 5860 zlevinter(ig) = zlev(ig, 1) 5861 END DO 5862 DO ig = 1, ngrid 5863 ! calcul de zlevinter 5864 zlevinter(ig) = (zlev(ig,lmax(ig)+1)-zlev(ig,lmax(ig)))*linter(ig) + & 5865 zlev(ig, lmax(ig)) - lmax(ig)*(zlev(ig,lmax(ig)+1)-zlev(ig,lmax(ig))) 5866 zmax(ig) = max(zmax(ig), zlevinter(ig)-zlev(ig,lmin(ig))) 5867 END DO 5868 DO ig = 1, ngrid 5869 ! write(8,*)zmax(ig),lmax(ig),lentr(ig),lmin(ig) 5870 END DO 5871 ! on stope après les calculs de zmax et wmax 5872 RETURN 5873 5874 ! print*,'avant fermeture' 5875 ! Fermeture,determination de f 5876 ! Attention! entrainement normalisé ou pas? 5877 DO ig = 1, ngrid 5878 entr_star2(ig) = 0. 5879 END DO 5880 DO ig = 1, ngrid 5881 IF (entr_star_tot(ig)<1.E-10) THEN 5882 f(ig) = 0. 5883 ELSE 5884 DO k = lmin(ig), lentr(ig) 5885 ! do k=lmin(ig),lalim(ig) 5886 entr_star2(ig) = entr_star2(ig) + entr_star(ig, k)**2/(rho(ig,k)*( & 5887 zlev(ig,k+1)-zlev(ig,k))) 5888 END DO 5889 ! Nouvelle fermeture 5890 f(ig) = wmax(ig)/(max(500.,zmax(ig))*r_aspect*entr_star2(ig)) 5891 ! s *entr_star_tot(ig) 5892 ! test 5893 ! if (first) then 5894 f(ig) = f(ig) + (f0(ig)-f(ig))*exp(-ptimestep/zmax(ig)*wmax(ig)) 5895 ! endif 5896 END IF 5897 f0(ig) = f(ig) 5898 ! first=.true. 5899 END DO 5900 ! print*,'apres fermeture' 5901 ! on stoppe après la fermeture 5902 RETURN 5903 ! Calcul de l'entrainement 5904 DO k = 1, klev 5905 DO ig = 1, ngrid 5906 entr(ig, k) = f(ig)*entr_star(ig, k) 5907 END DO 5908 END DO 5909 ! on stoppe après le calcul de entr 5910 ! RETURN 5911 ! CR:test pour entrainer moins que la masse 5912 ! do ig=1,ngrid 5913 ! do l=1,lentr(ig) 5914 ! if ((entr(ig,l)*ptimestep).gt.(0.9*masse(ig,l))) then 5915 ! entr(ig,l+1)=entr(ig,l+1)+entr(ig,l) 5916 ! s -0.9*masse(ig,l)/ptimestep 5917 ! entr(ig,l)=0.9*masse(ig,l)/ptimestep 5918 ! endif 5919 ! enddo 5920 ! enddo 5921 ! CR: fin test 5922 ! Calcul des flux 5923 DO ig = 1, ngrid 5924 DO l = 1, lmax(ig) - 1 5925 fmc(ig, l+1) = fmc(ig, l) + entr(ig, l) 5926 END DO 5927 END DO 5928 5929 ! RC 5930 5931 5932 ! print*,'9 OK convect8' 5933 ! print*,'WA1 ',wa_moy 5934 5935 ! determination de l'indice du debut de la mixed layer ou w decroit 5936 5937 ! calcul de la largeur de chaque ascendance dans le cas conservatif. 5938 ! dans ce cas simple, on suppose que la largeur de l'ascendance provenant 5939 ! d'une couche est égale à la hauteur de la couche alimentante. 5940 ! La vitesse maximale dans l'ascendance est aussi prise comme estimation 5941 ! de la vitesse d'entrainement horizontal dans la couche alimentante. 5942 5943 DO l = 2, nlay 5944 DO ig = 1, ngrid 5945 IF (l<=lmaxa(ig)) THEN 5946 zw = max(wa_moy(ig,l), 1.E-10) 5947 larg_cons(ig, l) = zmax(ig)*r_aspect*fmc(ig, l)/(rhobarz(ig,l)*zw) 5948 END IF 5949 END DO 5950 END DO 5951 5952 DO l = 2, nlay 5953 DO ig = 1, ngrid 5954 IF (l<=lmaxa(ig)) THEN 5955 ! if (idetr.eq.0) then 5956 ! cette option est finalement en dur. 5957 IF ((l_mix*zlev(ig,l))<0.) THEN 5958 ! print*,'pb l_mix*zlev<0' 5959 END IF 5960 ! CR: test: nouvelle def de lambda 5961 ! larg_detr(ig,l)=sqrt(l_mix*zlev(ig,l)) 5962 IF (zw2(ig,l)>1.E-10) THEN 5963 larg_detr(ig, l) = sqrt((l_mix/zw2(ig,l))*zlev(ig,l)) 5964 ELSE 5965 larg_detr(ig, l) = sqrt(l_mix*zlev(ig,l)) 5966 END IF 5967 ! RC 5968 ! else if (idetr.eq.1) then 5969 ! larg_detr(ig,l)=larg_cons(ig,l) 5970 ! s *sqrt(l_mix*zlev(ig,l))/larg_cons(ig,lmix(ig)) 5971 ! else if (idetr.eq.2) then 5972 ! larg_detr(ig,l)=sqrt(l_mix*zlev(ig,l)) 5973 ! s *sqrt(wa_moy(ig,l)) 5974 ! else if (idetr.eq.4) then 5975 ! larg_detr(ig,l)=sqrt(l_mix*zlev(ig,l)) 5976 ! s *wa_moy(ig,l) 5977 ! endif 5978 END IF 5979 END DO 5980 END DO 5981 5982 ! print*,'10 OK convect8' 5983 ! print*,'WA2 ',wa_moy 5984 ! calcul de la fraction de la maille concernée par l'ascendance en tenant 5985 ! compte de l'epluchage du thermique. 5986 5987 ! CR def de zmix continu (profil parabolique des vitesses) 5988 DO ig = 1, ngrid 5989 IF (lmix(ig)>1.) THEN 5990 ! test 5991 IF (((zw2(ig,lmix(ig)-1)-zw2(ig,lmix(ig)))*((zlev(ig,lmix(ig)))- & 5992 (zlev(ig,lmix(ig)+1)))-(zw2(ig,lmix(ig))- & 5993 zw2(ig,lmix(ig)+1))*((zlev(ig,lmix(ig)-1))- & 5994 (zlev(ig,lmix(ig)))))>1E-10) THEN 5995 5996 zmix(ig) = ((zw2(ig,lmix(ig)-1)-zw2(ig,lmix(ig)))*((zlev(ig,lmix(ig)) & 5997 )**2-(zlev(ig,lmix(ig)+1))**2)-(zw2(ig,lmix(ig))-zw2(ig, & 5998 lmix(ig)+1))*((zlev(ig,lmix(ig)-1))**2-(zlev(ig,lmix(ig)))**2))/ & 5999 (2.*((zw2(ig,lmix(ig)-1)-zw2(ig,lmix(ig)))*((zlev(ig,lmix(ig)))- & 6000 (zlev(ig,lmix(ig)+1)))-(zw2(ig,lmix(ig))- & 6001 zw2(ig,lmix(ig)+1))*((zlev(ig,lmix(ig)-1))-(zlev(ig,lmix(ig)))))) 6002 ELSE 6003 zmix(ig) = zlev(ig, lmix(ig)) 6004 ! print*,'pb zmix' 6005 END IF 6006 ELSE 6007 zmix(ig) = 0. 6008 END IF 6009 ! test 6010 IF ((zmax(ig)-zmix(ig))<0.) THEN 6011 zmix(ig) = 0.99*zmax(ig) 6012 ! print*,'pb zmix>zmax' 6013 END IF 6014 END DO 6015 6016 ! calcul du nouveau lmix correspondant 6017 DO ig = 1, ngrid 6018 DO l = 1, klev 6019 IF (zmix(ig)>=zlev(ig,l) .AND. zmix(ig)<zlev(ig,l+1)) THEN 6020 lmix(ig) = l 6021 END IF 6022 END DO 6023 END DO 6024 6025 DO l = 2, nlay 6026 DO ig = 1, ngrid 6027 IF (larg_cons(ig,l)>1.) THEN 6028 ! print*,ig,l,lmix(ig),lmaxa(ig),larg_cons(ig,l),' KKK' 6029 fraca(ig, l) = (larg_cons(ig,l)-larg_detr(ig,l))/(r_aspect*zmax(ig)) 6030 ! test 6031 fraca(ig, l) = max(fraca(ig,l), 0.) 6032 fraca(ig, l) = min(fraca(ig,l), 0.5) 6033 fracd(ig, l) = 1. - fraca(ig, l) 6034 fracc(ig, l) = larg_cons(ig, l)/(r_aspect*zmax(ig)) 6035 ELSE 6036 ! wa_moy(ig,l)=0. 6037 fraca(ig, l) = 0. 6038 fracc(ig, l) = 0. 6039 fracd(ig, l) = 1. 6040 END IF 6041 END DO 6042 END DO 6043 ! CR: calcul de fracazmix 6044 DO ig = 1, ngrid 6045 fracazmix(ig) = (fraca(ig,lmix(ig)+1)-fraca(ig,lmix(ig)))/ & 6046 (zlev(ig,lmix(ig)+1)-zlev(ig,lmix(ig)))*zmix(ig) + & 6047 fraca(ig, lmix(ig)) - zlev(ig, lmix(ig))*(fraca(ig,lmix(ig)+1)-fraca(ig & 6048 ,lmix(ig)))/(zlev(ig,lmix(ig)+1)-zlev(ig,lmix(ig))) 6049 END DO 6050 6051 DO l = 2, nlay 6052 DO ig = 1, ngrid 6053 IF (larg_cons(ig,l)>1.) THEN 6054 IF (l>lmix(ig)) THEN 6055 ! test 6056 IF (zmax(ig)-zmix(ig)<1.E-10) THEN 6057 ! print*,'pb xxx' 6058 xxx(ig, l) = (lmaxa(ig)+1.-l)/(lmaxa(ig)+1.-lmix(ig)) 6059 ELSE 6060 xxx(ig, l) = (zmax(ig)-zlev(ig,l))/(zmax(ig)-zmix(ig)) 6061 END IF 6062 IF (idetr==0) THEN 6063 fraca(ig, l) = fracazmix(ig) 6064 ELSE IF (idetr==1) THEN 6065 fraca(ig, l) = fracazmix(ig)*xxx(ig, l) 6066 ELSE IF (idetr==2) THEN 6067 fraca(ig, l) = fracazmix(ig)*(1.-(1.-xxx(ig,l))**2) 6068 ELSE 6069 fraca(ig, l) = fracazmix(ig)*xxx(ig, l)**2 6070 END IF 6071 ! print*,ig,l,lmix(ig),lmaxa(ig),xxx(ig,l),'LLLLLLL' 6072 fraca(ig, l) = max(fraca(ig,l), 0.) 6073 fraca(ig, l) = min(fraca(ig,l), 0.5) 6074 fracd(ig, l) = 1. - fraca(ig, l) 6075 fracc(ig, l) = larg_cons(ig, l)/(r_aspect*zmax(ig)) 6076 END IF 6077 END IF 6078 END DO 6079 END DO 6080 6081 ! print*,'fin calcul fraca' 6082 ! print*,'11 OK convect8' 6083 ! print*,'Ea3 ',wa_moy 6084 ! ------------------------------------------------------------------ 6085 ! Calcul de fracd, wd 6086 ! somme wa - wd = 0 6087 ! ------------------------------------------------------------------ 6088 6089 6090 DO ig = 1, ngrid 6091 fm(ig, 1) = 0. 6092 fm(ig, nlay+1) = 0. 6093 END DO 6094 6095 DO l = 2, nlay 6096 DO ig = 1, ngrid 6097 fm(ig, l) = fraca(ig, l)*wa_moy(ig, l)*rhobarz(ig, l) 6098 ! CR:test 6099 IF (entr(ig,l-1)<1E-10 .AND. fm(ig,l)>fm(ig,l-1) .AND. l>lmix(ig)) THEN 6100 fm(ig, l) = fm(ig, l-1) 6101 ! write(1,*)'ajustement fm, l',l 6102 END IF 6103 ! write(1,*)'ig,l,fm(ig,l)',ig,l,fm(ig,l) 6104 ! RC 6105 END DO 6106 DO ig = 1, ngrid 6107 IF (fracd(ig,l)<0.1) THEN 6108 abort_message = 'fracd trop petit' 6109 CALL abort_physic(modname, abort_message, 1) 6110 6111 ELSE 6112 ! vitesse descendante "diagnostique" 6113 wd(ig, l) = fm(ig, l)/(fracd(ig,l)*rhobarz(ig,l)) 6114 END IF 6115 END DO 6116 END DO 6117 6118 DO l = 1, nlay 6119 DO ig = 1, ngrid 6120 ! masse(ig,l)=rho(ig,l)*(zlev(ig,l+1)-zlev(ig,l)) 6121 masse(ig, l) = (pplev(ig,l)-pplev(ig,l+1))/rg 6122 END DO 6123 END DO 6124 6125 ! print*,'12 OK convect8' 6126 ! print*,'WA4 ',wa_moy 6127 ! c------------------------------------------------------------------ 6128 ! calcul du transport vertical 6129 ! ------------------------------------------------------------------ 6130 6131 GO TO 4444 6132 ! print*,'XXXXXXXXXXXXXXX ptimestep= ',ptimestep 6133 DO l = 2, nlay - 1 6134 DO ig = 1, ngrid 6135 IF (fm(ig,l+1)*ptimestep>masse(ig,l) .AND. fm(ig,l+1)*ptimestep>masse( & 6136 ig,l+1)) THEN 6137 ! print*,'WARN!!! FM>M ig=',ig,' l=',l,' FM=' 6138 ! s ,fm(ig,l+1)*ptimestep 6139 ! s ,' M=',masse(ig,l),masse(ig,l+1) 6140 END IF 6141 END DO 6142 END DO 6143 6144 DO l = 1, nlay 6145 DO ig = 1, ngrid 6146 IF (entr(ig,l)*ptimestep>masse(ig,l)) THEN 6147 ! print*,'WARN!!! E>M ig=',ig,' l=',l,' E==' 6148 ! s ,entr(ig,l)*ptimestep 6149 ! s ,' M=',masse(ig,l) 6150 END IF 6151 END DO 6152 END DO 6153 6154 DO l = 1, nlay 6155 DO ig = 1, ngrid 6156 IF (.NOT. fm(ig,l)>=0. .OR. .NOT. fm(ig,l)<=10.) THEN 6157 ! print*,'WARN!!! fm exagere ig=',ig,' l=',l 6158 ! s ,' FM=',fm(ig,l) 6159 END IF 6160 IF (.NOT. masse(ig,l)>=1.E-10 .OR. .NOT. masse(ig,l)<=1.E4) THEN 6161 ! print*,'WARN!!! masse exagere ig=',ig,' l=',l 6162 ! s ,' M=',masse(ig,l) 6163 ! print*,'rho(ig,l),pplay(ig,l),zpspsk(ig,l),RD,zh(ig,l)', 6164 ! s rho(ig,l),pplay(ig,l),zpspsk(ig,l),RD,zh(ig,l) 6165 ! print*,'zlev(ig,l+1),zlev(ig,l)' 6166 ! s ,zlev(ig,l+1),zlev(ig,l) 6167 ! print*,'pphi(ig,l-1),pphi(ig,l),pphi(ig,l+1)' 6168 ! s ,pphi(ig,l-1),pphi(ig,l),pphi(ig,l+1) 6169 END IF 6170 IF (.NOT. entr(ig,l)>=0. .OR. .NOT. entr(ig,l)<=10.) THEN 6171 ! print*,'WARN!!! entr exagere ig=',ig,' l=',l 6172 ! s ,' E=',entr(ig,l) 6173 END IF 6174 END DO 6175 END DO 6176 6177 4444 CONTINUE 6178 6179 ! CR:redefinition du entr 6180 DO l = 1, nlay 6181 DO ig = 1, ngrid 6182 detr(ig, l) = fm(ig, l) + entr(ig, l) - fm(ig, l+1) 6183 IF (detr(ig,l)<0.) THEN 6184 ! entr(ig,l)=entr(ig,l)-detr(ig,l) 6185 fm(ig, l+1) = fm(ig, l) + entr(ig, l) 6186 detr(ig, l) = 0. 6187 ! print*,'WARNING !!! detrainement negatif ',ig,l 6188 END IF 6189 END DO 6190 END DO 6191 ! RC 6192 IF (w2di==1) THEN 6193 fm0 = fm0 + ptimestep*(fm-fm0)/tho 6194 entr0 = entr0 + ptimestep*(entr-entr0)/tho 6195 ELSE 6196 fm0 = fm 6197 entr0 = entr 6198 END IF 6199 6200 IF (1==1) THEN 6201 CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zh, zdhadj, & 6202 zha) 6203 CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zo, pdoadj, & 6204 zoa) 6205 ELSE 6206 CALL dqthermcell2(ngrid, nlay, ptimestep, fm0, entr0, masse, fraca, zh, & 6207 zdhadj, zha) 6208 CALL dqthermcell2(ngrid, nlay, ptimestep, fm0, entr0, masse, fraca, zo, & 6209 pdoadj, zoa) 6210 END IF 6211 6212 IF (1==0) THEN 6213 CALL dvthermcell2(ngrid, nlay, ptimestep, fm0, entr0, masse, fraca, zmax, & 6214 zu, zv, pduadj, pdvadj, zua, zva) 6215 ELSE 6216 CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zu, pduadj, & 6217 zua) 6218 CALL dqthermcell(ngrid, nlay, ptimestep, fm0, entr0, masse, zv, pdvadj, & 6219 zva) 6220 END IF 6221 6222 DO l = 1, nlay 6223 DO ig = 1, ngrid 6224 zf = 0.5*(fracc(ig,l)+fracc(ig,l+1)) 6225 zf2 = zf/(1.-zf) 6226 thetath2(ig, l) = zf2*(zha(ig,l)-zh(ig,l))**2 6227 wth2(ig, l) = zf2*(0.5*(wa_moy(ig,l)+wa_moy(ig,l+1)))**2 6228 END DO 6229 END DO 6230 6231 6232 6233 ! print*,'13 OK convect8' 6234 ! print*,'WA5 ',wa_moy 6235 DO l = 1, nlay 6236 DO ig = 1, ngrid 6237 pdtadj(ig, l) = zdhadj(ig, l)*zpspsk(ig, l) 6238 END DO 6239 END DO 6240 6241 6242 ! do l=1,nlay 6243 ! do ig=1,ngrid 6244 ! if(abs(pdtadj(ig,l))*86400..gt.500.) then 6245 ! print*,'WARN!!! ig=',ig,' l=',l 6246 ! s ,' pdtadj=',pdtadj(ig,l) 6247 ! endif 6248 ! if(abs(pdoadj(ig,l))*86400..gt.1.) then 6249 ! print*,'WARN!!! ig=',ig,' l=',l 6250 ! s ,' pdoadj=',pdoadj(ig,l) 6251 ! endif 6252 ! enddo 6253 ! enddo 6254 6255 ! print*,'14 OK convect8' 6256 ! ------------------------------------------------------------------ 6257 ! Calculs pour les sorties 6258 ! ------------------------------------------------------------------ 6259 6260 IF (sorties) THEN 6261 DO l = 1, nlay 6262 DO ig = 1, ngrid 6263 zla(ig, l) = (1.-fracd(ig,l))*zmax(ig) 6264 zld(ig, l) = fracd(ig, l)*zmax(ig) 6265 IF (1.-fracd(ig,l)>1.E-10) zwa(ig, l) = wd(ig, l)*fracd(ig, l)/ & 6266 (1.-fracd(ig,l)) 6267 END DO 6268 END DO 6269 6270 ! deja fait 6271 ! do l=1,nlay 6272 ! do ig=1,ngrid 6273 ! detr(ig,l)=fm(ig,l)+entr(ig,l)-fm(ig,l+1) 6274 ! if (detr(ig,l).lt.0.) then 6275 ! entr(ig,l)=entr(ig,l)-detr(ig,l) 6276 ! detr(ig,l)=0. 6277 ! print*,'WARNING !!! detrainement negatif ',ig,l 6278 ! endif 6279 ! enddo 6280 ! enddo 6281 6282 ! print*,'15 OK convect8' 6283 6284 isplit = isplit + 1 6285 6286 6287 ! #define und 6288 GO TO 123 6289 #ifdef und 6290 CALL writeg1d(1, nlay, wd, 'wd ', 'wd ') 6291 CALL writeg1d(1, nlay, zwa, 'wa ', 'wa ') 6292 CALL writeg1d(1, nlay, fracd, 'fracd ', 'fracd ') 6293 CALL writeg1d(1, nlay, fraca, 'fraca ', 'fraca ') 6294 CALL writeg1d(1, nlay, wa_moy, 'wam ', 'wam ') 6295 CALL writeg1d(1, nlay, zla, 'la ', 'la ') 6296 CALL writeg1d(1, nlay, zld, 'ld ', 'ld ') 6297 CALL writeg1d(1, nlay, pt, 'pt ', 'pt ') 6298 CALL writeg1d(1, nlay, zh, 'zh ', 'zh ') 6299 CALL writeg1d(1, nlay, zha, 'zha ', 'zha ') 6300 CALL writeg1d(1, nlay, zu, 'zu ', 'zu ') 6301 CALL writeg1d(1, nlay, zv, 'zv ', 'zv ') 6302 CALL writeg1d(1, nlay, zo, 'zo ', 'zo ') 6303 CALL writeg1d(1, nlay, wh, 'wh ', 'wh ') 6304 CALL writeg1d(1, nlay, wu, 'wu ', 'wu ') 6305 CALL writeg1d(1, nlay, wv, 'wv ', 'wv ') 6306 CALL writeg1d(1, nlay, wo, 'w15uo ', 'wXo ') 6307 CALL writeg1d(1, nlay, zdhadj, 'zdhadj ', 'zdhadj ') 6308 CALL writeg1d(1, nlay, pduadj, 'pduadj ', 'pduadj ') 6309 CALL writeg1d(1, nlay, pdvadj, 'pdvadj ', 'pdvadj ') 6310 CALL writeg1d(1, nlay, pdoadj, 'pdoadj ', 'pdoadj ') 6311 CALL writeg1d(1, nlay, entr, 'entr ', 'entr ') 6312 CALL writeg1d(1, nlay, detr, 'detr ', 'detr ') 6313 CALL writeg1d(1, nlay, fm, 'fm ', 'fm ') 6314 6315 CALL writeg1d(1, nlay, pdtadj, 'pdtadj ', 'pdtadj ') 6316 CALL writeg1d(1, nlay, pplay, 'pplay ', 'pplay ') 6317 CALL writeg1d(1, nlay, pplev, 'pplev ', 'pplev ') 6318 6319 ! recalcul des flux en diagnostique... 6320 ! print*,'PAS DE TEMPS ',ptimestep 6321 CALL dt2f(pplev, pplay, pt, pdtadj, wh) 6322 CALL writeg1d(1, nlay, wh, 'wh2 ', 'wh2 ') 6323 #endif 6324 123 CONTINUE 6325 6326 END IF 6327 6328 ! if(wa_moy(1,4).gt.1.e-10) stop 6329 6330 ! print*,'19 OK convect8' 6331 RETURN 6332 END SUBROUTINE calcul_sec 6333 6334 SUBROUTINE fermeture_seche(ngrid, nlay, pplay, pplev, pphi, zlev, rhobarz, & 6335 f0, zpspsk, alim_star, zh, zo, lentr, lmin, nu_min, nu_max, r_aspect, & 6336 zmax, wmax) 6337 6338 USE dimphy 6339 IMPLICIT NONE 6340 6341 include "YOMCST.h" 6342 6343 INTEGER ngrid, nlay 6344 REAL pplay(ngrid, nlay), pplev(ngrid, nlay+1) 6345 REAL pphi(ngrid, nlay) 6346 REAL zlev(klon, klev+1) 6347 REAL alim_star(klon, klev) 6348 REAL f0(klon) 6349 INTEGER lentr(klon) 6350 INTEGER lmin(klon) 6351 REAL zmax(klon) 6352 REAL wmax(klon) 6353 REAL nu_min 6354 REAL nu_max 6355 REAL r_aspect 6356 REAL rhobarz(klon, klev+1) 6357 REAL zh(klon, klev) 6358 REAL zo(klon, klev) 6359 REAL zpspsk(klon, klev) 6360 6361 INTEGER ig, l 6362 6363 REAL f_star(klon, klev+1) 6364 REAL detr_star(klon, klev) 6365 REAL entr_star(klon, klev) 6366 REAL zw2(klon, klev+1) 6367 REAL linter(klon) 6368 INTEGER lmix(klon) 6369 INTEGER lmax(klon) 6370 REAL zlevinter(klon) 6371 REAL wa_moy(klon, klev+1) 6372 REAL wmaxa(klon) 6373 REAL ztv(klon, klev) 6374 REAL ztva(klon, klev) 6375 REAL nu(klon, klev) 6376 ! real zmax0_sec(klon) 6377 ! save zmax0_sec 6378 REAL, SAVE, ALLOCATABLE :: zmax0_sec(:) 6379 !$OMP THREADPRIVATE(zmax0_sec) 6380 LOGICAL, SAVE :: first = .TRUE. 6381 !$OMP THREADPRIVATE(first) 6382 6383 IF (first) THEN 6384 ALLOCATE (zmax0_sec(klon)) 6385 first = .FALSE. 6386 END IF 6387 6388 DO l = 1, nlay 6389 DO ig = 1, ngrid 6390 ztv(ig, l) = zh(ig, l)/zpspsk(ig, l) 6391 ztv(ig, l) = ztv(ig, l)*(1.+retv*zo(ig,l)) 6392 END DO 6393 END DO 6394 DO l = 1, nlay - 2 6395 DO ig = 1, ngrid 6396 IF (ztv(ig,l)>ztv(ig,l+1) .AND. alim_star(ig,l)>1.E-10 .AND. & 6397 zw2(ig,l)<1E-10) THEN 6398 f_star(ig, l+1) = alim_star(ig, l) 6399 ! test:calcul de dteta 6400 zw2(ig, l+1) = 2.*rg*(ztv(ig,l)-ztv(ig,l+1))/ztv(ig, l+1)* & 6401 (zlev(ig,l+1)-zlev(ig,l))*0.4*pphi(ig, l)/(pphi(ig,l+1)-pphi(ig,l)) 6402 ELSE IF ((zw2(ig,l)>=1E-10) .AND. (f_star(ig,l)+alim_star(ig, & 6403 l))>1.E-10) THEN 6404 ! estimation du detrainement a partir de la geometrie du pas 6405 ! precedent 6406 ! tests sur la definition du detr 6407 nu(ig, l) = (nu_min+nu_max)/2.*(1.-(nu_max-nu_min)/(nu_max+nu_min)* & 6408 tanh((((ztva(ig,l-1)-ztv(ig,l))/ztv(ig,l))/0.0005))) 6409 6410 detr_star(ig, l) = rhobarz(ig, l)*sqrt(zw2(ig,l))/ & 6411 (r_aspect*zmax0_sec(ig))* & ! s 6412 ! /(r_aspect*zmax0(ig))* 6413 (sqrt(nu(ig,l)*zlev(ig,l+1)/sqrt(zw2(ig,l)))-sqrt(nu(ig,l)*zlev(ig, & 6414 l)/sqrt(zw2(ig,l)))) 6415 detr_star(ig, l) = detr_star(ig, l)/f0(ig) 6416 IF ((detr_star(ig,l))>f_star(ig,l)) THEN 6417 detr_star(ig, l) = f_star(ig, l) 6418 END IF 6419 entr_star(ig, l) = 0.9*detr_star(ig, l) 6420 IF ((l<lentr(ig))) THEN 6421 entr_star(ig, l) = 0. 6422 ! detr_star(ig,l)=0. 6423 END IF 6424 ! print*,'ok detr_star' 6425 ! prise en compte du detrainement dans le calcul du flux 6426 f_star(ig, l+1) = f_star(ig, l) + alim_star(ig, l) + & 6427 entr_star(ig, l) - detr_star(ig, l) 6428 ! test sur le signe de f_star 6429 IF ((f_star(ig,l+1)+detr_star(ig,l))>1.E-10) THEN 6430 ! AM on melange Tl et qt du thermique 6431 ztva(ig, l) = (f_star(ig,l)*ztva(ig,l-1)+(entr_star(ig, & 6432 l)+alim_star(ig,l))*ztv(ig,l))/(f_star(ig,l+1)+detr_star(ig,l)) 6433 zw2(ig, l+1) = zw2(ig, l)*(f_star(ig,l)/(f_star(ig, & 6434 l+1)+detr_star(ig,l)))**2 + 2.*rg*(ztva(ig,l)-ztv(ig,l))/ztv(ig, & 6435 l)*(zlev(ig,l+1)-zlev(ig,l)) 6436 END IF 6437 END IF 6438 6439 IF (zw2(ig,l+1)<0.) THEN 6440 linter(ig) = (l*(zw2(ig,l+1)-zw2(ig,l))-zw2(ig,l))/(zw2(ig,l+1)-zw2( & 6441 ig,l)) 6442 zw2(ig, l+1) = 0. 6443 ! print*,'linter=',linter(ig) 6444 ELSE 6445 wa_moy(ig, l+1) = sqrt(zw2(ig,l+1)) 6446 END IF 6447 IF (wa_moy(ig,l+1)>wmaxa(ig)) THEN 6448 ! lmix est le niveau de la couche ou w (wa_moy) est maximum 6449 lmix(ig) = l + 1 6450 wmaxa(ig) = wa_moy(ig, l+1) 6451 END IF 6452 END DO 6453 END DO 6454 ! print*,'fin calcul zw2' 6455 6456 ! Calcul de la couche correspondant a la hauteur du thermique 6457 DO ig = 1, ngrid 6458 lmax(ig) = lentr(ig) 6459 END DO 6460 DO ig = 1, ngrid 6461 DO l = nlay, lentr(ig) + 1, -1 6462 IF (zw2(ig,l)<=1.E-10) THEN 6463 lmax(ig) = l - 1 6464 END IF 6465 END DO 6466 END DO 6467 ! pas de thermique si couche 1 stable 6468 DO ig = 1, ngrid 6469 IF (lmin(ig)>1) THEN 6470 lmax(ig) = 1 6471 lmin(ig) = 1 6472 lentr(ig) = 1 6473 END IF 6474 END DO 6475 6476 ! Determination de zw2 max 6477 DO ig = 1, ngrid 6478 wmax(ig) = 0. 6479 END DO 6480 6481 DO l = 1, nlay 6482 DO ig = 1, ngrid 6483 IF (l<=lmax(ig)) THEN 6484 IF (zw2(ig,l)<0.) THEN 6485 ! print*,'pb2 zw2<0' 6486 END IF 6487 zw2(ig, l) = sqrt(zw2(ig,l)) 6488 wmax(ig) = max(wmax(ig), zw2(ig,l)) 6489 ELSE 6490 zw2(ig, l) = 0. 6491 END IF 6492 END DO 6493 END DO 6494 6495 ! Longueur caracteristique correspondant a la hauteur des thermiques. 6496 DO ig = 1, ngrid 6497 zmax(ig) = 0. 6498 zlevinter(ig) = zlev(ig, 1) 6499 END DO 6500 DO ig = 1, ngrid 6501 ! calcul de zlevinter 6502 zlevinter(ig) = (zlev(ig,lmax(ig)+1)-zlev(ig,lmax(ig)))*linter(ig) + & 6503 zlev(ig, lmax(ig)) - lmax(ig)*(zlev(ig,lmax(ig)+1)-zlev(ig,lmax(ig))) 6504 ! pour le cas ou on prend tjs lmin=1 6505 ! zmax(ig)=max(zmax(ig),zlevinter(ig)-zlev(ig,lmin(ig))) 6506 zmax(ig) = max(zmax(ig), zlevinter(ig)-zlev(ig,1)) 6507 zmax0_sec(ig) = zmax(ig) 6508 END DO 6509 6510 RETURN 6511 END SUBROUTINE fermeture_seche 6512 6513 END MODULE lmdz_thermcell_old -
LMDZ6/trunk/libf/phylmd/lmdz_thermcell_plume.F90
r4589 r4590 1 MODULE lmdz_thermcell_plume 1 2 ! 2 3 ! $Id: thermcell_plume.F90 3074 2017-11-15 13:31:44Z fhourdin $ 3 4 ! 5 CONTAINS 6 4 7 SUBROUTINE thermcell_plume(itap,ngrid,nlay,ptimestep,ztv,zthl,po,zl,rhobarz, & 5 8 & zlev,pplev,pphi,zpspsk,alim_star,alim_star_tot, & … … 22 25 !-------------------------------------------------------------------------- 23 26 24 USE thermcell_ini_mod, ONLY: prt_level,fact_thermals_ed_dz,iflag_thermals_ed,RLvCP,RETV,RG 25 USE thermcell_ini_mod, ONLY: fact_epsilon, betalpha, afact, fact_shell 26 USE thermcell_ini_mod, ONLY: detr_min, entr_min, detr_q_coef, detr_q_power 27 USE thermcell_ini_mod, ONLY: mix0, thermals_flag_alim 27 USE lmdz_thermcell_ini, ONLY: prt_level,fact_thermals_ed_dz,iflag_thermals_ed,RLvCP,RETV,RG 28 USE lmdz_thermcell_ini, ONLY: fact_epsilon, betalpha, afact, fact_shell 29 USE lmdz_thermcell_ini, ONLY: detr_min, entr_min, detr_q_coef, detr_q_power 30 USE lmdz_thermcell_ini, ONLY: mix0, thermals_flag_alim 31 USE lmdz_thermcell_alim, ONLY : thermcell_alim 32 USE lmdz_thermcell_qsat, ONLY : thermcell_qsat 33 28 34 29 35 IMPLICIT NONE … … 446 452 RETURN 447 453 end 454 END MODULE lmdz_thermcell_plume -
LMDZ6/trunk/libf/phylmd/lmdz_thermcell_plume_6A.F90
r4589 r4590 1 MODULE lmdz_thermcell_plume_6A 1 2 ! 2 3 ! $Id$ 3 4 ! 5 CONTAINS 6 4 7 SUBROUTINE thermcell_plume_6A(itap,ngrid,nlay,ptimestep,ztv,zthl,po,zl,rhobarz, & 5 8 & zlev,pplev,pphi,zpspsk,alim_star,alim_star_tot, & … … 12 15 !-------------------------------------------------------------------------- 13 16 14 USE thermcell_ini_mod, ONLY: prt_level,fact_thermals_ed_dz,iflag_thermals_ed,RLvCP,RETV,RG 15 USE thermcell_ini_mod, ONLY: fact_epsilon, betalpha, afact, fact_shell 16 USE thermcell_ini_mod, ONLY: detr_min, entr_min, detr_q_coef, detr_q_power 17 USE thermcell_ini_mod, ONLY: mix0, thermals_flag_alim 17 USE lmdz_thermcell_ini, ONLY: prt_level,fact_thermals_ed_dz,iflag_thermals_ed,RLvCP,RETV,RG 18 USE lmdz_thermcell_ini, ONLY: fact_epsilon, betalpha, afact, fact_shell 19 USE lmdz_thermcell_ini, ONLY: detr_min, entr_min, detr_q_coef, detr_q_power 20 USE lmdz_thermcell_ini, ONLY: mix0, thermals_flag_alim 21 USE lmdz_thermcell_alim, ONLY : thermcell_alim 22 USE lmdz_thermcell_qsat, ONLY : thermcell_qsat 23 18 24 19 25 IMPLICIT NONE … … 718 724 !-------------------------------------------------------------------------- 719 725 720 USE thermcell_ini_mod, ONLY: prt_level,fact_thermals_ed_dz,iflag_thermals_ed,RLvCP,RETV,RG 726 USE lmdz_thermcell_ini, ONLY: prt_level,fact_thermals_ed_dz,iflag_thermals_ed,RLvCP,RETV,RG 727 USE lmdz_thermcell_qsat, ONLY : thermcell_qsat 721 728 IMPLICIT NONE 722 729 … … 1109 1116 return 1110 1117 end 1118 END MODULE lmdz_thermcell_plume_6A -
LMDZ6/trunk/libf/phylmd/lmdz_thermcell_qsat.F90
r4589 r4590 1 MODULE lmdz_thermcell_qsat 2 CONTAINS 3 1 4 subroutine thermcell_qsat(klon,active,pplev,ztemp,zqta,zqsat) 2 5 implicit none … … 94 97 return 95 98 end 99 END MODULE lmdz_thermcell_qsat -
LMDZ6/trunk/libf/phylmd/physiq_mod.F90
r4588 r4590 83 83 USE yamada_ini_mod, ONLY : yamada_ini 84 84 USE atke_turbulence_ini_mod, ONLY : atke_ini 85 USE thermcell_ini_mod, ONLY : thermcell_ini 85 USE lmdz_thermcell_ini, ONLY : thermcell_ini 86 USE lmdz_thermcell_dtke, ONLY : thermcell_dtke 86 87 USE blowing_snow_ini_mod, ONLY : blowing_snow_ini , qbst_bs 87 88 USE lscp_ini_mod, ONLY : lscp_ini -
LMDZ6/trunk/libf/phylmd/phytrac_mod.F90
r4514 r4590 135 135 USE print_control_mod, ONLY: lunout 136 136 USE aero_mod, ONLY : naero_grp 137 USE lmdz_thermcell_dq, ONLY : thermcell_dq 137 138 138 139 USE tracco2i_mod … … 249 250 !---------- 250 251 REAL,DIMENSION(klon,klev+1),INTENT(IN) :: fm_therm 251 REAL,DIMENSION(klon,klev),INTENT(IN ) :: entr_therm252 REAL,DIMENSION(klon,klev),INTENT(INOUT) :: entr_therm 252 253 ! 253 254 !Couche limite:
Note: See TracChangeset
for help on using the changeset viewer.