source: LMDZ5/trunk/libf/phylmd/concvl.F90 @ 2404

Last change on this file since 2404 was 2346, checked in by Ehouarn Millour, 9 years ago

Physics/dynamics separation:

  • remove all references to dimensions.h from physics. nbp_lon (==iim) , nbp_lat (==jjm+1) and nbp_lev (==llm) from mod_grid_phy_lmdz should be used instead.
  • added module regular_lonlat_mod in phy_common to store information about the global (lon-lat) grid cell boundaries and centers.

EM

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