source: LMDZ4/trunk/libf/phylmd/concvl.F @ 581

Last change on this file since 581 was 559, checked in by lmdzadmin, 20 years ago

Initialisations diverses YM
LF

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 5.2 KB
Line 
1!
2! $Header$
3!
4      SUBROUTINE concvl (iflag_con,dtime,paprs,pplay,t,q,u,v,tra,ntra,
5     .             work1,work2,d_t,d_q,d_u,d_v,d_tra,
6     .             rain, snow, kbas, ktop,
7     .             upwd,dnwd,dnwdbis,Ma,cape,tvp,iflag,
8     .             pbase,bbase,dtvpdt1,dtvpdq1,dplcldt,dplcldr,
9     .             qcondc,wd)
10 
11c
12      IMPLICIT none
13c======================================================================
14c Auteur(s): Z.X. Li (LMD/CNRS) date: 19930818
15c Objet: schema de convection de Emanuel (1991) interface
16c======================================================================
17c Arguments:
18c dtime--input-R-pas d'integration (s)
19c s-------input-R-la valeur "s" pour chaque couche
20c sigs----input-R-la valeur "sigma" de chaque couche
21c sig-----input-R-la valeur de "sigma" pour chaque niveau
22c psolpa--input-R-la pression au sol (en Pa)
23C pskapa--input-R-exponentiel kappa de psolpa
24c h-------input-R-enthalpie potentielle (Cp*T/P**kappa)
25c q-------input-R-vapeur d'eau (en kg/kg)
26c
27c work*: input et output: deux variables de travail,
28c                            on peut les mettre a 0 au debut
29c ALE-----input-R-energie disponible pour soulevement
30c
31C d_h-----output-R-increment de l'enthalpie potentielle (h)
32c d_q-----output-R-increment de la vapeur d'eau
33c rain----output-R-la pluie (mm/s)
34c snow----output-R-la neige (mm/s)
35c upwd----output-R-saturated updraft mass flux (kg/m**2/s)
36c dnwd----output-R-saturated downdraft mass flux (kg/m**2/s)
37c dnwd0---output-R-unsaturated downdraft mass flux (kg/m**2/s)
38c Cape----output-R-CAPE (J/kg)
39c Tvp-----output-R-Temperature virtuelle d'une parcelle soulevee
40c                  adiabatiquement a partir du niveau 1 (K)
41c deltapb-output-R-distance entre LCL et base de la colonne (<0 ; Pa)
42c Ice_flag-input-L-TRUE->prise en compte de la thermodynamique de la glace
43c======================================================================
44c
45#include "dimensions.h"
46#include "dimphy.h"
47c
48      integer NTRAC
49      PARAMETER (NTRAC=nqmx-2)
50c
51       INTEGER iflag_con
52c
53       REAL dtime, paprs(klon,klev+1),pplay(klon,klev)
54       REAL t(klon,klev),q(klon,klev),u(klon,klev),v(klon,klev)
55       REAL tra(klon,klev,ntrac)
56       INTEGER ntra
57       REAL work1(klon,klev),work2(klon,klev)
58c
59       REAL d_t(klon,klev),d_q(klon,klev),d_u(klon,klev),d_v(klon,klev)
60       REAL d_tra(klon,klev,ntrac)
61       REAL rain(klon),snow(klon)
62c
63       INTEGER kbas(klon),ktop(klon)
64       REAL em_ph(klon,klev+1),em_p(klon,klev)
65       REAL upwd(klon,klev),dnwd(klon,klev),dnwdbis(klon,klev)
66       REAL Ma(klon,klev),cape(klon),tvp(klon,klev)
67       INTEGER iflag(klon)
68       REAL rflag(klon)
69       REAL pbase(klon),bbase(klon)
70       REAL dtvpdt1(klon,klev),dtvpdq1(klon,klev)
71       REAL dplcldt(klon),dplcldr(klon)
72       REAL qcondc(klon,klev)
73       REAL wd(klon)
74c
75       REAL zx_t,zdelta,zx_qs,zcor
76c
77       INTEGER noff, minorig
78       INTEGER i,k,itra
79       REAL qs(klon,klev)
80       REAL cbmf(klon)
81       SAVE cbmf
82       INTEGER ifrst
83       SAVE ifrst
84       DATA ifrst /0/
85#include "YOMCST.h"
86#include "YOETHF.h"
87#include "FCTTRE.h"
88c
89c
90cym
91      snow(:)=0
92     
93      IF (ifrst .EQ. 0) THEN
94         ifrst = 1
95         DO i = 1, klon
96          cbmf(i) = 0.
97         ENDDO
98      ENDIF
99
100      DO k = 1, klev+1
101         DO i=1,klon
102         em_ph(i,k) = paprs(i,k) / 100.0
103      ENDDO
104      ENDDO
105c
106      DO k = 1, klev
107         DO i=1,klon
108         em_p(i,k) = pplay(i,k) / 100.0
109      ENDDO
110      ENDDO
111
112c
113      if (iflag_con .eq. 4) then
114      DO k = 1, klev
115        DO i = 1, klon
116         zx_t = t(i,k)
117         zdelta=MAX(0.,SIGN(1.,rtt-zx_t))
118         zx_qs= MIN(0.5 , r2es * FOEEW(zx_t,zdelta)/em_p(i,k)/100.0)
119         zcor=1./(1.-retv*zx_qs)
120         qs(i,k)=zx_qs*zcor
121        ENDDO
122      ENDDO
123      else ! iflag_con=3 (modif de puristes qui fait la diffce pour la convergence numerique)
124      DO k = 1, klev
125        DO i = 1, klon
126         zx_t = t(i,k)
127         zdelta=MAX(0.,SIGN(1.,rtt-zx_t))
128         zx_qs= r2es * FOEEW(zx_t,zdelta)/em_p(i,k)/100.0
129         zx_qs= MIN(0.5,zx_qs)
130         zcor=1./(1.-retv*zx_qs)
131         zx_qs=zx_qs*zcor
132         qs(i,k)=zx_qs
133        ENDDO
134      ENDDO
135      endif ! iflag_con
136c
137C------------------------------------------------------------------
138
139C Main driver for convection:
140C               iflag_con = 3  -> equivalent to convect3
141C               iflag_con = 4  -> equivalent to convect1/2
142
143      CALL cv_driver(klon,klev,klev+1,ntra,iflag_con,
144     :              t,q,qs,u,v,tra,
145     $              em_p,em_ph,iflag,
146     $              d_t,d_q,d_u,d_v,d_tra,rain,
147     $              cbmf,work1,work2,
148     $              dtime,Ma,upwd,dnwd,dnwdbis,qcondc,wd,cape)
149
150C------------------------------------------------------------------
151
152      DO i = 1,klon
153        rain(i) = rain(i)/86400.
154        rflag(i)=iflag(i)
155      ENDDO
156
157      DO k = 1, klev
158        DO i = 1, klon
159           d_t(i,k) = dtime*d_t(i,k)
160           d_q(i,k) = dtime*d_q(i,k)
161           d_u(i,k) = dtime*d_u(i,k)
162           d_v(i,k) = dtime*d_v(i,k)
163        ENDDO
164      ENDDO
165 
166c les traceurs ne sont pas mis dans cette version de convect4:
167      if (iflag_con.eq.4) then
168       DO itra = 1,ntra
169        DO k = 1, klev
170         DO i = 1, klon
171            d_tra(i,k,itra) = 0.
172         ENDDO
173        ENDDO
174       ENDDO
175      endif
176 
177      RETURN
178      END
179 
Note: See TracBrowser for help on using the repository browser.