source: LMDZ6/branches/LMDZ_cdrag_LSCE/libf/phylmd/fisrtilp.F90 @ 5444

Last change on this file since 5444 was 4669, checked in by Laurent Fairhead, 16 months ago

Merged with trunk revision 4586 corresponding to june 2023 testing

  • Property copyright set to
    Name of program: LMDZ
    Creation date: 1984
    Version: LMDZ5
    License: CeCILL version 2
    Holder: Laboratoire de m\'et\'eorologie dynamique, CNRS, UMR 8539
    See the license file in the root directory
  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 65.4 KB
RevLine 
[1403]1! $Id: fisrtilp.F90 4669 2023-09-04 08:17:16Z fhourdin $
[524]2!
[1472]3!
4SUBROUTINE fisrtilp(dtime,paprs,pplay,t,q,ptconv,ratqs, &
[2086]5     d_t, d_q, d_ql, d_qi, rneb, radliq, rain, snow,          &
[1742]6     pfrac_impa, pfrac_nucl, pfrac_1nucl,               &
7     frac_impa, frac_nucl, beta,                        &
8     prfl, psfl, rhcl, zqta, fraca,                     &
[2236]9     ztv, zpspsk, ztla, zthl, iflag_cld_th,             &
[1849]10     iflag_ice_thermo)
[524]11
[1472]12  !
13  USE dimphy
[2109]14  USE icefrac_lsc_mod ! compute ice fraction (JBM 3/14)
[2311]15  USE print_control_mod, ONLY: prt_level, lunout
[2686]16  USE cloudth_mod
[2703]17  USE ioipsl_getin_p_mod, ONLY : getin_p
[2807]18  USE phys_local_var_mod, ONLY: ql_seri,qs_seri
[2945]19  USE phys_local_var_mod, ONLY: rneblsvol
[2807]20  ! flag to include modifications to ensure energy conservation (if flag >0)
21  USE add_phys_tend_mod, only : fl_cor_ebil
[4669]22  USE lscp_ini_mod, ONLY: iflag_t_glace,t_glace_min, t_glace_max, exposant_glace
23  USE lscp_ini_mod, ONLY: iflag_cloudth_vert, iflag_rain_incloud_vol
24  USE lscp_ini_mod, ONLY: coef_eva, coef_eva_i, ffallv_lsc, ffallv_con
25  USE lscp_ini_mod, ONLY: cld_tau_lsc, cld_tau_con, cld_lc_lsc, cld_lc_con
26  USE lscp_ini_mod, ONLY: reevap_ice, iflag_bergeron, iflag_fisrtilp_qsat, iflag_pdf
27
28
[1472]29  IMPLICIT none
30  !======================================================================
31  ! Auteur(s): Z.X. Li (LMD/CNRS)
32  ! Date: le 20 mars 1995
33  ! Objet: condensation et precipitation stratiforme.
34  !        schema de nuage
[2500]35  ! Fusion de fisrt (physique sursaturation, P. LeVan K. Laval)
36  !             et ilp (il pleut, L. Li)
37  ! Principales parties:
[2807]38  ! P0> Thermalisation des precipitations venant de la couche du dessus
[2500]39  ! P1> Evaporation de la precipitation (qui vient du niveau k+1)
40  ! P2> Formation du nuage (en k)
[2807]41  ! P2.A.0> Calcul des grandeurs nuageuses une pdf en creneau
42  ! P2.A.1> Avec les nouvelles PDFs, calcul des grandeurs nuageuses pour
43  ! les valeurs de T et Q initiales
44  ! P2.A.2> Prise en compte du couplage entre eau condensee et T.
45  ! P2.A.3> Calcul des valeures finales associees a la formation des nuages
46  ! P2.B> Nuage "tout ou rien"
47  ! P2.C> Prise en compte de la Chaleur latente apres formation nuage
[2500]48  ! P3> Formation de la precipitation (en k)
[1472]49  !======================================================================
[2807]50  ! JLD:
51  ! * Routine probablement fausse (au moins incoherente) si thermcep = .false.
52  ! * fl_cor_ebil doit etre > 0 ;
53  !   fl_cor_ebil= 0 pour reproduire anciens bugs
[1472]54  !======================================================================
55  include "YOMCST.h"
56  !
[2500]57  ! Principaux inputs:
[1472]58  !
[2814]59  REAL, INTENT(IN)                              :: dtime  ! intervalle du temps (s)
60  REAL, DIMENSION(klon,klev+1),    INTENT(IN)   :: paprs  ! pression a inter-couche
61  REAL, DIMENSION(klon,klev),      INTENT(IN)   :: pplay  ! pression au milieu de couche
62  REAL, DIMENSION(klon,klev),      INTENT(IN)   :: t      ! temperature (K)
63  REAL, DIMENSION(klon,klev),      INTENT(IN)   :: q      ! humidite specifique (kg/kg)
64  LOGICAL, DIMENSION(klon,klev),   INTENT(IN)   :: ptconv ! points ou le schema de conv. prof. est actif
65  INTEGER,                         INTENT(IN)   :: iflag_cld_th
66  INTEGER,                         INTENT(IN)   :: iflag_ice_thermo
[2500]67  !
[2814]68  ! Inputs lies aux thermiques
69  !
70  REAL, DIMENSION(klon,klev),      INTENT(IN)   :: ztv
71  REAL, DIMENSION(klon,klev),      INTENT(IN)   :: zqta, fraca
72  REAL, DIMENSION(klon,klev),      INTENT(IN)   :: zpspsk, ztla
73  REAL, DIMENSION(klon,klev),      INTENT(IN)   :: zthl
74  !
75  !  Input/output
76  REAL, DIMENSION(klon,klev),      INTENT(INOUT):: ratqs  ! determine la largeur de distribution de vapeur
77  !
[2500]78  ! Principaux outputs:
79  !
[2814]80  REAL, DIMENSION(klon,klev),      INTENT(OUT)  :: d_t  ! incrementation de la temperature (K)
81  REAL, DIMENSION(klon,klev),      INTENT(OUT)  :: d_q  ! incrementation de la vapeur d'eau
82  REAL, DIMENSION(klon,klev),      INTENT(OUT)  :: d_ql ! incrementation de l'eau liquide
83  REAL, DIMENSION(klon,klev),      INTENT(OUT)  :: d_qi ! incrementation de l'eau glace
84  REAL, DIMENSION(klon,klev),      INTENT(OUT)  :: rneb ! fraction nuageuse
85  REAL, DIMENSION(klon,klev),      INTENT(OUT)  :: radliq ! eau liquide utilisee dans rayonnements
86  REAL, DIMENSION(klon,klev),      INTENT(OUT)  :: rhcl ! humidite relative en ciel clair
87  REAL, DIMENSION(klon),           INTENT(OUT)  :: rain
88  REAL, DIMENSION(klon),           INTENT(OUT)  :: snow
89  REAL, DIMENSION(klon,klev+1),    INTENT(OUT)  :: prfl
90  REAL, DIMENSION(klon,klev+1),    INTENT(OUT)  :: psfl
[1403]91
[1472]92  !AA
93  ! Coeffients de fraction lessivee : pour OFF-LINE
94  !
[4380]95  REAL, DIMENSION(klon,klev),      INTENT(INOUT)  :: pfrac_nucl
96  REAL, DIMENSION(klon,klev),      INTENT(INOUT)  :: pfrac_1nucl
97  REAL, DIMENSION(klon,klev),      INTENT(INOUT)  :: pfrac_impa
[1472]98  !
99  ! Fraction d'aerosols lessivee par impaction et par nucleation
100  ! POur ON-LINE
101  !
[2814]102  REAL, DIMENSION(klon,klev),      INTENT(OUT)  :: frac_impa
103  REAL, DIMENSION(klon,klev),      INTENT(OUT)  :: frac_nucl
[1472]104  !AA
[2814]105  ! --------------------------------------------------------------------------------
[1472]106  !
107  ! Options du programme:
108  !
[2923]109  REAL, SAVE :: seuil_neb=0.001 ! un nuage existe vraiment au-dela
[3992]110  !$OMP THREADPRIVATE(seuil_neb)
111
[3875]112  !<LTP
113  REAL smallestreal
114  REAL, SAVE :: rain_int_min=0.001 !intensité locale minimum pour la pluie avant diminution de la fraction précipitante associée = 0.001 mm/s
115  !>LTP 
[3992]116  !$OMP THREADPRIVATE(rain_int_min)
[3875]117
118
[1472]119  INTEGER ninter ! sous-intervals pour la precipitation
120  PARAMETER (ninter=5)
[2923]121  INTEGER,SAVE :: iflag_evap_prec=1 ! evaporation de la pluie
122  !$OMP THREADPRIVATE(iflag_evap_prec)
[1472]123  !
124  LOGICAL cpartiel ! condensation partielle
125  PARAMETER (cpartiel=.TRUE.)
126  REAL t_coup
127  PARAMETER (t_coup=234.0)
[2814]128  REAL DDT0
129  PARAMETER (DDT0=.01)
130  REAL ztfondue
131  PARAMETER (ztfondue=278.15)
132  ! --------------------------------------------------------------------------------
[1472]133  !
134  ! Variables locales:
135  !
136  INTEGER i, k, n, kk
[2923]137  INTEGER,save::itap=0
138  !$OMP THREADPRIVATE(itap)
139
[2814]140  REAL qsl, qsi
141  real zct      ,zcl
142  INTEGER ncoreczq 
143  REAL ctot(klon,klev)
[2945]144  REAL ctot_vol(klon,klev)
[1901]145  REAL zqs(klon), zdqs(klon), zdelta, zcor, zcvm5 
[2807]146  REAL zdqsdT_raw(klon)
[1901]147  REAL Tbef(klon),qlbef(klon),DT(klon),num,denom
[2814]148
149  logical lognormale(klon)
150  logical ice_thermo
[1901]151  LOGICAL convergence(klon)
[2086]152  INTEGER n_i(klon), iter
153  REAL cste
[2814]154
155  real zpdf_sig(klon),zpdf_k(klon),zpdf_delta(klon)
156  real Zpdf_a(klon),zpdf_b(klon),zpdf_e1(klon),zpdf_e2(klon)
157  real erf   
158  REAL qcloud(klon)
[1901]159 
[3875]160  REAL zrfl(klon), zrfln(klon), zqev, zqevt
161!<LTP
162  REAL zrflclr(klon), zrflcld(klon)
163  REAL d_zrfl_clr_cld(klon), d_zifl_clr_cld(klon)
164  REAL d_zrfl_cld_clr(klon), d_zifl_cld_clr(klon)
165!>LTP
166
[1849]167  REAL zifl(klon), zifln(klon), zqev0,zqevi, zqevti
[3875]168!<LTP
169  REAL ziflclr(klon), ziflcld(klon)
170!>LTP
[1849]171  REAL zoliq(klon), zcond(klon), zq(klon), zqn(klon), zdelq
172  REAL zoliqp(klon), zoliqi(klon)
[2006]173  REAL zt(klon)
174! JBM (3/14) nexpo is replaced by exposant_glace
175! REAL nexpo ! exponentiel pour glace/eau
176! INTEGER, PARAMETER :: nexpo=6
177  INTEGER exposant_glace_old
178  REAL t_glace_min_old
[1472]179  REAL zdz(klon),zrho(klon),ztot      , zrhol(klon)
[2923]180  REAL zchau      ,zfroi      ,zfice(klon),zneb(klon),znebprecip(klon)
[3875]181!<LTP
182  REAL znebprecipclr(klon), znebprecipcld(klon)
183  REAL tot_zneb(klon), tot_znebn(klon), d_tot_zneb(klon)
184  REAL d_znebprecip_clr_cld(klon), d_znebprecip_cld_clr(klon)
185!>LTP
186
[2814]187  REAL zmelt, zpluie, zice
[2086]188  REAL dzfice(klon)
[2415]189  REAL zsolid
[2466]190!!!!
191!  Variables pour Bergeron
[2807]192  REAL zcp, coef1, DeltaT, Deltaq, Deltaqprecl
[2466]193  REAL zqpreci(klon), zqprecl(klon)
[2807]194! Variable pour conservation enegie des precipitations
195  REAL zmqc(klon)
[1472]196  !
197  LOGICAL appel1er
198  SAVE appel1er
199  !$OMP THREADPRIVATE(appel1er)
200  !
[2703]201! iflag_oldbug_fisrtilp=0 enleve le BUG par JYG : tglace_min -> tglace_max
202! iflag_oldbug_fisrtilp=1 ajoute le BUG
203  INTEGER,SAVE :: iflag_oldbug_fisrtilp=0 !=0 sans bug
204  !$OMP THREADPRIVATE(iflag_oldbug_fisrtilp)
[1472]205  !---------------------------------------------------------------
206  !
207  !AA Variables traceurs:
208  !AA  Provisoire !!! Parametres alpha du lessivage
209  !AA  A priori on a 4 scavenging # possibles
210  !
211  REAL a_tr_sca(4)
212  save a_tr_sca
213  !$OMP THREADPRIVATE(a_tr_sca)
214  !
215  ! Variables intermediaires
216  !
217  REAL zalpha_tr
218  REAL zfrac_lessi
219  REAL zprec_cond(klon)
220  !AA
[1742]221! RomP >>> 15 nov 2012
222  REAL   beta(klon,klev) ! taux de conversion de l'eau cond
223! RomP <<<
[2807]224  REAL zmair(klon), zcpair, zcpeau
[1472]225  !     Pour la conversion eau-neige
226  REAL zlh_solid(klon), zm_solid
227  !---------------------------------------------------------------
228  !
229  ! Fonctions en ligne:
230  !
[2500]231  REAL fallvs,fallvc ! Vitesse de chute pour cristaux de glace
232                     ! (Heymsfield & Donner, 1990)
[1472]233  REAL zzz
234  include "YOETHF.h"
235  include "FCTTRE.h"
236  fallvc (zzz) = 3.29/2.0 * ((zzz)**0.16) * ffallv_con
237  fallvs (zzz) = 3.29/2.0 * ((zzz)**0.16) * ffallv_lsc
238  !
239  DATA appel1er /.TRUE./
240  !ym
[2086]241!CR: pour iflag_ice_thermo=2, on active que la convection
242!  ice_thermo = iflag_ice_thermo .GE. 1
[2923]243
[3875]244 
[2945]245  itap=itap+1
246  znebprecip(:)=0.
[2923]247
[3875]248!<LTP
249  smallestreal=1.e-9
250  znebprecipclr(:)=0.
251  znebprecipcld(:)=0.
252!>LTP
253
[2945]254  ice_thermo = (iflag_ice_thermo .EQ. 1).OR.(iflag_ice_thermo .GE. 3)
[1472]255  zdelq=0.0
[2945]256  ctot_vol(1:klon,1:klev)=0.0
257  rneblsvol(1:klon,1:klev)=0.0
[524]258
[1506]259  if (prt_level>9)write(lunout,*)'NUAGES4 A. JAM'
[1472]260  IF (appel1er) THEN
[2703]261     CALL getin_p('iflag_oldbug_fisrtilp',iflag_oldbug_fisrtilp)
[2923]262     CALL getin_p('iflag_evap_prec',iflag_evap_prec)
263     CALL getin_p('seuil_neb',seuil_neb)
[3875]264!<LTP   
265     CALL getin_p('rain_int_min',rain_int_min)
266!>LTP
[2703]267     write(lunout,*)' iflag_oldbug_fisrtilp =',iflag_oldbug_fisrtilp
[1472]268     !
[1575]269     WRITE(lunout,*) 'fisrtilp, ninter:', ninter
[2923]270     WRITE(lunout,*) 'fisrtilp, iflag_evap_prec:', iflag_evap_prec
[3875]271!<LTP   
272     WRITE(lunout,*) 'fisrtilp, rain_int_min:', rain_int_min
273!>LTP   
[1575]274     WRITE(lunout,*) 'fisrtilp, cpartiel:', cpartiel
[3875]275     WRITE(lunout,*) 'FISRTILP VERSION LUDO'
[2923]276     
[1472]277     IF (ABS(dtime/REAL(ninter)-360.0).GT.0.001) THEN
[1575]278        WRITE(lunout,*) 'fisrtilp: Ce n est pas prevu, voir Z.X.Li', dtime
279        WRITE(lunout,*) 'Je prefere un sous-intervalle de 6 minutes'
[1472]280        !         CALL abort
281     ENDIF
282     appel1er = .FALSE.
283     !
284     !AA initialiation provisoire
285     a_tr_sca(1) = -0.5
286     a_tr_sca(2) = -0.5
287     a_tr_sca(3) = -0.5
288     a_tr_sca(4) = -0.5
289     !
290     !AA Initialisation a 1 des coefs des fractions lessivees
291     !
292     !cdir collapse
293     DO k = 1, klev
294        DO i = 1, klon
295           pfrac_nucl(i,k)=1.
296           pfrac_1nucl(i,k)=1.
297           pfrac_impa(i,k)=1.
[1742]298           beta(i,k)=0.  !RomP initialisation
[1472]299        ENDDO
300     ENDDO
[524]301
[1472]302  ENDIF          !  test sur appel1er
303  !
304  !MAf Initialisation a 0 de zoliq
305  !      DO i = 1, klon
306  !         zoliq(i)=0.
307  !      ENDDO
308  ! Determiner les nuages froids par leur temperature
309  !  nexpo regle la raideur de la transition eau liquide / eau glace.
310  !
[2086]311!CR: on est oblige de definir des valeurs fisrt car les valeurs de newmicro ne sont pas les memes par defaut
[2006]312  IF (iflag_t_glace.EQ.0) THEN
313!   ztglace = RTT - 15.0
314    t_glace_min_old = RTT - 15.0
315    !AJ<
316    IF (ice_thermo) THEN
317!     nexpo = 2
318      exposant_glace_old = 2
319    ELSE
320!     nexpo = 6
321      exposant_glace_old = 6
322    ENDIF
[2086]323   
[1849]324  ENDIF
[2006]325 
[1849]326!!  RLVTT = 2.501e6 ! pas de redefinition des constantes physiques (jyg)
327!!  RLSTT = 2.834e6 ! pas de redefinition des constantes physiques (jyg)
328!>AJ
[1472]329  !cc      nexpo = 1
330  !
331  ! Initialiser les sorties:
332  !
333  !cdir collapse
334  DO k = 1, klev+1
335     DO i = 1, klon
336        prfl(i,k) = 0.0
337        psfl(i,k) = 0.0
338     ENDDO
339  ENDDO
[524]340
[1472]341  !cdir collapse
[3875]342
[1472]343  DO k = 1, klev
344     DO i = 1, klon
345        d_t(i,k) = 0.0
346        d_q(i,k) = 0.0
347        d_ql(i,k) = 0.0
[2086]348        d_qi(i,k) = 0.0
[1472]349        rneb(i,k) = 0.0
350        radliq(i,k) = 0.0
351        frac_nucl(i,k) = 1.
352        frac_impa(i,k) = 1.
353     ENDDO
354  ENDDO
355  DO i = 1, klon
356     rain(i) = 0.0
357     snow(i) = 0.0
358     zoliq(i)=0.
359     !     ENDDO
360     !
361     ! Initialiser le flux de precipitation a zero
362     !
363     !     DO i = 1, klon
364     zrfl(i) = 0.0
[1849]365     zifl(i) = 0.0
[3875]366!<LTP
367     zrflclr(i) = 0.0
368     ziflclr(i) = 0.0
369     zrflcld(i) = 0.0
370     ziflcld(i) = 0.0
371     tot_zneb(i) = 0.0
372     tot_znebn(i) = 0.0
373     d_tot_zneb(i) = 0.0
374!>LTP
375
[1472]376     zneb(i) = seuil_neb
377  ENDDO
378  !
379  !
380  !AA Pour plus de securite
[524]381
[1472]382  zalpha_tr   = 0.
383  zfrac_lessi = 0.
[524]384
[2500]385  !AA==================================================================
[1472]386  !
387  ncoreczq=0
[2500]388  ! BOUCLE VERTICALE (DU HAUT VERS LE BAS)
[1472]389  !
390  DO k = klev, 1, -1
391     !
[2500]392     !AA===============================================================
[1472]393     !
[2500]394     ! Initialisation temperature et vapeur
[1472]395     DO i = 1, klon
396        zt(i)=t(i,k)
397        zq(i)=q(i,k)
398     ENDDO
399     !
[2807]400     ! ----------------------------------------------------------------
401     ! P0> Thermalisation des precipitations venant de la couche du dessus
402     ! ----------------------------------------------------------------
[1472]403     ! Calculer la varition de temp. de l'air du a la chaleur sensible
[2807]404     ! transporter par la pluie. On thermalise la pluie avec l'air de la couche.
405     ! Cette quantite de pluie qui est thermalisee, et devra continue a l'etre lors
406     ! des differentes transformations thermodynamiques. Cette masse d'eau doit
407     ! donc etre ajoute a l'humidite de la couche lorsque l'on calcule la variation
408     ! de l'enthalpie  de la couche avec la temperature
409     ! Variables calculees ou modifiees:
410     !   -  zt: temperature de la cocuhe
411     !   - zmqc: masse de precip qui doit etre thermalisee
[1472]412     !
413     IF(k.LE.klevm1) THEN         
414        DO i = 1, klon
415           !IM
[2807]416           zmair(i)=(paprs(i,k)-paprs(i,k+1))/RG
417           ! il n'y a pas encore d'eau liquide ni glace dans la maiille, donc zq suffit
[1472]418           zcpair=RCPD*(1.0+RVTMP2*zq(i))
419           zcpeau=RCPD*RVTMP2
[2807]420         if (fl_cor_ebil .GT. 0) then
421           ! zmqc: masse de precip qui doit etre thermalisee avec l'air de la couche atm
422           ! pour s'assurer que la precip arrivant au sol aura bien la temperature de la
423           ! derniere couche
424           zmqc(i) = (zrfl(i)+zifl(i))*dtime/zmair(i)
425           ! t(i,k+1)+d_t(i,k+1): nouvelle temp de la couche au dessus
426           zt(i) = ( (t(i,k+1)+d_t(i,k+1))*zmqc(i)*zcpeau + zcpair*zt(i) ) &
427                 / (zcpair + zmqc(i)*zcpeau)
428         else ! si on maintient les anciennes erreurs
[1472]429           zt(i) = ( (t(i,k+1)+d_t(i,k+1))*zrfl(i)*dtime*zcpeau &
[2807]430                + zmair(i)*zcpair*zt(i) ) &
431                / (zmair(i)*zcpair + zrfl(i)*dtime*zcpeau)
432         end if
[1472]433        ENDDO
[2885]434     ELSE  ! IF(k.LE.klevm1)
435        DO i = 1, klon
436           zmair(i)=(paprs(i,k)-paprs(i,k+1))/RG
437           zmqc(i) = 0.
438        ENDDO
[2807]439     ENDIF ! end IF(k.LE.klevm1)
440     !
[2500]441     ! ----------------------------------------------------------------
[2807]442     ! P1> Calcul de l'evaporation de la precipitation
[2500]443     ! ----------------------------------------------------------------
[2807]444     ! On evapore une partie des precipitations venant de la maille du dessus.
445     ! On calcule l'evaporation et la sublimation des precipitations, jusqu'a
446     ! ce que la fraction de cette couche qui est sous le nuage soit saturee.
447     ! Variables calculees ou modifiees:
448     !   - zrfl et zifl: flux de precip liquide et glace
449     !   - zq, zt: humidite et temperature de la cocuhe
450     !   - zmqc: masse de precip qui doit etre thermalisee
451     !
[2923]452     IF (iflag_evap_prec>=1) THEN
[1472]453        DO i = 1, klon
[2807]454!          S'il y a des precipitations
[1849]455           IF (zrfl(i)+zifl(i).GT.0.) THEN
[2500]456              ! Calcul du qsat
[1472]457              IF (thermcep) THEN
458                 zdelta=MAX(0.,SIGN(1.,RTT-zt(i)))
459                 zqs(i)= R2ES*FOEEW(zt(i),zdelta)/pplay(i,k)
460                 zqs(i)=MIN(0.5,zqs(i))
461                 zcor=1./(1.-RETV*zqs(i))
462                 zqs(i)=zqs(i)*zcor
463              ELSE
464                 IF (zt(i) .LT. t_coup) THEN
465                    zqs(i) = qsats(zt(i)) / pplay(i,k)
466                 ELSE
467                    zqs(i) = qsatl(zt(i)) / pplay(i,k)
468                 ENDIF
469              ENDIF
[1849]470           ENDIF ! (zrfl(i)+zifl(i).GT.0.)
471        ENDDO
472!AJ<
[2807]473
[1849]474       IF (.NOT. ice_thermo) THEN
475        DO i = 1, klon
[2807]476!          S'il y a des precipitations
[1849]477           IF (zrfl(i)+zifl(i).GT.0.) THEN
[2500]478                ! Evap max pour ne pas saturer la fraction sous le nuage
[3493]479                ! Evap max jusqu'à atteindre la saturation dans la partie
[2807]480                ! de la maille qui est sous le nuage de la couche du dessus
481                !!! On ne tient compte de cette fraction que sous une seule
482                !!! couche sous le nuage
[1849]483                zqev = MAX (0.0, (zqs(i)-zq(i))*zneb(i) )
[2807]484             ! Ajout de la prise en compte des precip a thermiser
485             ! avec petite reecriture
486             if  (fl_cor_ebil .GT. 0) then ! nouveau
[2500]487                ! Calcul de l'evaporation du flux de precip herite
488                !   d'au-dessus
[1849]489                zqevt = coef_eva * (1.0-zq(i)/zqs(i)) * SQRT(zrfl(i)) &
[2807]490                     * zmair(i)/pplay(i,k)*zt(i)*RD
491                zqevt = MAX(0.0,MIN(zqevt,zrfl(i))) * dtime/zmair(i)
492
493                ! Seuil pour ne pas saturer la fraction sous le nuage
494                zqev = MIN (zqev, zqevt)
495                ! Nouveau flux de precip
496                zrfln(i) = zrfl(i) - zqev*zmair(i)/dtime
497                ! Aucun flux liquide pour T < t_coup, on reevapore tout.
498                IF (zt(i) .LT. t_coup.and.reevap_ice) THEN
499                  zrfln(i)=0.
500                  zqev = (zrfl(i)-zrfln(i))/zmair(i)*dtime
501                END IF
502                ! Nouvelle vapeur
503                zq(i) = zq(i) + zqev
504                zmqc(i) = zmqc(i)-zqev
505                ! Nouvelle temperature (chaleur latente)
506                zt(i) = zt(i) - zqev &
507                     * RLVTT/RCPD/(1.0+RVTMP2*(zq(i)+zmqc(i)))
[2814]508!!JLD debut de partie a supprimer a terme
[2807]509            else ! if  (fl_cor_ebil .GT. 0)
510                ! Calcul de l'evaporation du flux de precip herite
511                !   d'au-dessus
512                zqevt = coef_eva * (1.0-zq(i)/zqs(i)) * SQRT(zrfl(i)) &
[1849]513                     * (paprs(i,k)-paprs(i,k+1))/pplay(i,k)*zt(i)*RD/RG
514                zqevt = MAX(0.0,MIN(zqevt,zrfl(i))) &
515                     * RG*dtime/(paprs(i,k)-paprs(i,k+1))
[2500]516                ! Seuil pour ne pas saturer la fraction sous le nuage
[1849]517                zqev = MIN (zqev, zqevt)
[2500]518                ! Nouveau flux de precip
[1849]519                zrfln(i) = zrfl(i) - zqev*(paprs(i,k)-paprs(i,k+1)) &
520                     /RG/dtime
[2500]521                ! Aucun flux liquide pour T < t_coup
[1849]522                IF (zt(i) .LT. t_coup.and.reevap_ice) zrfln(i)=0.
[2500]523                ! Nouvelle vapeur
[1849]524                zq(i) = zq(i) - (zrfln(i)-zrfl(i)) &
525                     * (RG/(paprs(i,k)-paprs(i,k+1)))*dtime
[2500]526                ! Nouvelle temperature (chaleur latente)
[1849]527                zt(i) = zt(i) + (zrfln(i)-zrfl(i)) &
528                     * (RG/(paprs(i,k)-paprs(i,k+1)))*dtime &
529                     * RLVTT/RCPD/(1.0+RVTMP2*zq(i))
[2807]530              end if ! if  (fl_cor_ebil .GT. 0)
[2814]531!!JLD fin de partie a supprimer a terme
[1849]532                zrfl(i) = zrfln(i)
533                zifl(i) = 0.
534           ENDIF ! (zrfl(i)+zifl(i).GT.0.)
535        ENDDO
536!
537       ELSE ! (.NOT. ice_thermo)
[2807]538!      ================================
539!      Avec thermodynamique de la glace
540!      ================================
[1849]541        DO i = 1, klon
[3875]542
543
[1849]544!AJ<
[2807]545!        S'il y a des precipitations
546         IF (zrfl(i)+zifl(i).GT.0.) THEN
[2923]547
[3875]548        !LTP<
549        !On ne tient compte que du flux de précipitation en ciel clair dans le calcul de l'évaporation.
550                IF (iflag_evap_prec==4) THEN
551                        zrfl(i) = zrflclr(i)
552                        zifl(i) = ziflclr(i)
553                ENDIF
554       
555        !>LTP
556
[2923]557         IF (iflag_evap_prec==1) THEN
558            znebprecip(i)=zneb(i)
559         ELSE
560            znebprecip(i)=MAX(zneb(i),znebprecip(i))
561         ENDIF
[3875]562         
563         IF (iflag_evap_prec==4) THEN
564        ! Evap max pour ne pas saturer toute la maille
565         zqev0 = MAX (0.0, zqs(i)-zq(i))
566         ELSE
[2807]567        ! Evap max pour ne pas saturer la fraction sous le nuage
[2923]568         zqev0 = MAX (0.0, (zqs(i)-zq(i))*znebprecip(i) )
[3875]569         ENDIF
[524]570
[2807]571         !JAM
572         ! On differencie qsat pour l'eau et la glace
573         ! Si zdelta=1. --> glace
574         ! Si zdelta=0. --> eau liquide
[2500]575       
576         ! Calcul du qsat par rapport a l'eau liquide
[1849]577         qsl= R2ES*FOEEW(zt(i),0.)/pplay(i,k)
578         qsl= MIN(0.5,qsl)
579         zcor= 1./(1.-RETV*qsl)
580         qsl= qsl*zcor
581         
[2807]582         ! Calcul de l'evaporation du flux de precip venant du dessus
[2500]583         ! Formulation en racine du flux de precip
584         ! (Klemp & Wilhelmson, 1978; Sundqvist, 1988)
[2962]585         IF (iflag_evap_prec==3) THEN
586         zqevt = znebprecip(i)*coef_eva*(1.0-zq(i)/qsl) &
587              *SQRT(zrfl(i)/max(1.e-4,znebprecip(i))) &
588              *(paprs(i,k)-paprs(i,k+1))/pplay(i,k)*zt(i)*RD/RG
[3875]589!<LTP
590         ELSE IF (iflag_evap_prec==4) THEN
591         zqevt = znebprecipclr(i)*coef_eva*(1.0-zq(i)/qsl) &
592              *SQRT(zrfl(i)/max(1.e-8,znebprecipclr(i))) &
593              *(paprs(i,k)-paprs(i,k+1))/pplay(i,k)*zt(i)*RD/RG
594!>LTP
595        ELSE
[1849]596         zqevt = 1.*coef_eva*(1.0-zq(i)/qsl)*SQRT(zrfl(i)) &
597              *(paprs(i,k)-paprs(i,k+1))/pplay(i,k)*zt(i)*RD/RG
[2962]598         ENDIF
599
600
[1849]601         zqevt = MAX(0.0,MIN(zqevt,zrfl(i))) &
602              *RG*dtime/(paprs(i,k)-paprs(i,k+1))
[2500]603         
604         ! Calcul du qsat par rapport a la glace
[1849]605         qsi= R2ES*FOEEW(zt(i),1.)/pplay(i,k)
606         qsi= MIN(0.5,qsi)
607         zcor= 1./(1.-RETV*qsi)
608         qsi= qsi*zcor
[1472]609
[2500]610         ! Calcul de la sublimation du flux de precip solide herite
611         !   d'au-dessus
[2962]612         IF (iflag_evap_prec==3) THEN
613         zqevti = znebprecip(i)*coef_eva*(1.0-zq(i)/qsi) &
614              *SQRT(zifl(i)/max(1.e-4,znebprecip(i))) &
615              *(paprs(i,k)-paprs(i,k+1))/pplay(i,k)*zt(i)*RD/RG
[3875]616!<LTP
617         ELSE IF (iflag_evap_prec==4) THEN
618         zqevti = znebprecipclr(i)*coef_eva*(1.0-zq(i)/qsi) &
619              *SQRT(zifl(i)/max(1.e-8,znebprecipclr(i))) &
620              *(paprs(i,k)-paprs(i,k+1))/pplay(i,k)*zt(i)*RD/RG
621!>LTP
[2962]622         ELSE
[1849]623         zqevti = 1.*coef_eva*(1.0-zq(i)/qsi)*SQRT(zifl(i)) &
624              *(paprs(i,k)-paprs(i,k+1))/pplay(i,k)*zt(i)*RD/RG
[2962]625         ENDIF
[1849]626         zqevti = MAX(0.0,MIN(zqevti,zifl(i))) &
627              *RG*dtime/(paprs(i,k)-paprs(i,k+1))   
628
[3875]629       
[2807]630        !JAM
631        ! Limitation de l'evaporation. On s'assure qu'on ne sature pas
632        ! la fraction de la couche sous le nuage sinon on repartit zqev0
633        ! en conservant la proportion liquide / glace
[1849]634     
635         IF (zqevt+zqevti.GT.zqev0) THEN
[2807]636            zqev=zqev0*zqevt/(zqevt+zqevti)
637            zqevi=zqev0*zqevti/(zqevt+zqevti)
[1849]638         ELSE
[2807]639!JLD je ne comprends pas les lignes ci-dessous. On repartit les precips
640!       liquides et solides meme si on ne sature pas la couche.
641!       A mon avis, le test est inutile, et il faudrait tout remplacer par:
642!            zqev=zqevt
643!            zqevi=zqevti
[1849]644             IF (zqevt+zqevti.GT.0.) THEN
[2807]645                zqev=MIN(zqev0*zqevt/(zqevt+zqevti),zqevt)
646                zqevi=MIN(zqev0*zqevti/(zqevt+zqevti),zqevti)
[1849]647             ELSE
648             zqev=0.
649             zqevi=0.
650             ENDIF
651         ENDIF
[3875]652
[2500]653         ! Nouveaux flux de precip liquide et solide
[1849]654         zrfln(i) = Max(0.,zrfl(i) - zqev*(paprs(i,k)-paprs(i,k+1)) &
655                                 /RG/dtime)
656         zifln(i) = Max(0.,zifl(i) - zqevi*(paprs(i,k)-paprs(i,k+1)) &
657                                 /RG/dtime)
[2500]658
659         ! Mise a jour de la vapeur, temperature et flux de precip
[1849]660         zq(i) = zq(i) - (zrfln(i)+zifln(i)-zrfl(i)-zifl(i)) &
661                  * (RG/(paprs(i,k)-paprs(i,k+1)))*dtime
[2807]662       if (fl_cor_ebil .GT. 0) then ! avec correction thermalisation des precips
663         zmqc(i) = zmqc(i) + (zrfln(i)+zifln(i)-zrfl(i)-zifl(i)) &
664                  * (RG/(paprs(i,k)-paprs(i,k+1)))*dtime
[1849]665         zt(i) = zt(i) + (zrfln(i)-zrfl(i)) &
666                  * (RG/(paprs(i,k)-paprs(i,k+1)))*dtime &
[2807]667                  * RLVTT/RCPD/(1.0+RVTMP2*(zq(i)+zmqc(i))) &
668                  + (zifln(i)-zifl(i)) &
669                  * (RG/(paprs(i,k)-paprs(i,k+1)))*dtime &
670                  * RLSTT/RCPD/(1.0+RVTMP2*(zq(i)+zmqc(i)))
671       else ! sans correction thermalisation des precips
672         zt(i) = zt(i) + (zrfln(i)-zrfl(i)) &
673                  * (RG/(paprs(i,k)-paprs(i,k+1)))*dtime &
[1849]674                  * RLVTT/RCPD/(1.0+RVTMP2*zq(i)) &
675                  + (zifln(i)-zifl(i)) &
676                  * (RG/(paprs(i,k)-paprs(i,k+1)))*dtime &
677                  * RLSTT/RCPD/(1.0+RVTMP2*zq(i))
[2807]678       end if
679        ! Nouvelles vaeleurs des precips liquides et solides
[1849]680         zrfl(i) = zrfln(i)
681         zifl(i) = zifln(i)
[3875]682
683!<LTP
684        IF (iflag_evap_prec==4) THEN
685                zrflclr(i) = zrfl(i)
686                ziflclr(i) = zifl(i)   
687                IF(zrflclr(i) + ziflclr(i) .LE. 0) THEN
688                        znebprecipclr(i) = 0.
689                ENDIF   
690                zrfl(i) = zrflclr(i) + zrflcld(i)
691                zifl(i) = ziflclr(i) + ziflcld(i)
692        ENDIF
693!>LTP       
694
695
[2923]696!        print*,'REEVAP ',itap,k,znebprecip(1),zqev0,zqev,zqevi,zrfl(1)
[1849]697
[2086]698!CR ATTENTION: deplacement de la fonte de la glace
[2466]699!jyg : Bug !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! jyg
700!!!        zmelt = ((zt(i)-273.15)/(ztfondue-273.15))**2  !!!!!!!!! jyg
701!jyg : Bug !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! jyg
702           zmelt = ((zt(i)-273.15)/(ztfondue-273.15))             ! jyg
[2807]703           ! fraction de la precip solide qui est fondue
[2086]704           zmelt = MIN(MAX(zmelt,0.),1.)
[2500]705           ! Fusion de la glace
[3875]706!<LTP
707           IF (iflag_evap_prec==4) THEN
708                   zrflclr(i)=zrflclr(i)+zmelt*ziflclr(i)
709                   zrflcld(i)=zrflcld(i)+zmelt*ziflcld(i)
710                   zrfl(i)=zrflclr(i)+zrflcld(i)
711!>LTP       
712           ELSE
713                   zrfl(i)=zrfl(i)+zmelt*zifl(i)
714           ENDIF
[2807]715           if (fl_cor_ebil .LE. 0) then
716             ! the following line should not be here. Indeed, if zifl is modified
717             ! now, zifl(i)*zmelt is no more the amount of ice that has melt
718             ! and therefore the change in temperature computed below is wrong
719             zifl(i)=zifl(i)*(1.-zmelt)
720           end if
[2500]721           ! Chaleur latente de fusion
[2807]722        if (fl_cor_ebil .GT. 0) then ! avec correction thermalisation des precips
[2086]723           zt(i)=zt(i)-zifl(i)*zmelt*(RG*dtime)/(paprs(i,k)-paprs(i,k+1)) &
[2807]724                      *RLMLT/RCPD/(1.0+RVTMP2*(zq(i)+zmqc(i)))
725        else ! sans correction thermalisation des precips
726           zt(i)=zt(i)-zifl(i)*zmelt*(RG*dtime)/(paprs(i,k)-paprs(i,k+1)) &
[2086]727                      *RLMLT/RCPD/(1.0+RVTMP2*zq(i))
[2807]728        end if
729           if (fl_cor_ebil .GT. 0) then ! correction bug, deplacement ligne precedente
[3875]730!<LTP
731             IF (iflag_evap_prec==4) THEN
732                   ziflclr(i)=ziflclr(i)*(1.-zmelt)
733                   ziflcld(i)=ziflcld(i)*(1.-zmelt)
734                   zifl(i)=ziflclr(i)+ziflcld(i)
735!>LTP       
736             ELSE
737                   zifl(i)=zifl(i)*(1.-zmelt)
738             ENDIF
[2807]739           end if
[2086]740
[2923]741           ELSE
742              ! Si on n'a plus de pluies, on reinitialise a 0 la farcion
743              ! sous nuageuse utilisee pour la pluie.
744              znebprecip(i)=0.
[1849]745           ENDIF ! (zrfl(i)+zifl(i).GT.0.)
[1472]746        ENDDO
[1849]747
748      ENDIF ! (.NOT. ice_thermo)
749     
[2500]750     ! ----------------------------------------------------------------
751     ! Fin evaporation de la precipitation
752     ! ----------------------------------------------------------------
[2923]753     ENDIF ! (iflag_evap_prec>=1)
[1472]754     !
755     ! Calculer Qs et L/Cp*dQs/dT:
756     !
757     IF (thermcep) THEN
758        DO i = 1, klon
[524]759           zdelta = MAX(0.,SIGN(1.,RTT-zt(i)))
760           zcvm5 = R5LES*RLVTT*(1.-zdelta) + R5IES*RLSTT*zdelta
[2807]761       if  (fl_cor_ebil .GT. 0) then ! nouveau
762           zcvm5 = zcvm5 /RCPD/(1.0+RVTMP2*(zq(i)+zmqc(i)))
763       else   
[524]764           zcvm5 = zcvm5 /RCPD/(1.0+RVTMP2*zq(i))
[2807]765       endif
[524]766           zqs(i) = R2ES*FOEEW(zt(i),zdelta)/pplay(i,k)
767           zqs(i) = MIN(0.5,zqs(i))
768           zcor = 1./(1.-RETV*zqs(i))
769           zqs(i) = zqs(i)*zcor
770           zdqs(i) = FOEDE(zt(i),zdelta,zcvm5,zqs(i),zcor)
[2807]771           zdqsdT_raw(i) = zdqs(i)*  &
772         &         RCPD*(1.0+RVTMP2*zq(i)) / (RLVTT*(1.-zdelta) + RLSTT*zdelta)
[1472]773        ENDDO
774     ELSE
775        DO i = 1, klon
776           IF (zt(i).LT.t_coup) THEN
777              zqs(i) = qsats(zt(i))/pplay(i,k)
778              zdqs(i) = dqsats(zt(i),zqs(i))
779           ELSE
780              zqs(i) = qsatl(zt(i))/pplay(i,k)
781              zdqs(i) = dqsatl(zt(i),zqs(i))
782           ENDIF
783        ENDDO
784     ENDIF
785     !
786     ! Determiner la condensation partielle et calculer la quantite
787     ! de l'eau condensee:
788     !
[1901]789!verification de la valeur de iflag_fisrtilp_qsat pour iflag_ice_thermo=1
[2086]790!       if ((iflag_ice_thermo.eq.1).and.(iflag_fisrtilp_qsat.ne.0)) then
791!         write(*,*) " iflag_ice_thermo==1 requires iflag_fisrtilp_qsat==0", &
792!        " but iflag_fisrtilp_qsat=",iflag_fisrtilp_qsat, ". Might as well stop here."
793!         stop
794!       endif
[1403]795
[2500]796     ! ----------------------------------------------------------------
797     ! P2> Formation du nuage
798     ! ----------------------------------------------------------------
[2807]799     ! Variables calculees:
800     !   rneb  : fraction nuageuse
801     !   zcond : eau condensee moyenne dans la maille.
802     !   rhcl: humidite relative ciel-clair
803     !   zt : temperature de la maille
804     ! ----------------------------------------------------------------
805     !
[1472]806     IF (cpartiel) THEN
[2807]807        ! -------------------------
808        ! P2.A> Nuage fractionnaire
809        ! -------------------------
[1472]810        !
811        !   Calcul de l'eau condensee et de la fraction nuageuse et de l'eau
812        !   nuageuse a partir des PDF de Sandrine Bony.
813        !   rneb  : fraction nuageuse
814        !   zqn   : eau totale dans le nuage
815        !   zcond : eau condensee moyenne dans la maille.
[3493]816        !  on prend en compte le réchauffement qui diminue la partie
[1472]817        ! condensee
818        !
819        !   Version avec les raqts
[524]820
[2807]821        ! ----------------------------------------------------------------
822        ! P2.A.0> Calcul des grandeurs nuageuses une pdf en creneau
823        ! ----------------------------------------------------------------
[1472]824        if (iflag_pdf.eq.0) then
[524]825
[2500]826           ! version creneau de (Li, 1998)
[524]827           do i=1,klon
[1472]828              zdelq = min(ratqs(i,k),0.99) * zq(i)
829              rneb(i,k) = (zq(i)+zdelq-zqs(i)) / (2.0*zdelq)
830              zqn(i) = (zq(i)+zdelq+zqs(i))/2.0
[524]831           enddo
832
[2807]833        else !  if (iflag_pdf.eq.0)
834           ! ----------------------------------------------------------------
835           ! P2.A.1> Avec les nouvelles PDFs, calcul des grandeurs nuageuses pour
836           ! les valeurs de T et Q initiales
837           ! ----------------------------------------------------------------
[524]838           do i=1,klon
839              if(zq(i).lt.1.e-15) then
[1472]840                 ncoreczq=ncoreczq+1
841                 zq(i)=1.e-15
[524]842              endif
[1472]843           enddo
[1403]844
[2236]845           if (iflag_cld_th>=5) then
[1403]846
[2696]847              if (iflag_cloudth_vert<=2) then
[2686]848               call cloudth(klon,klev,k,ztv, &
[1472]849                   zq,zqta,fraca, &
[3493]850                   qcloud,ctot,zpspsk,paprs,pplay,ztla,zthl, &
[1472]851                   ratqs,zqs,t)
[3493]852              elseif (iflag_cloudth_vert>=3 .and. iflag_cloudth_vert<=5) then
[2686]853               call cloudth_v3(klon,klev,k,ztv, &
854                   zq,zqta,fraca, &
[3493]855                   qcloud,ctot,ctot_vol,zpspsk,paprs,pplay,ztla,zthl, &
[2686]856                   ratqs,zqs,t)
[3493]857              !----------------------------------
858              !Version these Jean Jouhaud, Decembre 2018
859              !----------------------------------             
860              elseif (iflag_cloudth_vert==6) then
861               call cloudth_v6(klon,klev,k,ztv, &
862                   zq,zqta,fraca, &
863                   qcloud,ctot,ctot_vol,zpspsk,paprs,pplay,ztla,zthl, &
864                   ratqs,zqs,t)
865
[2686]866              endif
[1472]867              do i=1,klon
[1403]868                 rneb(i,k)=ctot(i,k)
[2945]869                 rneblsvol(i,k)=ctot_vol(i,k)
[1403]870                 zqn(i)=qcloud(i)
[1472]871              enddo
[1403]872
[1472]873           endif
874
[2236]875           if (iflag_cld_th <= 4) then
[1472]876              lognormale = .true.
[2236]877           elseif (iflag_cld_th >= 6) then
[1472]878              ! lognormale en l'absence des thermiques
879              lognormale = fraca(:,k) < 1e-10
880           else
[3493]881              ! Dans le cas iflag_cld_th=5, on prend systématiquement la
[1472]882              ! bi-gaussienne
883              lognormale = .false.
884           end if
885
[2500]886!CR: variation de qsat avec T en presence de glace ou non
[2086]887!initialisations
[1472]888           do i=1,klon
[2086]889              DT(i) = 0.
890              n_i(i)=0
[1901]891              Tbef(i)=zt(i)
[2086]892              qlbef(i)=0.
893           enddo
894
[2807]895        ! ----------------------------------------------------------------
896        ! P2.A.2> Prise en compte du couplage entre eau condensee et T.
897        ! Calcul des grandeurs nuageuses en tenant compte de l'effet de
898        ! la condensation sur T, et donc sur qsat et sur les grandeurs nuageuses
899        ! qui en dependent. Ce changement de temperature est provisoire, et
900        ! la valeur definitive sera calcule plus tard.
901        ! Variables calculees:
902        !   rneb : nebulosite
903        !   zcond: eau condensee en moyenne dans la maille
904        ! note JLD: si on n'a pas de pdf lognormale, ce qui se passe ne me semble
905        ! pas clair, il n'y a probablement pas de prise en compte de l'effet de
906        ! T sur qsat
907        ! ----------------------------------------------------------------
[2086]908
909!Boucle iterative: ATTENTION, l'option -1 n'est plus activable ici
910           if (iflag_fisrtilp_qsat.ge.0) then
[2500]911             ! Iteration pour condensation avec variation de qsat(T)
912             ! -----------------------------------------------------
[2086]913             do iter=1,iflag_fisrtilp_qsat+1
914               
915               do i=1,klon
916!                 do while ((abs(DT(i)).gt.DDT0).or.(n_i(i).eq.0))
[2807]917                 ! !! convergence = .true. tant que l'on n'a pas converge !!
918                 ! ------------------------------
[2086]919                 convergence(i)=abs(DT(i)).gt.DDT0
920                 if ((convergence(i).or.(n_i(i).eq.0)).and.lognormale(i)) then
[2807]921                 ! si on n'a pas converge
922                 !
923                 ! P2.A.2.1> Calcul de la fraction nuageuse et de la quantite d'eau condensee
924                 ! ---------------------------------------------------------------
925                 ! Variables calculees:
926                 ! rneb : nebulosite
[3875]927                 ! zqn : eau condensee, dans le nuage (in cloud water content)
[2807]928                 ! zcond: eau condensee en moyenne dans la maille
929                 ! rhcl: humidite relative ciel-clair
930                 !
931                 Tbef(i)=Tbef(i)+DT(i) ! nouvelle temperature
[2086]932                 if (.not.ice_thermo) then   
933                    zdelta = MAX(0.,SIGN(1.,RTT-Tbef(i)))
934                 else
935                    if (iflag_t_glace.eq.0) then
936                    zdelta = MAX(0.,SIGN(1.,t_glace_min_old-Tbef(i)))
[2507]937                    else if (iflag_t_glace.ge.1) then
[2703]938                       if (iflag_oldbug_fisrtilp.EQ.0) then
939                          zdelta = MAX(0.,SIGN(1.,t_glace_max-Tbef(i)))
940                       else
[2807]941                          !avec bug : zdelta = MAX(0.,SIGN(1.,t_glace_min-Tbef(i)))
[2703]942                          zdelta = MAX(0.,SIGN(1.,t_glace_min-Tbef(i)))
943                       endif
[2086]944                    endif
945                 endif
[2807]946                 ! Calcul de rneb, qzn et zcond pour les PDF lognormales
[2086]947                 zcvm5 = R5LES*RLVTT*(1.-zdelta) + R5IES*RLSTT*zdelta
[2807]948               if (fl_cor_ebil .GT. 0) then
949                 zcvm5 = zcvm5 /RCPD/(1.0+RVTMP2*(zq(i)+zmqc(i)))
950               else
[2086]951                 zcvm5 = zcvm5 /RCPD/(1.0+RVTMP2*zq(i))
[2807]952               end if
[2086]953                 zqs(i) = R2ES*FOEEW(Tbef(i),zdelta)/pplay(i,k)
954                 zqs(i) = MIN(0.5,zqs(i))
955                 zcor = 1./(1.-RETV*zqs(i))
956                 zqs(i) = zqs(i)*zcor
957                 zdqs(i) = FOEDE(Tbef(i),zdelta,zcvm5,zqs(i),zcor)
[1472]958                 zpdf_sig(i)=ratqs(i,k)*zq(i)
959                 zpdf_k(i)=-sqrt(log(1.+(zpdf_sig(i)/zq(i))**2))
960                 zpdf_delta(i)=log(zq(i)/zqs(i))
961                 zpdf_a(i)=zpdf_delta(i)/(zpdf_k(i)*sqrt(2.))
962                 zpdf_b(i)=zpdf_k(i)/(2.*sqrt(2.))
963                 zpdf_e1(i)=zpdf_a(i)-zpdf_b(i)
964                 zpdf_e1(i)=sign(min(abs(zpdf_e1(i)),5.),zpdf_e1(i))
965                 zpdf_e1(i)=1.-erf(zpdf_e1(i))
966                 zpdf_e2(i)=zpdf_a(i)+zpdf_b(i)
967                 zpdf_e2(i)=sign(min(abs(zpdf_e2(i)),5.),zpdf_e2(i))
968                 zpdf_e2(i)=1.-erf(zpdf_e2(i))
[1901]969             
970                 if (zpdf_e1(i).lt.1.e-10) then
971                    rneb(i,k)=0.
972                    zqn(i)=zqs(i)
973                 else
974                    rneb(i,k)=0.5*zpdf_e1(i)
975                    zqn(i)=zq(i)*zpdf_e2(i)/zpdf_e1(i)
976                 endif
977
[2956]978                 ! If vertical heterogeneity, change fraction by volume as well
979                 if (iflag_cloudth_vert>=3) then
980                   ctot_vol(i,k)=rneb(i,k)
981                   rneblsvol(i,k)=ctot_vol(i,k)
982                 endif
983
[2086]984                 endif !convergence
[2956]985
[2086]986               enddo ! boucle en i
987
[2807]988                 ! P2.A.2.2> Calcul APPROCHE de la variation de temperature DT
989                 !         due a la condensation.
990                 ! ---------------------------------------------------------------
991                 ! Variables calculees:
992                 ! DT : variation de temperature due a la condensation
993
[2086]994                 if (.not. ice_thermo) then
[2807]995                 ! --------------------------
[2086]996                 do i=1,klon
997                 if ((convergence(i).or.(n_i(i).eq.0)).and.lognormale(i)) then
998
[1901]999                 qlbef(i)=max(0.,zqn(i)-zqs(i))
[2807]1000               if (fl_cor_ebil .GT. 0) then
1001                 num=-Tbef(i)+zt(i)+rneb(i,k)*RLVTT/RCPD/(1.0+RVTMP2*(zq(i)+zmqc(i)))*qlbef(i)
1002               else
[1901]1003                 num=-Tbef(i)+zt(i)+rneb(i,k)*RLVTT/RCPD/(1.0+RVTMP2*zq(i))*qlbef(i)
[2807]1004               end if
[1901]1005                 denom=1.+rneb(i,k)*zdqs(i)
1006                 DT(i)=num/denom
[2086]1007                 n_i(i)=n_i(i)+1
1008                 endif
1009                 enddo
[1403]1010
[2807]1011                 else ! if (.not. ice_thermo)
1012                 ! --------------------------
[2507]1013                 if (iflag_t_glace.ge.1) then
[2109]1014                 CALL icefrac_lsc(klon,zt(:),pplay(:,k)/paprs(:,1),zfice(:))
[1472]1015                 endif
[1411]1016
[2086]1017                 do i=1,klon
1018                 if ((convergence(i).or.(n_i(i).eq.0)).and.lognormale(i)) then
1019                 
1020                 if (iflag_t_glace.eq.0) then
1021                    zfice(i) = 1.0 - (Tbef(i)-t_glace_min_old) / (RTT-t_glace_min_old)
1022                    zfice(i) = MIN(MAX(zfice(i),0.0),1.0)
1023                    zfice(i) = zfice(i)**exposant_glace_old
[2807]1024                    dzfice(i)= exposant_glace_old * zfice(i)**(exposant_glace_old-1) &
1025          &                     / (t_glace_min_old - RTT)
[1901]1026                 endif
[2086]1027                 
[2969]1028                 if (iflag_t_glace.ge.1.and.zfice(i)>0.) then
[2807]1029                 dzfice(i)= exposant_glace * zfice(i)**(exposant_glace-1) &
1030          &                    / (t_glace_min - t_glace_max)
[2086]1031                 endif
1032               
1033                 if ((zfice(i).eq.0).or.(zfice(i).eq.1)) then
1034                    dzfice(i)=0.
1035                 endif
[1411]1036
[2086]1037                 if (zfice(i).lt.1) then
1038                    cste=RLVTT
1039                 else
1040                    cste=RLSTT
1041                 endif
1042
1043                 qlbef(i)=max(0.,zqn(i)-zqs(i))
[2807]1044               if (fl_cor_ebil .GT. 0) then
1045                 num = -Tbef(i)+zt(i)+rneb(i,k)*((1-zfice(i))*RLVTT &
1046           &          +zfice(i)*RLSTT)/RCPD/(1.0+RVTMP2*(zq(i)+zmqc(i)))*qlbef(i)
1047                 denom = 1.+rneb(i,k)*((1-zfice(i))*RLVTT+zfice(i)*RLSTT)/cste*zdqs(i) &
1048                         -(RLSTT-RLVTT)/RCPD/(1.0+RVTMP2*(zq(i)+zmqc(i)))*rneb(i,k)    &
1049           &               *qlbef(i)*dzfice(i)
1050               else
1051                 num = -Tbef(i)+zt(i)+rneb(i,k)*((1-zfice(i))*RLVTT &
1052           &         +zfice(i)*RLSTT)/RCPD/(1.0+RVTMP2*zq(i))*qlbef(i)
1053                 denom = 1.+rneb(i,k)*((1-zfice(i))*RLVTT+zfice(i)*RLSTT)/cste*zdqs(i) &
[2086]1054                         -(RLSTT-RLVTT)/RCPD/(1.0+RVTMP2*zq(i))*rneb(i,k)*qlbef(i)*dzfice(i)
[2807]1055               end if
[2086]1056                 DT(i)=num/denom
1057                 n_i(i)=n_i(i)+1
1058
1059                 endif ! fin convergence
1060                 enddo ! fin boucle i
1061
1062                 endif !ice_thermo
1063
[2500]1064             enddo ! iter=1,iflag_fisrtilp_qsat+1
1065             ! Fin d'iteration pour condensation avec variation de qsat(T)
1066             ! -----------------------------------------------------------
[2807]1067           endif !  if (iflag_fisrtilp_qsat.ge.0)
1068     ! ----------------------------------------------------------------
1069     ! Fin de P2.A.2> la prise en compte du couplage entre eau condensee et T
1070     ! ----------------------------------------------------------------
[524]1071
1072        endif ! iflag_pdf
1073
[2086]1074!        if (iflag_fisrtilp_qsat.eq.-1) then
[2500]1075!------------------------------------------
1076!CR: ATTENTION option fausse mais a existe:
1077! pour la re-activer, prendre iflag_fisrtilp_qsat=0 et
1078! activer les lignes suivantes:
[2086]1079       IF (1.eq.0) THEN
1080       DO i=1,klon
[1146]1081           IF (rneb(i,k) .LE. 0.0) THEN
1082              zqn(i) = 0.0
1083              rneb(i,k) = 0.0
1084              zcond(i) = 0.0
1085              rhcl(i,k)=zq(i)/zqs(i)
1086           ELSE IF (rneb(i,k) .GE. 1.0) THEN
1087              zqn(i) = zq(i)
[1901]1088              rneb(i,k) = 1.0                 
1089              zcond(i) = MAX(0.0,zqn(i)-zqs(i))/(1+zdqs(i))
[1146]1090              rhcl(i,k)=1.0
1091           ELSE
[1901]1092              zcond(i) = MAX(0.0,zqn(i)-zqs(i))*rneb(i,k)/(1+zdqs(i))
[1146]1093              rhcl(i,k)=(zqs(i)+zq(i)-zdelq)/2./zqs(i)
1094           ENDIF
[2500]1095       ENDDO
1096       ENDIF
1097!------------------------------------------
[1901]1098
[2086]1099!        ELSE
[2807]1100        ! ----------------------------------------------------------------
1101        ! P2.A.3> Calcul des valeures finales associees a la formation des nuages
1102        ! Variables calculees:
1103        !   rneb : nebulosite
1104        !   zcond: eau condensee en moyenne dans la maille
1105        !   zq : eau vapeur dans la maille
1106        !   zt : temperature de la maille
1107        !   rhcl: humidite relative ciel-clair
1108        ! ----------------------------------------------------------------
1109        !
1110        ! Bornage de l'eau in-cloud (zqn) et de la fraction nuageuse (rneb)
1111        ! Calcule de l'eau condensee moyenne dans la maille (zcond),
1112        ! et de l'humidite relative ciel-clair (rhcl)
[1901]1113        DO i=1,klon
1114           IF (rneb(i,k) .LE. 0.0) THEN
1115              zqn(i) = 0.0
1116              rneb(i,k) = 0.0
1117              zcond(i) = 0.0
1118              rhcl(i,k)=zq(i)/zqs(i)
1119           ELSE IF (rneb(i,k) .GE. 1.0) THEN
1120              zqn(i) = zq(i)
1121              rneb(i,k) = 1.0
1122              zcond(i) = MAX(0.0,zqn(i)-zqs(i))
1123              rhcl(i,k)=1.0
1124           ELSE
1125              zcond(i) = MAX(0.0,zqn(i)-zqs(i))*rneb(i,k)
1126              rhcl(i,k)=(zqs(i)+zq(i)-zdelq)/2./zqs(i)
1127           ENDIF
1128        ENDDO
[3875]1129
1130       
[2956]1131        ! If vertical heterogeneity, change fraction by volume as well
1132        if (iflag_cloudth_vert>=3) then
1133          ctot_vol(1:klon,k)=min(max(ctot_vol(1:klon,k),0.),1.)
1134          rneblsvol(1:klon,k)=ctot_vol(1:klon,k)
1135        endif
[1901]1136
[2086]1137!        ENDIF
[1901]1138
[2500]1139     ELSE ! de IF (cpartiel)
[2807]1140        ! -------------------------
1141        ! P2.B> Nuage "tout ou rien"
1142        ! -------------------------
1143        ! note JLD: attention, rhcl non calcule. Ca peut avoir des consequences?
[1472]1144        DO i = 1, klon
1145           IF (zq(i).GT.zqs(i)) THEN
1146              rneb(i,k) = 1.0
1147           ELSE
1148              rneb(i,k) = 0.0
1149           ENDIF
1150           zcond(i) = MAX(0.0,zq(i)-zqs(i))/(1.+zdqs(i))
1151        ENDDO
[2807]1152     ENDIF ! de IF (cpartiel)
[1472]1153     !
[2500]1154     ! Mise a jour vapeur d'eau
[2807]1155     ! -------------------------
[1472]1156     DO i = 1, klon
1157        zq(i) = zq(i) - zcond(i)
1158        !         zt(i) = zt(i) + zcond(i) * RLVTT/RCPD
1159     ENDDO
[1849]1160!AJ<
[2807]1161     ! ------------------------------------
1162     ! P2.C> Prise en compte de la Chaleur latente apres formation nuage
[2500]1163     ! -------------------------------------
[2807]1164     ! Variable calcule:
1165     !   zt : temperature de la maille
1166     !
[1849]1167     IF (.NOT. ice_thermo) THEN
[1901]1168        if (iflag_fisrtilp_qsat.lt.1) then
1169           DO i = 1, klon
1170             zt(i) = zt(i) + zcond(i) * RLVTT/RCPD/(1.0+RVTMP2*zq(i))
1171           ENDDO
1172        else if (iflag_fisrtilp_qsat.gt.0) then
1173           DO i= 1, klon
[2807]1174    if (fl_cor_ebil .GT. 0) then
1175             zt(i) = zt(i) + zcond(i) * RLVTT/RCPD/(1.0+RVTMP2*(zq(i)+zmqc(i)+zcond(i)))
1176    else
[1901]1177             zt(i) = zt(i) + zcond(i) * RLVTT/RCPD/(1.0+RVTMP2*(zq(i)+zcond(i)))
[2807]1178    end if
[1901]1179           ENDDO
1180        endif
[1849]1181     ELSE
[2507]1182         if (iflag_t_glace.ge.1) then
[2109]1183            CALL icefrac_lsc(klon,zt(:),pplay(:,k)/paprs(:,1),zfice(:))
[1901]1184         endif
[2006]1185         if (iflag_fisrtilp_qsat.lt.1) then
1186           DO i = 1, klon
[2109]1187! JBM: icefrac_lsc is now a function contained in icefrac_lsc_mod
[2086]1188!              zfice(i) = icefrac_lsc(zt(i), t_glace_min, &
1189!                                     t_glace_max, exposant_glace)
1190              if (iflag_t_glace.eq.0) then
[2223]1191                    zfice(i) = 1.0 - (zt(i)-t_glace_min_old) / (RTT-t_glace_min_old)
[2086]1192                    zfice(i) = MIN(MAX(zfice(i),0.0),1.0)
1193                    zfice(i) = zfice(i)**exposant_glace_old
1194              endif
[2006]1195              zt(i) = zt(i) + (1.-zfice(i))*zcond(i) * RLVTT/RCPD/(1.0+RVTMP2*zq(i)) &
1196                       +zfice(i)*zcond(i) * RLSTT/RCPD/(1.0+RVTMP2*zq(i))
1197           ENDDO
1198         else
1199           DO i=1, klon
[2109]1200! JBM: icefrac_lsc is now a function contained in icefrac_lsc_mod
[2086]1201!              zfice(i) = icefrac_lsc(zt(i), t_glace_min, &
1202!                                     t_glace_max, exposant_glace)
1203              if (iflag_t_glace.eq.0) then
[2223]1204                    zfice(i) = 1.0 - (zt(i)-t_glace_min_old) / (RTT-t_glace_min_old)
[2086]1205                    zfice(i) = MIN(MAX(zfice(i),0.0),1.0)
1206                    zfice(i) = zfice(i)**exposant_glace_old
1207              endif
[2807]1208        if (fl_cor_ebil .GT. 0) then
1209              zt(i) = zt(i) + (1.-zfice(i))*zcond(i) &
1210           &             * RLVTT/RCPD/(1.0+RVTMP2*(zq(i)+zmqc(i)+zcond(i))) &
1211                      +zfice(i)*zcond(i) * RLSTT/RCPD/(1.0+RVTMP2*(zq(i)+zmqc(i)+zcond(i)))
1212        else
[2006]1213              zt(i) = zt(i) + (1.-zfice(i))*zcond(i) * RLVTT/RCPD/(1.0+RVTMP2*(zq(i)+zcond(i))) &
[2807]1214                      +zfice(i)*zcond(i) * RLSTT/RCPD/(1.0+RVTMP2*(zq(i)+zcond(i)))
1215        end if
[2006]1216           ENDDO
1217         endif
1218!         print*,zt(i),zrfl(i),zifl(i),'temp1'
1219       ENDIF
[1849]1220!>AJ
[2807]1221
[2500]1222     ! ----------------------------------------------------------------
1223     ! P3> Formation des precipitations
1224     ! ----------------------------------------------------------------
[1472]1225     !
1226     ! Partager l'eau condensee en precipitation et eau liquide nuageuse
1227     !
[2500]1228
[3875]1229!<LTP
1230
1231IF (iflag_evap_prec==4) THEN
1232        !Partitionnement des precipitations venant du dessus en précipitations nuageuses
1233        !et précipitations ciel clair
1234
1235        !0) Calculate tot_zneb, la fraction nuageuse totale au-dessus du nuage
1236        !en supposant un recouvrement maximum aléatoire (voir Jakob and Klein, 2000)
1237       
1238        DO i=1, klon
1239                tot_znebn(i) = 1 - (1-tot_zneb(i))*(1 - max(rneb(i,k),zneb(i))) &
1240                        /(1-min(zneb(i),1-smallestreal))
1241                d_tot_zneb(i) = tot_znebn(i) - tot_zneb(i)
1242                tot_zneb(i) = tot_znebn(i)
1243
1244
1245                !1) Cloudy to clear air
1246                d_znebprecip_cld_clr(i) = znebprecipcld(i) - min(rneb(i,k),znebprecipcld(i))
1247                IF (znebprecipcld(i) .GT. 0) THEN
1248                        d_zrfl_cld_clr(i) = d_znebprecip_cld_clr(i)/znebprecipcld(i)*zrflcld(i)
1249                        d_zifl_cld_clr(i) = d_znebprecip_cld_clr(i)/znebprecipcld(i)*ziflcld(i)
1250                ELSE
1251                        d_zrfl_cld_clr(i) = 0.
1252                        d_zifl_cld_clr(i) = 0.
1253                ENDIF
1254
1255                !2) Clear to cloudy air
1256                d_znebprecip_clr_cld(i) = max(0., min(znebprecipclr(i), rneb(i,k) &
1257                        - d_tot_zneb(i) - zneb(i)))
1258                IF (znebprecipclr(i) .GT. 0) THEN
1259                        d_zrfl_clr_cld(i) = d_znebprecip_clr_cld(i)/znebprecipclr(i)*zrflclr(i)
1260                        d_zifl_clr_cld(i) = d_znebprecip_clr_cld(i)/znebprecipclr(i)*ziflclr(i)
1261                ELSE
1262                        d_zrfl_clr_cld(i) = 0.
1263                        d_zifl_clr_cld(i) = 0.
1264                ENDIF
1265
1266                !Update variables
1267                znebprecipcld(i) = znebprecipcld(i) + d_znebprecip_clr_cld(i) - d_znebprecip_cld_clr(i) 
1268                znebprecipclr(i) = znebprecipclr(i) + d_znebprecip_cld_clr(i) - d_znebprecip_clr_cld(i)
1269                zrflcld(i) = zrflcld(i) + d_zrfl_clr_cld(i) - d_zrfl_cld_clr(i)
1270                ziflcld(i) = ziflcld(i) + d_zifl_clr_cld(i) - d_zifl_cld_clr(i)
1271                zrflclr(i) = zrflclr(i) + d_zrfl_cld_clr(i) - d_zrfl_clr_cld(i)
1272                ziflclr(i) = ziflclr(i) + d_zifl_cld_clr(i) - d_zifl_clr_cld(i)
1273
1274        ENDDO
1275ENDIF
1276
1277!>LTP
1278
1279
1280
[2500]1281     ! Initialisation de zoliq (eau condensee moyenne dans la maille)
[1472]1282     DO i = 1, klon
1283        IF (rneb(i,k).GT.0.0) THEN
1284           zoliq(i) = zcond(i)
1285           zrho(i) = pplay(i,k) / zt(i) / RD
1286           zdz(i) = (paprs(i,k)-paprs(i,k+1)) / (zrho(i)*RG)
[1849]1287        ENDIF
1288     ENDDO
1289!AJ<
1290     IF (.NOT. ice_thermo) THEN
[2006]1291       IF (iflag_t_glace.EQ.0) THEN
1292         DO i = 1, klon
1293            IF (rneb(i,k).GT.0.0) THEN
1294               zfice(i) = 1.0 - (zt(i)-t_glace_min_old) / (273.13-t_glace_min_old)
1295               zfice(i) = MIN(MAX(zfice(i),0.0),1.0)
1296               zfice(i) = zfice(i)**exposant_glace_old
1297!              zfice(i) = zfice(i)**nexpo
1298         !!      zfice(i)=0.
1299            ENDIF
1300         ENDDO
1301       ELSE ! of IF (iflag_t_glace.EQ.0)
[2109]1302         CALL icefrac_lsc(klon,zt(:),pplay(:,k)/paprs(:,1),zfice(:))
[2086]1303!         DO i = 1, klon
1304!            IF (rneb(i,k).GT.0.0) THEN
[2109]1305! JBM: icefrac_lsc is now a function contained in icefrac_lsc_mod
[2086]1306!              zfice(i) = icefrac_lsc(zt(i), t_glace_min, &
1307!                                     t_glace_max, exposant_glace)
1308!            ENDIF
1309!         ENDDO
[2006]1310       ENDIF
[1849]1311     ENDIF
[2500]1312
1313     ! Calcul de radliq (eau condensee pour le rayonnement)
1314     ! Iteration pour realiser une moyenne de l'eau nuageuse lors de la precip
1315     ! Remarque: ce n'est donc pas l'eau restante en fin de precip mais une
1316     ! eau moyenne restante dans le nuage sur la duree du pas de temps qui est
1317     ! transmise au rayonnement;
1318     ! ----------------------------------------------------------------
[1849]1319     DO i = 1, klon
1320        IF (rneb(i,k).GT.0.0) THEN
[1472]1321           zneb(i) = MAX(rneb(i,k), seuil_neb)
[1849]1322     !      zt(i) = zt(i)+zcond(i)*zfice(i)*RLMLT/RCPD/(1.0+RVTMP2*zq(i)) 
1323!           print*,zt(i),'fractionglace'
1324!>AJ
[1472]1325           radliq(i,k) = zoliq(i)/REAL(ninter+1)
1326        ENDIF
1327     ENDDO
1328     !
1329     DO n = 1, ninter
1330        DO i = 1, klon
1331           IF (rneb(i,k).GT.0.0) THEN
1332              zrhol(i) = zrho(i) * zoliq(i) / zneb(i)
[1855]1333              ! Initialization of zpluie and zice:
1334              zpluie=0
1335              zice=0
[1472]1336              IF (zneb(i).EQ.seuil_neb) THEN
1337                 ztot = 0.0
1338              ELSE
[2500]1339                 !  quantite d'eau a eliminer: zchau (Sundqvist, 1978)
1340                 !  meme chose pour la glace: zfroi (Zender & Kiehl, 1997)
[1472]1341                 if (ptconv(i,k)) then
1342                    zcl   =cld_lc_con
1343                    zct   =1./cld_tau_con
1344                    zfroi    = dtime/REAL(ninter)/zdz(i)*zoliq(i) &
1345                         *fallvc(zrhol(i)) * zfice(i)
1346                 else
1347                    zcl   =cld_lc_lsc
1348                    zct   =1./cld_tau_lsc
1349                    zfroi    = dtime/REAL(ninter)/zdz(i)*zoliq(i) &
1350                         *fallvs(zrhol(i)) * zfice(i)
1351                 endif
[2945]1352
1353                 ! si l'heterogeneite verticale est active, on utilise
1354                 ! la fraction volumique "vraie" plutot que la fraction
1355                 ! surfacique modifiee, qui est plus grande et reduit
1356                 ! sinon l'eau in-cloud de facon artificielle
1357                 if ((iflag_cloudth_vert>=3).AND.(iflag_rain_incloud_vol==1)) then
1358                    zchau    = zct   *dtime/REAL(ninter) * zoliq(i) &
1359                         *(1.0-EXP(-(zoliq(i)/ctot_vol(i,k)/zcl   )**2)) *(1.-zfice(i))
1360                 else
1361                    zchau    = zct   *dtime/REAL(ninter) * zoliq(i) &
1362                         *(1.0-EXP(-(zoliq(i)/zneb(i)/zcl   )**2)) *(1.-zfice(i))
1363                 endif
[1849]1364!AJ<
1365                 IF (.NOT. ice_thermo) THEN
1366                   ztot    = zchau + zfroi
1367                 ELSE
1368                   zpluie = MIN(MAX(zchau,0.0),zoliq(i)*(1.-zfice(i)))
1369                   zice = MIN(MAX(zfroi,0.0),zoliq(i)*zfice(i))
1370                   ztot    = zpluie    + zice
1371                 ENDIF
1372!>AJ
[1472]1373                 ztot    = MAX(ztot   ,0.0)
1374              ENDIF
1375              ztot    = MIN(ztot,zoliq(i))
[1849]1376!AJ<
1377     !         zoliqp = MAX(zoliq(i)*(1.-zfice(i))-1.*zpluie   , 0.0)
1378     !         zoliqi = MAX(zoliq(i)*zfice(i)-1.*zice   , 0.0)
[2807]1379!JLD : les 2 variables zoliqp et zoliqi crorresponent a des pseudo precip
1380!      temporaires et ne doivent pas etre calcule (alors qu'elles le sont
1381!      si iflag_bergeron <> 2
1382!      A SUPPRIMER A TERME
[1849]1383              zoliqp(i) = MAX(zoliq(i)*(1.-zfice(i))-1.*zpluie  , 0.0)
1384              zoliqi(i) = MAX(zoliq(i)*zfice(i)-1.*zice  , 0.0)
[1472]1385              zoliq(i) = MAX(zoliq(i)-ztot   , 0.0)
[1849]1386!>AJ
[1472]1387              radliq(i,k) = radliq(i,k) + zoliq(i)/REAL(ninter+1)
1388           ENDIF
[2466]1389        ENDDO  ! i = 1,klon
1390     ENDDO     ! n = 1,ninter
[2807]1391
[2500]1392     ! ----------------------------------------------------------------
[1472]1393     !
[2466]1394     IF (.NOT. ice_thermo) THEN
[1849]1395       DO i = 1, klon
1396         IF (rneb(i,k).GT.0.0) THEN
[1472]1397           d_ql(i,k) = zoliq(i)
1398           zrfl(i) = zrfl(i)+ MAX(zcond(i)-zoliq(i),0.0) &
1399                * (paprs(i,k)-paprs(i,k+1))/(RG*dtime)
[1849]1400         ENDIF
1401       ENDDO
1402     ELSE
[2466]1403!
1404!CR&JYG<
1405! On prend en compte l'effet Bergeron dans les flux de precipitation :
1406! Si T < 0 C, alors les precipitations liquides sont converties en glace, ce qui
1407! provoque un accroissement de temperature DeltaT. L'effet de DeltaT sur le condensat
1408! et les precipitations est grossierement pris en compte en linearisant les equations
1409! et en approximant le processus de precipitation liquide par un processus a seuil.
[3493]1410! On fait l'hypothese que le condensat nuageux n'est pas modifié dans cette opération.
[2466]1411! Le condensat precipitant liquide est supprime (dans la limite DeltaT<273-T).
1412! Le condensat precipitant solide est augmente.
1413! La vapeur d'eau est augmentee.
1414!
1415       IF ((iflag_bergeron .EQ. 2)) THEN
1416         DO i = 1, klon
1417           IF (rneb(i,k) .GT. 0.0) THEN
1418             zqpreci(i)=(zcond(i)-zoliq(i))*zfice(i)
1419             zqprecl(i)=(zcond(i)-zoliq(i))*(1.-zfice(i))
[2807]1420           if (fl_cor_ebil .GT. 0) then
1421             zcp=RCPD*(1.0+RVTMP2*(zq(i)+zmqc(i)+zcond(i)))
1422             coef1 = rneb(i,k)*RLSTT/zcp*zdqsdT_raw(i)
1423!            Calcul de DT si toute les precips liquides congelent
1424             DeltaT = RLMLT*zqprecl(i) / (zcp*(1.+coef1))
1425!            On ne veut pas que T devienne superieur a la temp. de congelation.
1426!            donc que Delta > RTT-zt(i
1427             DeltaT = max( min( RTT-zt(i), DeltaT) , 0. )
1428             zt(i)      = zt(i)      + DeltaT
1429!            Eau vaporisee du fait de l'augmentation de T
1430             Deltaq = rneb(i,k)*zdqsdT_raw(i)*DeltaT
1431!            on reajoute cette eau vaporise a la vapeur et on l'enleve des precips
1432             zq(i) = zq(i) +  Deltaq
1433!            Les 3 max si dessous prtotegent uniquement des erreurs d'arrondies
1434             zcond(i)   = max( zcond(i)- Deltaq, 0. )
1435!            precip liquide qui congele ou qui s'evapore
1436             Deltaqprecl = -zcp/RLMLT*(1.+coef1)*DeltaT
1437             zqprecl(i) = max( zqprecl(i) + Deltaqprecl, 0. )
1438!            bilan eau glacee
1439             zqpreci(i) = max (zqpreci(i) - Deltaqprecl - Deltaq, 0.)
1440           else ! if (fl_cor_ebil .GT. 0)
1441!            ancien calcul
[2466]1442             zcp=RCPD*(1.0+RVTMP2*(zq(i)+zcond(i)))
1443             coef1 = RLMLT*zdqs(i)/RLVTT
1444             DeltaT = max( min( RTT-zt(i), RLMLT*zqprecl(i)/zcp/(1.+coef1) ) , 0.)
1445             zqpreci(i) = zqpreci(i) + zcp/RLMLT*DeltaT
1446             zqprecl(i) = max( zqprecl(i) - zcp/RLMLT*(1.+coef1)*DeltaT, 0. )
1447             zcond(i)   = max( zcond(i)   - zcp/RLVTT*zdqs(i)*DeltaT, 0. )
1448             zq(i)      = zq(i)      + zcp/RLVTT*zdqs(i)*DeltaT
1449             zt(i)      = zt(i)      + DeltaT
[2807]1450           end if ! if (fl_cor_ebil .GT. 0)
[2466]1451           ENDIF  ! rneb(i,k) .GT. 0.0
1452         ENDDO
1453         DO i = 1, klon
1454           IF (rneb(i,k).GT.0.0) THEN
1455             d_ql(i,k) = (1-zfice(i))*zoliq(i)
1456             d_qi(i,k) = zfice(i)*zoliq(i)
[3875]1457!<LTP
1458             IF (iflag_evap_prec == 4) THEN
1459                zrflcld(i) = zrflcld(i)+zqprecl(i) &
1460                 *(paprs(i,k)-paprs(i,k+1))/(RG*dtime)
1461                ziflcld(i) = ziflcld(i)+ zqpreci(i) &
1462                      *(paprs(i,k)-paprs(i,k+1))/(RG*dtime)
1463                znebprecipcld(i) = rneb(i,k)
1464                zrfl(i) = zrflcld(i) + zrflclr(i)
1465                zifl(i) = ziflcld(i) + ziflclr(i)       
1466!>LTP
1467             ELSE
1468                zrfl(i) = zrfl(i)+ zqprecl(i) &
[2466]1469                 *(paprs(i,k)-paprs(i,k+1))/(RG*dtime)
[3875]1470                zifl(i) = zifl(i)+ zqpreci(i) &
[2466]1471                      *(paprs(i,k)-paprs(i,k+1))/(RG*dtime) 
[3875]1472             
1473             ENDIF !iflag_evap_prec==4
1474
[2466]1475           ENDIF                     
1476         ENDDO
1477!!
1478       ELSE  ! iflag_bergeron
1479!>CR&JYG
1480!!
[1849]1481       DO i = 1, klon
1482         IF (rneb(i,k).GT.0.0) THEN
[2086]1483!CR on prend en compte la phase glace
[2807]1484!JLD inutile car on ne passe jamais ici si .not.ice_thermo
1485!           if (.not.ice_thermo) then
1486!           d_ql(i,k) = zoliq(i)
1487!           d_qi(i,k) = 0.
1488!           else
[2086]1489           d_ql(i,k) = (1-zfice(i))*zoliq(i)
1490           d_qi(i,k) = zfice(i)*zoliq(i)
[2807]1491!           endif
[3875]1492!<LTP
1493             IF (iflag_evap_prec == 4) THEN
1494                zrflcld(i) = zrflcld(i)+ MAX(zcond(i)*(1.-zfice(i))-zoliqp(i),0.0) &
1495                       *(paprs(i,k)-paprs(i,k+1))/(RG*dtime)
1496                ziflcld(i) = ziflcld(i)+ MAX(zcond(i)*zfice(i)-zoliqi(i),0.0) &
1497                        *(paprs(i,k)-paprs(i,k+1))/(RG*dtime) 
1498                znebprecipcld(i) = rneb(i,k)
1499                zrfl(i) = zrflcld(i) + zrflclr(i)
1500                zifl(i) = ziflcld(i) + ziflclr(i)       
1501!>LTP
1502             ELSE
[1849]1503!AJ<
[3875]1504                   zrfl(i) = zrfl(i)+ MAX(zcond(i)*(1.-zfice(i))-zoliqp(i),0.0) &
1505                       *(paprs(i,k)-paprs(i,k+1))/(RG*dtime)
1506                        zifl(i) = zifl(i)+ MAX(zcond(i)*zfice(i)-zoliqi(i),0.0) &
1507                        *(paprs(i,k)-paprs(i,k+1))/(RG*dtime) 
[1849]1508     !      zrfl(i) = zrfl(i)+  zpluie                         &
1509     !          *(paprs(i,k)-paprs(i,k+1))/(RG*dtime)
1510     !      zifl(i) = zifl(i)+  zice                    &
1511     !               *(paprs(i,k)-paprs(i,k+1))/(RG*dtime)                                   
[3875]1512             ENDIF !iflag_evap_prec == 4             
[1849]1513
[2415]1514!CR : on prend en compte l'effet Bergeron dans les flux de precipitation
[2466]1515           IF ((iflag_bergeron .EQ. 1) .AND. (zt(i) .LT. 273.15)) THEN
[3875]1516!<LTP
1517                IF (iflag_evap_prec == 4) THEN
1518                     zsolid = zrfl(i)
1519                     ziflclr(i) = ziflclr(i) +zrflclr(i)
1520                     ziflcld(i) = ziflcld(i) +zrflcld(i)
1521                     zifl(i) = ziflclr(i)+ziflcld(i)
1522                     zrflcld(i)=0.
1523                     zrflclr(i)=0.   
1524                     zrfl(i) = zrflclr(i)+zrflcld(i)
1525!>LTP
1526                ELSE
1527                     zsolid = zrfl(i)
1528                     zifl(i) = zifl(i)+zrfl(i)
1529                     zrfl(i) = 0.
1530                 ENDIF!iflag_evap_prec==4
1531
[2807]1532           if (fl_cor_ebil .GT. 0) then
[2415]1533              zt(i)=zt(i)+zsolid*(RG*dtime)/(paprs(i,k)-paprs(i,k+1)) &
[2807]1534                      *(RLSTT-RLVTT)/RCPD/(1.0+RVTMP2*(zq(i)+zmqc(i)))
1535           else
1536              zt(i)=zt(i)+zsolid*(RG*dtime)/(paprs(i,k)-paprs(i,k+1)) &
[2415]1537                      *(RLSTT-RLVTT)/RCPD/(1.0+RVTMP2*zq(i))
[2807]1538           end if
[2466]1539           ENDIF  ! (iflag_bergeron .EQ. 1) .AND. (zt(i) .LT. 273.15)
[2415]1540!RC   
1541
[2466]1542         ENDIF ! rneb(i,k).GT.0.0
[1849]1543       ENDDO
1544
[2466]1545       ENDIF  ! iflag_bergeron .EQ. 2
1546     ENDIF  ! .NOT. ice_thermo
1547
[2086]1548!CR: la fonte est faite au debut
1549!      IF (ice_thermo) THEN
1550!       DO i = 1, klon
1551!           zmelt = ((zt(i)-273.15)/(ztfondue-273.15))**2
1552!           zmelt = MIN(MAX(zmelt,0.),1.)
1553!           zrfl(i)=zrfl(i)+zmelt*zifl(i)
1554!           zifl(i)=zifl(i)*(1.-zmelt)
[1849]1555!           print*,zt(i),'octavio1'
[2086]1556!           zt(i)=zt(i)-zifl(i)*zmelt*(RG*dtime)/(paprs(i,k)-paprs(i,k+1)) &
1557!                      *RLMLT/RCPD/(1.0+RVTMP2*zq(i))
[1849]1558!           print*,zt(i),zrfl(i),zifl(i),zmelt,'octavio2'
[2086]1559!       ENDDO
1560!     ENDIF
[1849]1561
[3875]1562
1563!<LTP
1564
1565!Limitation de la fraction surfacique couverte par les précipitations lorsque l'intensité locale du flux de précipitation descend en
1566!dessous de rain_int_min
1567    IF (iflag_evap_prec==4) THEN
1568        DO i=1, klon
1569            IF (zrflclr(i) + ziflclr(i) .GT. 0 ) THEN
[4260]1570               znebprecipclr(i) = min(znebprecipclr(i), max(zrflclr(i) &
1571                    /(znebprecipclr(i)*rain_int_min), &
1572                    ziflclr(i)/(znebprecipclr(i)*rain_int_min)))
[3875]1573            ELSE
1574                znebprecipclr(i)=0.
1575            ENDIF
1576
1577            IF (zrflcld(i) + ziflcld(i) .GT. 0 ) THEN
[4260]1578               znebprecipcld(i) = min(znebprecipcld(i), &
1579                    max(zrflcld(i)/(znebprecipcld(i)*rain_int_min), &
1580                    ziflcld(i)/(znebprecipcld(i)*rain_int_min)))
[3875]1581            ELSE
1582                znebprecipcld(i)=0.
1583            ENDIF
1584       ENDDO
1585    ENDIf
1586
1587!>LTP
1588
1589
1590
1591
[1849]1592       
1593     IF (.NOT. ice_thermo) THEN
1594       DO i = 1, klon
1595         IF (zt(i).LT.RTT) THEN
[1472]1596           psfl(i,k)=zrfl(i)
[1849]1597         ELSE
[1472]1598           prfl(i,k)=zrfl(i)
[1849]1599         ENDIF
1600       ENDDO
1601     ELSE
1602     ! JAM*************************************************
[2500]1603     ! Revoir partie ci-dessous: a quoi servent psfl et prfl?
[1849]1604     ! *****************************************************
1605
1606       DO i = 1, klon
1607     !   IF (zt(i).LT.RTT) THEN
1608           psfl(i,k)=zifl(i)
1609     !   ELSE
1610           prfl(i,k)=zrfl(i)
1611     !   ENDIF
1612!>AJ
1613       ENDDO
1614     ENDIF
[2500]1615     ! ----------------------------------------------------------------
1616     ! Fin de formation des precipitations
1617     ! ----------------------------------------------------------------
[1472]1618     !
1619     ! Calculer les tendances de q et de t:
1620     !
1621     DO i = 1, klon
1622        d_q(i,k) = zq(i) - q(i,k)
1623        d_t(i,k) = zt(i) - t(i,k)
1624     ENDDO
1625     !
1626     !AA--------------- Calcul du lessivage stratiforme  -------------
[524]1627
[1472]1628     DO i = 1,klon
1629        !
[1742]1630        if(zcond(i).gt.zoliq(i)+1.e-10) then
1631         beta(i,k) = (zcond(i)-zoliq(i))/zcond(i)/dtime
1632        else
1633         beta(i,k) = 0.
1634        endif
[1472]1635        zprec_cond(i) = MAX(zcond(i)-zoliq(i),0.0) &
1636             * (paprs(i,k)-paprs(i,k+1))/RG
1637        IF (rneb(i,k).GT.0.0.and.zprec_cond(i).gt.0.) THEN
1638           !AA lessivage nucleation LMD5 dans la couche elle-meme
[2006]1639          IF (iflag_t_glace.EQ.0) THEN
1640           if (t(i,k) .GE. t_glace_min_old) THEN
[1472]1641              zalpha_tr = a_tr_sca(3)
1642           else
1643              zalpha_tr = a_tr_sca(4)
1644           endif
[2006]1645          ELSE ! of IF (iflag_t_glace.EQ.0)
1646           if (t(i,k) .GE. t_glace_min) THEN
1647              zalpha_tr = a_tr_sca(3)
1648           else
1649              zalpha_tr = a_tr_sca(4)
1650           endif
1651          ENDIF
[1472]1652           zfrac_lessi = 1. - EXP(zalpha_tr*zprec_cond(i)/zneb(i))
1653           pfrac_nucl(i,k)=pfrac_nucl(i,k)*(1.-zneb(i)*zfrac_lessi)
1654           frac_nucl(i,k)= 1.-zneb(i)*zfrac_lessi
1655           !
1656           ! nucleation avec un facteur -1 au lieu de -0.5
1657           zfrac_lessi = 1. - EXP(-zprec_cond(i)/zneb(i))
1658           pfrac_1nucl(i,k)=pfrac_1nucl(i,k)*(1.-zneb(i)*zfrac_lessi)
1659        ENDIF
1660        !
1661     ENDDO      ! boucle sur i
1662     !
1663     !AA Lessivage par impaction dans les couches en-dessous
1664     DO kk = k-1, 1, -1
[524]1665        DO i = 1, klon
[1472]1666           IF (rneb(i,k).GT.0.0.and.zprec_cond(i).gt.0.) THEN
[2006]1667             IF (iflag_t_glace.EQ.0) THEN
1668              if (t(i,kk) .GE. t_glace_min_old) THEN
[1472]1669                 zalpha_tr = a_tr_sca(1)
1670              else
1671                 zalpha_tr = a_tr_sca(2)
1672              endif
[2006]1673             ELSE ! of IF (iflag_t_glace.EQ.0)
1674              if (t(i,kk) .GE. t_glace_min) THEN
1675                 zalpha_tr = a_tr_sca(1)
1676              else
1677                 zalpha_tr = a_tr_sca(2)
1678              endif
1679             ENDIF
[1472]1680              zfrac_lessi = 1. - EXP(zalpha_tr*zprec_cond(i)/zneb(i))
1681              pfrac_impa(i,kk)=pfrac_impa(i,kk)*(1.-zneb(i)*zfrac_lessi)
1682              frac_impa(i,kk)= 1.-zneb(i)*zfrac_lessi
1683           ENDIF
[524]1684        ENDDO
[1472]1685     ENDDO
1686     !
[2500]1687     !AA===============================================================
1688     !                     FIN DE LA BOUCLE VERTICALE 
[1472]1689  end DO
1690  !
[2500]1691  !AA==================================================================
[1472]1692  !
1693  ! Pluie ou neige au sol selon la temperature de la 1ere couche
1694  !
[2086]1695!CR: si la thermo de la glace est active, on calcule zifl directement
1696  IF (.NOT.ice_thermo) THEN
[1472]1697  DO i = 1, klon
1698     IF ((t(i,1)+d_t(i,1)) .LT. RTT) THEN
[1849]1699!AJ<
[2086]1700!        snow(i) = zrfl(i)
[1849]1701        snow(i) = zrfl(i)+zifl(i)
1702!>AJ
[1472]1703        zlh_solid(i) = RLSTT-RLVTT
1704     ELSE
1705        rain(i) = zrfl(i)
1706        zlh_solid(i) = 0.
1707     ENDIF
1708  ENDDO
[2086]1709
1710  ELSE
1711     DO i = 1, klon
1712        snow(i) = zifl(i)
1713        rain(i) = zrfl(i)
1714     ENDDO
1715   
1716   ENDIF
[1472]1717  !
1718  ! For energy conservation : when snow is present, the solification
1719  ! latent heat is considered.
[2086]1720!CR: si thermo de la glace, neige deja prise en compte
1721  IF (.not.ice_thermo) THEN
[1472]1722  DO k = 1, klev
1723     DO i = 1, klon
1724        zcpair=RCPD*(1.0+RVTMP2*(q(i,k)+d_q(i,k)))
[2807]1725        zmair(i)=(paprs(i,k)-paprs(i,k+1))/RG
[1472]1726        zm_solid = (prfl(i,k)-prfl(i,k+1)+psfl(i,k)-psfl(i,k+1))*dtime
[2807]1727        d_t(i,k) = d_t(i,k) + zlh_solid(i) *zm_solid / (zcpair*zmair(i))
[1472]1728     END DO
1729  END DO
[2086]1730  ENDIF
[1472]1731  !
[883]1732
[1472]1733  if (ncoreczq>0) then
[1575]1734     WRITE(lunout,*)'WARNING : ZQ dans fisrtilp ',ncoreczq,' val < 1.e-15.'
[1472]1735  endif
1736
1737END SUBROUTINE fisrtilp
Note: See TracBrowser for help on using the repository browser.