source: LMDZ6/branches/Amaury_dev/libf/phylmd/concvl.F90 @ 5133

Last change on this file since 5133 was 5112, checked in by abarral, 5 months ago

Rename modules in phy_common from *_mod > lmdz_*

  • 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: 20.8 KB
RevLine 
[2007]1SUBROUTINE concvl(iflag_clos, &
[2259]2                  dtime, paprs, pplay, k_upper_cv, &
[2007]3                  t, q, t_wake, q_wake, s_wake, u, v, tra, ntra, &
4                  Ale, Alp, sig1, w01, &
[4613]5                  d_t, d_q, d_qcomp, d_u, d_v, d_tra, &
[2007]6                  rain, snow, kbas, ktop, sigd, &
[2824]7                  cbmf, plcl, plfc, wbeff, convoccur, &
8                  upwd, dnwd, dnwdbis, &
[2007]9                  Ma, mip, Vprecip, &
10                  cape, cin, tvp, Tconv, iflag, &
11                  pbase, bbase, dtvpdt1, dtvpdq1, dplcldt, dplcldr, &
12                  qcondc, wd, pmflxr, pmflxs, &
13!RomP >>>
14!!     .             da,phi,mp,dd_t,dd_q,lalim_conv,wght_th)
[3496]15                  da, phi, mp, phii, d1a, dam, sij, qta, clw, elij, &! RomP
[2007]16                  dd_t, dd_q, lalim_conv, wght_th, &                 ! RomP
17                  evap, ep, epmlmMm, eplaMm, &                       ! RomP
[4613]18                  wdtrainA, wdtrainS, wdtrainM, wght, qtc, sigt, detrain, &
[2481]19                  tau_cld_cv, coefw_cld_cv, &                           ! RomP+RL, AJ
[2007]20!RomP <<<
[2481]21                  epmax_diag) ! epmax_cape
[2007]22! **************************************************************
23! *
24! CONCVL                                                      *
25! *
26! *
27! written by   : Sandrine Bony-Lena, 17/05/2003, 11.16.04    *
28! modified by :                                               *
29! **************************************************************
[1849]30
[1334]31
[1992]32  USE dimphy
[2320]33  USE infotrac_phy, ONLY: nbtr
[2201]34  USE phys_local_var_mod, ONLY: omega
[5112]35  USE lmdz_print_control, ONLY: prt_level, lunout
[1992]36  IMPLICIT NONE
[2007]37! ======================================================================
38! Auteur(s): S. Bony-Lena (LMD/CNRS) date: ???
39! Objet: schema de convection de Emanuel (1991) interface
40! ======================================================================
41! Arguments:
42! dtime--input-R-pas d'integration (s)
43! s-------input-R-la vAleur "s" pour chaque couche
44! sigs----input-R-la vAleur "sigma" de chaque couche
45! sig-----input-R-la vAleur de "sigma" pour chaque niveau
46! psolpa--input-R-la pression au sol (en Pa)
47! pskapa--input-R-exponentiel kappa de psolpa
48! h-------input-R-enthAlpie potentielle (Cp*T/P**kappa)
49! q-------input-R-vapeur d'eau (en kg/kg)
[1334]50
[2007]51! work*: input et output: deux variables de travail,
52! on peut les mettre a 0 au debut
53! ALE--------input-R-energie disponible pour soulevement
54! ALP--------input-R-puissance disponible pour soulevement
[766]55
[2007]56! d_h--------output-R-increment de l'enthAlpie potentielle (h)
57! d_q--------output-R-increment de la vapeur d'eau
58! rain-------output-R-la pluie (mm/s)
59! snow-------output-R-la neige (mm/s)
60! upwd-------output-R-saturated updraft mass flux (kg/m**2/s)
61! dnwd-------output-R-saturated downdraft mass flux (kg/m**2/s)
62! dnwd0------output-R-unsaturated downdraft mass flux (kg/m**2/s)
63! Ma---------output-R-adiabatic ascent mass flux (kg/m2/s)
64! mip--------output-R-mass flux shed by adiabatic ascent (kg/m2/s)
[2306]65! Vprecip----output-R-vertical profile of total precipitation (kg/m2/s)
[2007]66! Tconv------output-R-environment temperature seen by convective scheme (K)
67! Cape-------output-R-CAPE (J/kg)
68! Cin -------output-R-CIN  (J/kg)
69! Tvp--------output-R-Temperature virtuelle d'une parcelle soulevee
70! adiabatiquement a partir du niveau 1 (K)
71! deltapb----output-R-distance entre LCL et base de la colonne (<0 ; Pa)
72! Ice_flag---input-L-TRUE->prise en compte de la thermodynamique de la glace
73! dd_t-------output-R-increment de la temperature du aux descentes precipitantes
74! dd_q-------output-R-increment de la vapeur d'eau du aux desc precip
75! lalim_conv-
76! wght_th----
77! evap-------output-R
78! ep---------output-R
79! epmlmMm----output-R
80! eplaMm-----output-R
81! wdtrainA---output-R
[3496]82! wdtrainS---output-R
[2007]83! wdtrainM---output-R
84! wght-------output-R
85! ======================================================================
[879]86
[524]87
[1992]88  include "clesphys.h"
[1574]89
[2853]90  INTEGER, INTENT(IN)                           :: iflag_clos
91  REAL, INTENT(IN)                              :: dtime
92  REAL, DIMENSION(klon,klev),   INTENT(IN)      :: pplay
93  REAL, DIMENSION(klon,klev+1), INTENT(IN)      :: paprs
94  INTEGER,                      INTENT(IN)      :: k_upper_cv
95  REAL, DIMENSION(klon,klev),   INTENT(IN)      :: t, q, u, v
96  REAL, DIMENSION(klon,klev),   INTENT(IN)      :: t_wake, q_wake
97  REAL, DIMENSION(klon),        INTENT(IN)      :: s_wake
98  REAL, DIMENSION(klon,klev, nbtr),INTENT(IN)   :: tra
99  INTEGER,                      INTENT(IN)      :: ntra
100  REAL, DIMENSION(klon),        INTENT(IN)      :: Ale, Alp
101!CR:test: on passe lentr et alim_star des thermiques
102  INTEGER, DIMENSION(klon),     INTENT(IN)      :: lalim_conv
103  REAL, DIMENSION(klon,klev),   INTENT(IN)      :: wght_th
[1992]104
[2853]105  REAL, DIMENSION(klon,klev),   INTENT(INOUT)   :: sig1, w01
[1992]106
[4613]107  REAL, DIMENSION(klon,klev),   INTENT(OUT)     :: d_t, d_q, d_qcomp, d_u, d_v
[2853]108  REAL, DIMENSION(klon,klev, nbtr),INTENT(OUT)  :: d_tra
109  REAL, DIMENSION(klon),        INTENT(OUT)     :: rain, snow
[1992]110
[2853]111  INTEGER, DIMENSION(klon),     INTENT(OUT)     :: kbas, ktop
112  REAL, DIMENSION(klon),        INTENT(OUT)     :: sigd
113  REAL, DIMENSION(klon),        INTENT(OUT)     :: cbmf, plcl, plfc, wbeff
114  REAL, DIMENSION(klon),        INTENT(OUT)     :: convoccur
115  REAL, DIMENSION(klon,klev),   INTENT(OUT)     :: upwd, dnwd, dnwdbis
[1992]116
[2853]117!!       REAL Ma(klon,klev), mip(klon,klev),Vprecip(klon,klev)                    !jyg
118  REAL, DIMENSION(klon,klev),   INTENT(OUT)     :: Ma, mip
119  REAL, DIMENSION(klon,klev+1), INTENT(OUT)     :: Vprecip                        !jyg
120  REAL, DIMENSION(klon),        INTENT(OUT)     :: cape, cin
121  REAL, DIMENSION(klon,klev),   INTENT(OUT)     :: tvp
122  REAL, DIMENSION(klon,klev),   INTENT(OUT)     :: Tconv
123  INTEGER, DIMENSION(klon),     INTENT(OUT)     :: iflag
124  REAL, DIMENSION(klon),        INTENT(OUT)     :: pbase, bbase
125  REAL, DIMENSION(klon,klev),   INTENT(OUT)     :: dtvpdt1, dtvpdq1
126  REAL, DIMENSION(klon),        INTENT(OUT)     :: dplcldt, dplcldr
127  REAL, DIMENSION(klon,klev),   INTENT(OUT)     :: qcondc
128  REAL, DIMENSION(klon),        INTENT(OUT)     :: wd
129  REAL, DIMENSION(klon,klev+1), INTENT(OUT)     :: pmflxr, pmflxs
[1992]130
[2853]131  REAL, DIMENSION(klon,klev),   INTENT(OUT)     :: da, mp
132  REAL, DIMENSION(klon,klev,klev),INTENT(OUT)   :: phi
[2007]133! RomP >>>
[2853]134  REAL, DIMENSION(klon,klev,klev),INTENT(OUT)   :: phii
135  REAL, DIMENSION(klon,klev),   INTENT(OUT)     :: d1a, dam
136  REAL, DIMENSION(klon,klev,klev),INTENT(OUT)   :: sij, elij
[3496]137  REAL, DIMENSION(klon,klev),   INTENT(OUT)     :: qta
[2853]138  REAL, DIMENSION(klon,klev),   INTENT(OUT)     :: clw
139  REAL, DIMENSION(klon,klev),   INTENT(OUT)     :: dd_t, dd_q
140  REAL, DIMENSION(klon,klev),   INTENT(OUT)     :: evap, ep
141  REAL, DIMENSION(klon,klev),   INTENT(OUT)     :: eplaMm
142  REAL, DIMENSION(klon,klev,klev), INTENT(OUT)  :: epmlmMm
[3496]143  REAL, DIMENSION(klon,klev),   INTENT(OUT)     :: wdtrainA, wdtrainS, wdtrainM
[2007]144! RomP <<<
[2853]145  REAL, DIMENSION(klon,klev),   INTENT(OUT)     :: wght                       !RL
146  REAL, DIMENSION(klon,klev),   INTENT(OUT)     :: qtc
[4613]147  REAL, DIMENSION(klon,klev),   INTENT(OUT)     :: sigt, detrain
[2853]148  REAL,                         INTENT(OUT)     :: tau_cld_cv, coefw_cld_cv
149  REAL, DIMENSION(klon),        INTENT(OUT)     :: epmax_diag                ! epmax_cape
[1992]150
[2853]151!  Local
152!  ----
153  REAL, DIMENSION(klon,klev)                    :: em_p
154  REAL, DIMENSION(klon,klev+1)                  :: em_ph
155  REAL                                          :: em_sig1feed ! sigma at lower bound of feeding layer
156  REAL                                          :: em_sig2feed ! sigma at upper bound of feeding layer
157  REAL, DIMENSION(klev)                         :: em_wght ! weight density determining the feeding mixture
158  REAL, DIMENSION(klon,klev+1)                  :: Vprecipi                       !jyg
[2007]159!on enleve le save
160! SAVE em_sig1feed,em_sig2feed,em_wght
[1992]161
[2853]162  REAL, DIMENSION(klon)                         :: rflag
163  REAL, DIMENSION(klon)                         :: plim1, plim2
164  REAL, DIMENSION(klon)                         :: ptop2
165  REAL, DIMENSION(klon,klev)                    :: asupmax
166  REAL, DIMENSION(klon)                         :: supmax0, asupmaxmin
167  REAL                                          :: zx_t, zdelta, zx_qs, zcor
[5099]168
[2007]169!   INTEGER iflag_mix
170!   SAVE iflag_mix
[2853]171  INTEGER                                       :: noff, minorig
172  INTEGER                                       :: i,j, k, itra
173  REAL, DIMENSION(klon,klev)                    :: qs, qs_wake
[2007]174!LF          SAVE cbmf
175!IM/JYG      REAL, SAVE, ALLOCATABLE :: cbmf(:)
176!!!$OMP THREADPRIVATE(cbmf)!
[2853]177  REAL, DIMENSION(klon)                         :: cbmflast
[1992]178
179
[2007]180! Variables supplementaires liees au bilan d'energie
181! Real paire(klon)
182!LF      Real ql(klon,klev)
183! Save paire
184!LF      Save ql
185!LF      Real t1(klon,klev),q1(klon,klev)
186!LF      Save t1,q1
187! Data paire /1./
[1992]188  REAL, SAVE, ALLOCATABLE :: ql(:, :), q1(:, :), t1(:, :)
[2007]189!$OMP THREADPRIVATE(ql, q1, t1)
[1992]190
[2007]191! Variables liees au bilan d'energie et d'enthAlpi
[1992]192  REAL ztsol(klon)
[2007]193  REAL        h_vcol_tot, h_dair_tot, h_qw_tot, h_ql_tot, &
194              h_qs_tot, qw_tot, ql_tot, qs_tot, ec_tot
195  SAVE        h_vcol_tot, h_dair_tot, h_qw_tot, h_ql_tot, &
196              h_qs_tot, qw_tot, ql_tot, qs_tot, ec_tot
197!$OMP THREADPRIVATE(h_vcol_tot, h_dair_tot, h_qw_tot, h_ql_tot)
198!$OMP THREADPRIVATE(h_qs_tot, qw_tot, ql_tot, qs_tot , ec_tot)
199  REAL        d_h_vcol, d_h_dair, d_qt, d_qw, d_ql, d_qs, d_ec
200  REAL        d_h_vcol_phy
201  REAL        fs_bound, fq_bound
202  SAVE        d_h_vcol_phy
203!$OMP THREADPRIVATE(d_h_vcol_phy)
204  REAL        zero_v(klon)
[1992]205  CHARACTER *15 ztit
[2007]206  INTEGER     ip_ebil ! PRINT level for energy conserv. diag.
207  SAVE        ip_ebil
208  DATA        ip_ebil/2/
209!$OMP THREADPRIVATE(ip_ebil)
210  INTEGER     if_ebil ! level for energy conserv. dignostics
211  SAVE        if_ebil
212  DATA        if_ebil/2/
213!$OMP THREADPRIVATE(if_ebil)
214!+jld ec_conser
[1992]215  REAL d_t_ec(klon, klev) ! tendance du a la conersion Ec -> E thermique
216  REAL zrcpd
[2007]217!-jld ec_conser
218!LF
[1992]219  INTEGER nloc
[2007]220  LOGICAL, SAVE            :: first = .TRUE.
221!$OMP THREADPRIVATE(first)
222  INTEGER, SAVE            :: itap, igout
223!$OMP THREADPRIVATE(itap, igout)
[1992]224
[2205]225
[1992]226  include "YOMCST.h"
227  include "YOMCST2.h"
228  include "YOETHF.h"
229  include "FCTTRE.h"
[2253]230!jyg<
231  include "conema3.h"
232!>jyg
[1992]233
234  IF (first) THEN
[2007]235! Allocate some variables LF 04/2008
[1992]236
[2007]237!IM/JYG allocate(cbmf(klon))
[1992]238    ALLOCATE (ql(klon,klev))
239    ALLOCATE (t1(klon,klev))
240    ALLOCATE (q1(klon,klev))
[5099]241
[2824]242    convoccur(:) = 0.
[5099]243
[1992]244    itap = 0
245    igout = klon/2 + 1/klon
246  END IF
[2007]247! Incrementer le compteur de la physique
[1992]248  itap = itap + 1
249
[2007]250! Copy T into Tconv
[1992]251  DO k = 1, klev
252    DO i = 1, klon
[2007]253      Tconv(i, k) = t(i, k)
[1992]254    END DO
255  END DO
256
257  IF (if_ebil>=1) THEN
258    DO i = 1, klon
259      ztsol(i) = t(i, 1)
260      zero_v(i) = 0.
[524]261      DO k = 1, klev
[1992]262        ql(i, k) = 0.
263      END DO
264    END DO
265  END IF
[524]266
[2007]267! ym
[1992]268  snow(:) = 0
269
270  IF (first) THEN
271    first = .FALSE.
272
[2007]273! ===========================================================================
274! READ IN PARAMETERS FOR THE CLOSURE AND THE MIXING DISTRIBUTION
275! ===========================================================================
[1992]276
277    IF (iflag_con==3) THEN
[2007]278!      CALL cv3_inicp()
[1992]279      CALL cv3_inip()
280    END IF
281
[2007]282! ===========================================================================
283! READ IN PARAMETERS FOR CONVECTIVE INHIBITION BY TROPOS. DRYNESS
284! ===========================================================================
[1992]285
[2007]286! c$$$         open (56,file='supcrit.data')
287! c$$$         read (56,*) Supcrit1, Supcrit2
288! c$$$         close (56)
[1992]289
[2007]290    IF (prt_level>=10) WRITE (lunout, *) 'supcrit1, supcrit2', supcrit1, supcrit2
[1992]291
[2007]292! ===========================================================================
293! Initialisation pour les bilans d'eau et d'energie
294! ===========================================================================
[1992]295    IF (if_ebil>=1) d_h_vcol_phy = 0.
296
297    DO i = 1, klon
298      cbmf(i) = 0.
[2007]299!!          plcl(i) = 0.
[1992]300      sigd(i) = 0.
301    END DO
[2853]302  END IF !(first)
[1992]303
[2007]304! Initialisation a chaque pas de temps
[1992]305  plfc(:) = 0.
306  wbeff(:) = 100.
307  plcl(:) = 0.
308
309  DO k = 1, klev + 1
310    DO i = 1, klon
311      em_ph(i, k) = paprs(i, k)/100.0
312      pmflxr(i, k) = 0.
313      pmflxs(i, k) = 0.
314    END DO
315  END DO
316
317  DO k = 1, klev
318    DO i = 1, klon
319      em_p(i, k) = pplay(i, k)/100.0
320    END DO
321  END DO
322
323
[2007]324! Feeding layer
[1992]325
326  em_sig1feed = 1.
[2253]327!jyg<
328!  em_sig2feed = 0.97
329  em_sig2feed = cvl_sig2feed
330!>jyg
[2007]331! em_sig2feed = 0.8
332! Relative Weight densities
[1992]333  DO k = 1, klev
334    em_wght(k) = 1.
335  END DO
[2007]336!CRtest: couche alim des tehrmiques ponderee par a*
337! DO i = 1, klon
338! do k=1,lalim_conv(i)
339! em_wght(k)=wght_th(i,k)
[5103]340! PRINT*,'em_wght=',em_wght(k),wght_th(i,k)
[2007]341! END DO
[5086]342! END DO
[1992]343
344  IF (iflag_con==4) THEN
345    DO k = 1, klev
346      DO i = 1, klon
347        zx_t = t(i, k)
348        zdelta = max(0., sign(1.,rtt-zx_t))
349        zx_qs = min(0.5, r2es*foeew(zx_t,zdelta)/em_p(i,k)/100.0)
350        zcor = 1./(1.-retv*zx_qs)
351        qs(i, k) = zx_qs*zcor
352      END DO
353      DO i = 1, klon
354        zx_t = t_wake(i, k)
355        zdelta = max(0., sign(1.,rtt-zx_t))
356        zx_qs = min(0.5, r2es*foeew(zx_t,zdelta)/em_p(i,k)/100.0)
357        zcor = 1./(1.-retv*zx_qs)
358        qs_wake(i, k) = zx_qs*zcor
359      END DO
360    END DO
[2007]361  ELSE ! iflag_con=3 (modif de puristes qui fait la diffce pour la convergence numerique)
[1992]362    DO k = 1, klev
363      DO i = 1, klon
364        zx_t = t(i, k)
365        zdelta = max(0., sign(1.,rtt-zx_t))
366        zx_qs = r2es*foeew(zx_t, zdelta)/em_p(i, k)/100.0
367        zx_qs = min(0.5, zx_qs)
368        zcor = 1./(1.-retv*zx_qs)
369        zx_qs = zx_qs*zcor
370        qs(i, k) = zx_qs
371      END DO
372      DO i = 1, klon
373        zx_t = t_wake(i, k)
374        zdelta = max(0., sign(1.,rtt-zx_t))
375        zx_qs = r2es*foeew(zx_t, zdelta)/em_p(i, k)/100.0
376        zx_qs = min(0.5, zx_qs)
377        zcor = 1./(1.-retv*zx_qs)
378        zx_qs = zx_qs*zcor
379        qs_wake(i, k) = zx_qs
380      END DO
381    END DO
382  END IF ! iflag_con
383
[2007]384! ------------------------------------------------------------------
[1992]385
[2007]386! Main driver for convection:
387!                   iflag_con=3 -> nvlle version de KE (JYG)
388!                   iflag_con = 30  -> equivAlent to convect3
389!                   iflag_con = 4  -> equivAlent to convect1/2
[1992]390
391
392  IF (iflag_con==30) THEN
393
[2007]394! print *, '-> cv_driver'      !jyg
395    CALL cv_driver(klon, klev, klevp1, ntra, iflag_con, &
396                   t, q, qs, u, v, tra, &
397                   em_p, em_ph, iflag, &
398                   d_t, d_q, d_u, d_v, d_tra, rain, &
399                   Vprecip, cbmf, sig1, w01, & !jyg
400                   kbas, ktop, &
401                   dtime, Ma, upwd, dnwd, dnwdbis, qcondc, wd, cape, &
[2853]402                   da, phi, mp, phii, d1a, dam, sij, clw, elij, &       !RomP
[2007]403                   evap, ep, epmlmMm, eplaMm, &                         !RomP
[2481]404                   wdtrainA, wdtrainM, &                                !RomP
405                   epmax_diag) ! epmax_cape
[2007]406!           print *, 'cv_driver ->'      !jyg
[1992]407
408    DO i = 1, klon
[2007]409      cbmf(i) = Ma(i, kbas(i))
[1992]410    END DO
411
[2007]412!RL
413    wght(:, :) = 0.
414    DO i = 1, klon
415      wght(i, 1) = 1.
416    END DO
417!RL
418
[1992]419  ELSE
420
[2007]421!LF   necessary for gathered fields
[1992]422    nloc = klon
[2259]423    CALL cva_driver(klon, klev, klev+1, ntra, nloc, k_upper_cv, &
[2007]424                    iflag_con, iflag_mix, iflag_ice_thermo, &
[2253]425                    iflag_clos, ok_conserv_q, dtime, cvl_comp_threshold, &
[2007]426                    t, q, qs, t_wake, q_wake, qs_wake, s_wake, u, v, tra, &
427                    em_p, em_ph, &
[2201]428                    Ale, Alp, omega, &
[2007]429                    em_sig1feed, em_sig2feed, em_wght, &
[4613]430                    iflag, d_t, d_q, d_qcomp, d_u, d_v, d_tra, rain, kbas, ktop, &
[2007]431                    cbmf, plcl, plfc, wbeff, sig1, w01, ptop2, sigd, &
[2306]432                    Ma, mip, Vprecip, Vprecipi, upwd, dnwd, dnwdbis, qcondc, wd, &
[2007]433                    cape, cin, tvp, &
434                    dd_t, dd_q, plim1, plim2, asupmax, supmax0, &
435                    asupmaxmin, lalim_conv, &
436!AC!+!RomP+jyg
[2853]437!!                   da,phi,mp,phii,d1a,dam,sij,clw,elij, &               ! RomP
[2007]438!!                   evap,ep,epmlmMm,eplaMm,                              ! RomP
[2853]439                    da, phi, mp, phii, d1a, dam, sij, wght, &           ! RomP+RL
[3496]440                    qta, clw, elij, evap, ep, epmlmMm, eplaMm, &        ! RomP+RL
[4613]441                    wdtrainA, wdtrainS, wdtrainM, qtc, sigt, detrain, &
[2481]442                    tau_cld_cv, coefw_cld_cv, &                         ! RomP,AJ
[2007]443!AC!+!RomP+jyg
[2481]444                    epmax_diag) ! epmax_cape
[1992]445  END IF
[2007]446! ------------------------------------------------------------------
[3197]447  IF (prt_level>=10) WRITE (lunout, *) ' cva_driver -> cbmf,plcl,plfc,wbeff, d_t, d_q ', &
448                                         cbmf(1), plcl(1), plfc(1), wbeff(1), d_t(1,1), d_q(1,1)
[1992]449
450  DO i = 1, klon
451    rain(i) = rain(i)/86400.
452    rflag(i) = iflag(i)
453  END DO
454
455  DO k = 1, klev
456    DO i = 1, klon
457      d_t(i, k) = dtime*d_t(i, k)
458      d_q(i, k) = dtime*d_q(i, k)
459      d_u(i, k) = dtime*d_u(i, k)
460      d_v(i, k) = dtime*d_v(i, k)
461    END DO
462  END DO
463
[2824]464  IF (iflag_con==3) THEN
465    DO i = 1,klon
466      IF (wbeff(i) > 100. .OR. wbeff(i) == 0 .OR. iflag(i) > 3) THEN
467        wbeff(i) = 0.
468        convoccur(i) = 0. 
469      ELSE
470        convoccur(i) = 1.
471      ENDIF
472    ENDDO
473  ENDIF
474
[1992]475  IF (iflag_con==30) THEN
476    DO itra = 1, ntra
[524]477      DO k = 1, klev
478        DO i = 1, klon
[2007]479!RL!            d_tra(i,k,itra) =dtime*d_tra(i,k,itra)
480          d_tra(i, k, itra) = 0.
[1992]481        END DO
482      END DO
483    END DO
484  END IF
485
[2007]486!!AC!
[1992]487  IF (iflag_con==3) THEN
488    DO itra = 1, ntra
[524]489      DO k = 1, klev
490        DO i = 1, klon
[2007]491!RL!            d_tra(i,k,itra) =dtime*d_tra(i,k,itra)
492          d_tra(i, k, itra) = 0.
[1992]493        END DO
494      END DO
495    END DO
496  END IF
[2007]497!!AC!
[524]498
[1992]499  DO k = 1, klev
500    DO i = 1, klon
501      t1(i, k) = t(i, k) + d_t(i, k)
502      q1(i, k) = q(i, k) + d_q(i, k)
503    END DO
504  END DO
[2306]505!                                                     !jyg
506  IF (iflag_con == 30 .OR. iflag_ice_thermo ==0) THEN
507! --Separation neige/pluie (pour diagnostics)         !jyg
508    DO k = 1, klev                                    !jyg
509      DO i = 1, klon                                  !jyg
510        IF (t1(i,k)<rtt) THEN                         !jyg
511          pmflxs(i, k) = Vprecip(i, k)                !jyg
512        ELSE                                          !jyg
513          pmflxr(i, k) = Vprecip(i, k)                !jyg
514        END IF                                        !jyg
515      END DO                                          !jyg
516    END DO                                            !jyg
517  ELSE
518    DO k = 1, klev                                    !jyg
519      DO i = 1, klon                                  !jyg
520        pmflxs(i, k) = Vprecipi(i, k)                 !jyg
521        pmflxr(i, k) = Vprecip(i, k)-Vprecipi(i, k)   !jyg
522      END DO                                          !jyg
523    END DO                                            !jyg
524  ENDIF
[524]525
[2007]526! c      IF (if_ebil.ge.2) THEN
527! c        ztit='after convect'
528! c        CALL diagetpq(paire,ztit,ip_ebil,2,2,dtime
529! c     e      , t1,q1,ql,qs,u,v,paprs,pplay
530! c     s      , d_h_vcol, d_qt, d_qw, d_ql, d_qs, d_ec)
[5101]531! c         CALL diagphy(paire,ztit,ip_ebil
[2007]532! c     e      , zero_v, zero_v, zero_v, zero_v, zero_v
533! c     e      , zero_v, rain, zero_v, ztsol
534! c     e      , d_h_vcol, d_qt, d_ec
535! c     s      , fs_bound, fq_bound )
536! c      END IF
[524]537
538
[2007]539! les traceurs ne sont pas mis dans cette version de convect4:
[1992]540  IF (iflag_con==4) THEN
541    DO itra = 1, ntra
[524]542      DO k = 1, klev
543        DO i = 1, klon
[1992]544          d_tra(i, k, itra) = 0.
545        END DO
546      END DO
547    END DO
548  END IF
[5103]549! PRINT*, 'concvl->: dd_t,dd_q ',dd_t(1,1),dd_q(1,1)
[879]550
[1992]551  DO k = 1, klev
552    DO i = 1, klon
553      dtvpdt1(i, k) = 0.
554      dtvpdq1(i, k) = 0.
555    END DO
556  END DO
557  DO i = 1, klon
558    dplcldt(i) = 0.
559    dplcldr(i) = 0.
560  END DO
[1650]561
[1992]562  IF (prt_level>=20) THEN
563    DO k = 1, klev
[5103]564! PRINT*,'physiq apres_add_con i k it d_u d_v d_t d_q qdl0',igout, &
[2007]565!         k,itap,d_u_con(igout,k) ,d_v_con(igout,k), d_t_con(igout,k), &
566!         d_q_con(igout,k),dql0(igout,k)
[5103]567! PRINT*,'phys apres_add_con itap Ma cin ALE ALP wak t q undi t q', &
[2007]568!         itap,Ma(igout,k),cin(igout),ALE(igout), ALP(igout), &
569!         t_wake(igout,k),q_wake(igout,k),t_undi(igout,k),q_undi(igout,k)
[5103]570! PRINT*,'phy apres_add_con itap CON rain snow EMA wk1 wk2 Vpp mip', &
[2007]571!         itap,rain_con(igout),snow_con(igout),ema_work1(igout,k), &
572!         ema_work2(igout,k),Vprecip(igout,k), mip(igout,k)
[5103]573! PRINT*,'phy apres_add_con itap upwd dnwd dnwd0 cape tvp Tconv ', &
[2007]574!         itap,upwd(igout,k),dnwd(igout,k),dnwd0(igout,k),cape(igout), &
575!         tvp(igout,k),Tconv(igout,k)
[5103]576! PRINT*,'phy apres_add_con itap dtvpdt dtvdq dplcl dplcldr qcondc', &
[2007]577!         itap,dtvpdt1(igout,k),dtvpdq1(igout,k),dplcldt(igout), &
578!         dplcldr(igout),qcondc(igout,k)
[5103]579! PRINT*,'phy apres_add_con itap wd pmflxr Kpmflxr Kp1 Kpmflxs Kp1', &
[2007]580!         itap,wd(igout),pmflxr(igout,k),pmflxr(igout,k+1),pmflxs(igout,k), &
581!         pmflxs(igout,k+1)
[5103]582! PRINT*,'phy apres_add_con itap da phi mp ftd fqd lalim wgth', &
[2007]583!         itap,da(igout,k),phi(igout,k,k),mp(igout,k),ftd(igout,k), &
584!         fqd(igout,k),lalim_conv(igout),wght_th(igout,k)
[1992]585    END DO
586  END IF !(prt_level.EQ.20) THEN
[879]587
[5105]588
[1992]589END SUBROUTINE concvl
590
Note: See TracBrowser for help on using the repository browser.