source: LMDZ.3.3/branches/rel-LF/libf/phylmd/fisrtilp.F @ 986

Last change on this file since 986 was 546, checked in by lmdzadmin, 20 years ago

Suite des adaptations au portage sur SGI et VPP pour Prism (Caubel & Demory)
LF

  • Property svn:eol-style set to native
  • Property svn:executable set to *
  • Property svn:keywords set to Author Date Id Revision
File size: 16.1 KB
Line 
1c $Header$
2c
3      SUBROUTINE fisrtilp(dtime,paprs,pplay,t,q,ptconv,ratqs,
4     s                   d_t, d_q, d_ql, rneb, radliq, rain, snow,
5     s                   pfrac_impa, pfrac_nucl, pfrac_1nucl,
6     s                   frac_impa, frac_nucl,
7     s                   prfl, psfl, rhcl)
8
9c
10      IMPLICIT none
11c======================================================================
12c Auteur(s): Z.X. Li (LMD/CNRS)
13c Date: le 20 mars 1995
14c Objet: condensation et precipitation stratiforme.
15c        schema de nuage
16c======================================================================
17c======================================================================
18#include "dimensions.h"
19#include "dimphy.h"
20#include "YOMCST.h"
21#include "tracstoke.h"
22#include "fisrtilp.h"
23c
24c Arguments:
25c
26      REAL dtime ! intervalle du temps (s)
27      REAL paprs(klon,klev+1) ! pression a inter-couche
28      REAL pplay(klon,klev) ! pression au milieu de couche
29      REAL t(klon,klev) ! temperature (K)
30      REAL q(klon,klev) ! humidite specifique (kg/kg)
31      REAL d_t(klon,klev) ! incrementation de la temperature (K)
32      REAL d_q(klon,klev) ! incrementation de la vapeur d'eau
33      REAL d_ql(klon,klev) ! incrementation de l'eau liquide
34      REAL rneb(klon,klev) ! fraction nuageuse
35      REAL radliq(klon,klev) ! eau liquide utilisee dans rayonnements
36      REAL rhcl(klon,klev) ! humidite relative en ciel clair
37      REAL rain(klon) ! pluies (mm/s)
38      REAL snow(klon) ! neige (mm/s)
39      REAL prfl(klon,klev+1) ! flux d'eau precipitante aux interfaces (kg/m2/s)
40      REAL psfl(klon,klev+1) ! flux d'eau precipitante aux interfaces (kg/m2/s)
41cAA
42c Coeffients de fraction lessivee : pour OFF-LINE
43c
44      REAL pfrac_nucl(klon,klev)
45      REAL pfrac_1nucl(klon,klev)
46      REAL pfrac_impa(klon,klev)
47c
48c Fraction d'aerosols lessivee par impaction et par nucleation
49c POur ON-LINE
50c
51      REAL frac_impa(klon,klev)
52      REAL frac_nucl(klon,klev)
53      real zct(klon),zcl(klon)
54cAA
55c
56c Options du programme:
57c
58      REAL seuil_neb ! un nuage existe vraiment au-dela
59      PARAMETER (seuil_neb=0.001)
60
61      INTEGER ninter ! sous-intervals pour la precipitation
62      PARAMETER (ninter=5)
63      LOGICAL evap_prec ! evaporation de la pluie
64      PARAMETER (evap_prec=.TRUE.)
65      REAL ratqs(klon,klev) ! determine la largeur de distribution de vapeur
66      logical ptconv(klon,klev) ! determine la largeur de distribution de vapeur
67
68      real zpdf_sig(klon),zpdf_k(klon),zpdf_delta(klon)
69      real Zpdf_a(klon),zpdf_b(klon),zpdf_e1(klon),zpdf_e2(klon)
70      real erf
71c
72      LOGICAL cpartiel ! condensation partielle
73      PARAMETER (cpartiel=.TRUE.)
74      REAL t_coup
75      PARAMETER (t_coup=234.0)
76c
77c Variables locales:
78c
79      INTEGER i, k, n, kk
80      REAL zqs(klon), zdqs(klon), zdelta, zcor, zcvm5
81      REAL zrfl(klon), zrfln(klon), zqev, zqevt
82      REAL zoliq(klon), zcond(klon), zq(klon), zqn(klon), zdelq
83      REAL ztglace, zt(klon)
84      INTEGER nexpo ! exponentiel pour glace/eau
85      REAL zdz(klon),zrho(klon),ztot(klon), zrhol(klon)
86      REAL zchau(klon),zfroi(klon),zfice(klon),zneb(klon)
87c
88      LOGICAL appel1er
89      SAVE appel1er
90c
91c---------------------------------------------------------------
92c
93cAA Variables traceurs:
94cAA  Provisoire !!! Parametres alpha du lessivage
95cAA  A priori on a 4 scavenging # possibles
96c
97      REAL a_tr_sca(4)
98      save a_tr_sca
99c
100c Variables intermediaires
101c
102      REAL zalpha_tr
103      REAL zfrac_lessi
104      REAL zprec_cond(klon)
105cAA
106      REAL zmair, zcpair, zcpeau
107C     Pour la conversion eau-neige
108      REAL zlh_solid(klon), zm_solid
109cIM
110      INTEGER klevm1
111c---------------------------------------------------------------
112c
113c Fonctions en ligne:
114c
115      REAL fallvs,fallvc ! vitesse de chute pour crystaux de glace
116      REAL zzz
117#include "YOETHF.h"
118#include "FCTTRE.h"
119      fallvc (zzz) = 3.29/2.0 * ((zzz)**0.16) * ffallv_con
120      fallvs (zzz) = 3.29/2.0 * ((zzz)**0.16) * ffallv_lsc
121c
122      DATA appel1er /.TRUE./
123
124      IF (appel1er) THEN
125c
126         PRINT*, 'fisrtilp, ninter:', ninter
127         PRINT*, 'fisrtilp, evap_prec:', evap_prec
128         PRINT*, 'fisrtilp, cpartiel:', cpartiel
129         IF (ABS(dtime/FLOAT(ninter)-360.0).GT.0.001) THEN
130          PRINT*, 'fisrtilp: Ce n est pas prevu, voir Z.X.Li', dtime
131          PRINT*, 'Je prefere un sous-intervalle de 6 minutes'
132c         CALL abort
133         ENDIF
134         appel1er = .FALSE.
135c
136cAA initialiation provisoire
137       a_tr_sca(1) = -0.5
138       a_tr_sca(2) = -0.5
139       a_tr_sca(3) = -0.5
140       a_tr_sca(4) = -0.5
141c
142cAA Initialisation a 1 des coefs des fractions lessivees
143c
144      DO k = 1, klev
145       DO i = 1, klon
146          pfrac_nucl(i,k)=1.
147          pfrac_1nucl(i,k)=1.
148          pfrac_impa(i,k)=1.
149       ENDDO
150      ENDDO
151
152      ENDIF          !  test sur appel1er
153c
154cMAf Initialisation a 0 de zoliq
155       DO i = 1, klon
156          zoliq(i)=0.
157       ENDDO
158c Determiner les nuages froids par leur temperature
159c  nexpo regle la raideur de la transition eau liquide / eau glace.
160c
161      ztglace = RTT - 15.0
162      nexpo = 6
163ccc      nexpo = 1
164c
165c Initialiser les sorties:
166c
167      DO k = 1, klev+1
168      DO i = 1, klon
169         prfl(i,k) = 0.0
170         psfl(i,k) = 0.0
171      ENDDO
172      ENDDO
173
174      DO k = 1, klev
175      DO i = 1, klon
176         d_t(i,k) = 0.0
177         d_q(i,k) = 0.0
178         d_ql(i,k) = 0.0
179         rneb(i,k) = 0.0
180         radliq(i,k) = 0.0
181         frac_nucl(i,k) = 1.
182         frac_impa(i,k) = 1.
183      ENDDO
184      ENDDO
185      DO i = 1, klon
186         rain(i) = 0.0
187         snow(i) = 0.0
188      ENDDO
189c
190c Initialiser le flux de precipitation a zero
191c
192      DO i = 1, klon
193         zrfl(i) = 0.0
194         zneb(i) = seuil_neb
195      ENDDO
196c
197c
198cAA Pour plus de securite
199
200      zalpha_tr   = 0.
201      zfrac_lessi = 0.
202
203cAA----------------------------------------------------------
204c
205c Boucle verticale (du haut vers le bas)
206c
207cIM : klevm1
208      klevm1=klev-1
209      DO 9999 k = klev, 1, -1
210c
211cAA----------------------------------------------------------
212c
213      DO i = 1, klon
214         zt(i)=t(i,k)
215         zq(i)=q(i,k)
216      ENDDO
217c
218c Calculer la varition de temp. de l'air du a la chaleur sensible
219C transporter par la pluie.
220C Il resterait a rajouter cet effet de la chaleur sensible sur les
221C flux de surface, du a la diff. de temp. entre le 1er niveau et la
222C surface.
223C
224      DO i = 1, klon
225cIM
226       IF(k.LE.klevm1) THEN         
227        zmair=(paprs(i,k)-paprs(i,k+1))/RG
228        zcpair=RCPD*(1.0+RVTMP2*zq(i))
229        zcpeau=RCPD*RVTMP2
230        zt(i) = ( (t(i,k+1)+d_t(i,k+1))*zrfl(i)*dtime*zcpeau
231     $      + zmair*zcpair*zt(i) )
232     $      / (zmair*zcpair + zrfl(i)*dtime*zcpeau)
233CC        WRITE (6,*) 'cppluie ', zt(i)-(t(i,k+1)+d_t(i,k+1))
234       ENDIF
235      ENDDO
236c
237c
238c Calculer l'evaporation de la precipitation
239c
240
241
242      IF (evap_prec) THEN
243      DO i = 1, klon
244      IF (zrfl(i) .GT.0.) THEN
245         IF (thermcep) THEN
246           zdelta=MAX(0.,SIGN(1.,RTT-zt(i)))
247           zqs(i)= R2ES*FOEEW(zt(i),zdelta)/pplay(i,k)
248           zqs(i)=MIN(0.5,zqs(i))
249           zcor=1./(1.-RETV*zqs(i))
250           zqs(i)=zqs(i)*zcor
251         ELSE
252           IF (zt(i) .LT. t_coup) THEN
253              zqs(i) = qsats(zt(i)) / pplay(i,k)
254           ELSE
255              zqs(i) = qsatl(zt(i)) / pplay(i,k)
256           ENDIF
257         ENDIF
258         zqev = MAX (0.0, (zqs(i)-zq(i))*zneb(i) )
259         zqevt = coef_eva * (1.0-zq(i)/zqs(i)) * SQRT(zrfl(i))
260     .         * (paprs(i,k)-paprs(i,k+1))/pplay(i,k)*zt(i)*RD/RG
261         zqevt = MAX(0.0,MIN(zqevt,zrfl(i)))
262     .         * RG*dtime/(paprs(i,k)-paprs(i,k+1))
263         zqev = MIN (zqev, zqevt)
264         zrfln(i) = zrfl(i) - zqev*(paprs(i,k)-paprs(i,k+1))
265     .                            /RG/dtime
266
267c pour la glace, on réévapore toute la précip dans la couche du dessous
268c la glace venant de la couche du dessus est simplement dans la couche
269c du dessous.
270
271         IF (zt(i) .LT. t_coup.and.reevap_ice) zrfln(i)=0.
272
273         zq(i) = zq(i) - (zrfln(i)-zrfl(i))
274     .             * (RG/(paprs(i,k)-paprs(i,k+1)))*dtime
275         zt(i) = zt(i) + (zrfln(i)-zrfl(i))
276     .             * (RG/(paprs(i,k)-paprs(i,k+1)))*dtime
277     .             * RLVTT/RCPD/(1.0+RVTMP2*zq(i))
278         zrfl(i) = zrfln(i)
279      ENDIF
280      ENDDO
281      ENDIF
282c
283c Calculer Qs et L/Cp*dQs/dT:
284c
285      IF (thermcep) THEN
286         DO i = 1, klon
287           zdelta = MAX(0.,SIGN(1.,RTT-zt(i)))
288           zcvm5 = R5LES*RLVTT*(1.-zdelta) + R5IES*RLSTT*zdelta
289           zcvm5 = zcvm5 /RCPD/(1.0+RVTMP2*zq(i))
290           zqs(i) = R2ES*FOEEW(zt(i),zdelta)/pplay(i,k)
291           zqs(i) = MIN(0.5,zqs(i))
292           zcor = 1./(1.-RETV*zqs(i))
293           zqs(i) = zqs(i)*zcor
294           zdqs(i) = FOEDE(zt(i),zdelta,zcvm5,zqs(i),zcor)
295         ENDDO
296      ELSE
297         DO i = 1, klon
298            IF (zt(i).LT.t_coup) THEN
299               zqs(i) = qsats(zt(i))/pplay(i,k)
300               zdqs(i) = dqsats(zt(i),zqs(i))
301            ELSE
302               zqs(i) = qsatl(zt(i))/pplay(i,k)
303               zdqs(i) = dqsatl(zt(i),zqs(i))
304            ENDIF
305         ENDDO
306      ENDIF
307c
308c Determiner la condensation partielle et calculer la quantite
309c de l'eau condensee:
310c
311      IF (cpartiel) THEN
312
313c        print*,'Dans partiel k=',k
314c
315c   Calcul de l'eau condensee et de la fraction nuageuse et de l'eau
316c   nuageuse a partir des PDF de Sandrine Bony.
317c   rneb  : fraction nuageuse
318c   zqn   : eau totale dans le nuage
319c   zcond : eau condensee moyenne dans la maille.
320c           on prend en compte le réchauffement qui diminue la partie condensee
321c
322c   Version avec les raqts
323
324         if (iflag_pdf.eq.0) then
325
326           do i=1,klon
327            zdelq = min(ratqs(i,k),0.99) * zq(i)
328            rneb(i,k) = (zq(i)+zdelq-zqs(i)) / (2.0*zdelq)
329            zqn(i) = (zq(i)+zdelq+zqs(i))/2.0
330           enddo
331
332         else
333c
334c   Version avec les nouvelles PDFs.
335           do i=1,klon
336              if(zq(i).lt.1.e-15) then
337                print*,'ZQ(',i,',',k,')=',zq(i)
338                zq(i)=1.e-15
339              endif
340           enddo
341           do i=1,klon
342            zpdf_sig(i)=ratqs(i,k)*zq(i)
343            zpdf_k(i)=-sqrt(log(1.+(zpdf_sig(i)/zq(i))**2))
344            zpdf_delta(i)=log(zq(i)/zqs(i))
345            zpdf_a(i)=zpdf_delta(i)/(zpdf_k(i)*sqrt(2.))
346            zpdf_b(i)=zpdf_k(i)/(2.*sqrt(2.))
347            zpdf_e1(i)=zpdf_a(i)-zpdf_b(i)
348            zpdf_e1(i)=sign(min(abs(zpdf_e1(i)),5.),zpdf_e1(i))
349            zpdf_e1(i)=1.-erf(zpdf_e1(i))
350            zpdf_e2(i)=zpdf_a(i)+zpdf_b(i)
351            zpdf_e2(i)=sign(min(abs(zpdf_e2(i)),5.),zpdf_e2(i))
352            zpdf_e2(i)=1.-erf(zpdf_e2(i))
353            if (zpdf_e1(i).lt.1.e-10) then
354               rneb(i,k)=0.
355               zqn(i)=zqs(i)
356            else
357               rneb(i,k)=0.5*zpdf_e1(i)
358               zqn(i)=zq(i)*zpdf_e2(i)/zpdf_e1(i)
359            endif
360           
361           enddo
362
363        endif ! iflag_pdf
364
365         do i=1,klon
366            IF (rneb(i,k) .LE. 0.0) zqn(i) = 0.0
367            IF (rneb(i,k) .GE. 1.0) zqn(i) = zq(i)
368            rneb(i,k) = MAX(0.0,MIN(1.0,rneb(i,k)))
369c           zcond(i) = MAX(0.0,zqn(i)-zqs(i))*rneb(i,k)/(1.+zdqs(i))
370c  On ne divise pas par 1+zdqs pour forcer a avoir l'eau predite par
371c  la convection.
372c  ATTENTION !!! Il va falloir verifier tout ca.
373            zcond(i) = MAX(0.0,zqn(i)-zqs(i))*rneb(i,k)
374c           print*,'ZDQS ',zdqs(i)
375c--Olivier
376            zdelq = min(ratqs(i,k),0.99) * zq(i)
377            rhcl(i,k)=(zqs(i)+zq(i)-zdelq)/2./zqs(i)
378            IF (rneb(i,k) .LE. 0.0) rhcl(i,k)=zq(i)/zqs(i)
379            IF (rneb(i,k) .GE. 1.0) rhcl(i,k)=1.0
380c--fin
381           ENDDO
382      ELSE
383         DO i = 1, klon
384            IF (zq(i).GT.zqs(i)) THEN
385               rneb(i,k) = 1.0
386            ELSE
387               rneb(i,k) = 0.0
388            ENDIF
389            zcond(i) = MAX(0.0,zq(i)-zqs(i))/(1.+zdqs(i))
390         ENDDO
391      ENDIF
392c
393      DO i = 1, klon
394         zq(i) = zq(i) - zcond(i)
395c         zt(i) = zt(i) + zcond(i) * RLVTT/RCPD
396         zt(i) = zt(i) + zcond(i) * RLVTT/RCPD/(1.0+RVTMP2*zq(i))
397      ENDDO
398c
399c Partager l'eau condensee en precipitation et eau liquide nuageuse
400c
401      DO i = 1, klon
402      IF (rneb(i,k).GT.0.0) THEN
403         zoliq(i) = zcond(i)
404         zrho(i) = pplay(i,k) / zt(i) / RD
405         zdz(i) = (paprs(i,k)-paprs(i,k+1)) / (zrho(i)*RG)
406         zfice(i) = 1.0 - (zt(i)-ztglace) / (273.13-ztglace)
407         zfice(i) = MIN(MAX(zfice(i),0.0),1.0)
408         zfice(i) = zfice(i)**nexpo
409         zneb(i) = MAX(rneb(i,k), seuil_neb)
410         radliq(i,k) = zoliq(i)/FLOAT(ninter+1)
411      ENDIF
412      ENDDO
413c
414      DO n = 1, ninter
415      DO i = 1, klon
416      IF (rneb(i,k).GT.0.0) THEN
417         zrhol(i) = zrho(i) * zoliq(i) / zneb(i)
418
419         if (ptconv(i,k)) then
420            zcl(i)=cld_lc_con
421            zct(i)=1./cld_tau_con
422         else
423            zcl(i)=cld_lc_lsc
424            zct(i)=1./cld_tau_lsc
425         endif
426c  quantité d'eau à élminier.
427         zchau(i) = zct(i)*dtime/FLOAT(ninter) * zoliq(i)
428     .         *(1.0-EXP(-(zoliq(i)/zneb(i)/zcl(i))**2)) *(1.-zfice(i))
429c  meme chose pour la glace.
430         if (ptconv(i,k)) then
431            zfroi(i) = dtime/FLOAT(ninter)/zdz(i)*zoliq(i)
432     .              *fallvc(zrhol(i)) * zfice(i)
433         else
434            zfroi(i) = dtime/FLOAT(ninter)/zdz(i)*zoliq(i)
435     .              *fallvs(zrhol(i)) * zfice(i)
436         endif
437         ztot(i) = zchau(i) + zfroi(i)
438         IF (zneb(i).EQ.seuil_neb) ztot(i) = 0.0
439         ztot(i) = MIN(MAX(ztot(i),0.0),zoliq(i))
440         zoliq(i) = MAX(zoliq(i)-ztot(i), 0.0)
441         radliq(i,k) = radliq(i,k) + zoliq(i)/FLOAT(ninter+1)
442      ENDIF
443      ENDDO
444      ENDDO
445c
446      DO i = 1, klon
447      IF (rneb(i,k).GT.0.0) THEN
448         d_ql(i,k) = zoliq(i)
449         zrfl(i) = zrfl(i)+ MAX(zcond(i)-zoliq(i),0.0)
450     .                    * (paprs(i,k)-paprs(i,k+1))/(RG*dtime)
451      ENDIF
452      IF (zt(i).LT.RTT) THEN
453        psfl(i,k)=zrfl(i)
454      ELSE
455        prfl(i,k)=zrfl(i)
456      ENDIF
457      ENDDO
458c
459c Calculer les tendances de q et de t:
460c
461      DO i = 1, klon
462         d_q(i,k) = zq(i) - q(i,k)
463         d_t(i,k) = zt(i) - t(i,k)
464      ENDDO
465c
466cAA--------------- Calcul du lessivage stratiforme  -------------
467
468      DO i = 1,klon
469c
470         zprec_cond(i) = MAX(zcond(i)-zoliq(i),0.0)
471     .                * (paprs(i,k)-paprs(i,k+1))/RG
472         IF (rneb(i,k).GT.0.0.and.zprec_cond(i).gt.0.) THEN
473cAA lessivage nucleation LMD5 dans la couche elle-meme
474            if (t(i,k) .GE. ztglace) THEN
475               zalpha_tr = a_tr_sca(3)
476            else
477               zalpha_tr = a_tr_sca(4)
478            endif
479            zfrac_lessi = 1. - EXP(zalpha_tr*zprec_cond(i)/zneb(i))
480            pfrac_nucl(i,k)=pfrac_nucl(i,k)*(1.-zneb(i)*zfrac_lessi)
481            frac_nucl(i,k)= 1.-zneb(i)*zfrac_lessi
482c
483c nucleation avec un facteur -1 au lieu de -0.5
484            zfrac_lessi = 1. - EXP(-zprec_cond(i)/zneb(i))
485            pfrac_1nucl(i,k)=pfrac_1nucl(i,k)*(1.-zneb(i)*zfrac_lessi)
486         ENDIF
487c
488      ENDDO      ! boucle sur i
489c
490cAA Lessivage par impaction dans les couches en-dessous
491      DO kk = k-1, 1, -1
492        DO i = 1, klon
493          IF (rneb(i,k).GT.0.0.and.zprec_cond(i).gt.0.) THEN
494            if (t(i,kk) .GE. ztglace) THEN
495              zalpha_tr = a_tr_sca(1)
496            else
497              zalpha_tr = a_tr_sca(2)
498            endif
499            zfrac_lessi = 1. - EXP(zalpha_tr*zprec_cond(i)/zneb(i))
500            pfrac_impa(i,kk)=pfrac_impa(i,kk)*(1.-zneb(i)*zfrac_lessi)
501            frac_impa(i,kk)= 1.-zneb(i)*zfrac_lessi
502          ENDIF
503        ENDDO
504      ENDDO
505c
506cAA----------------------------------------------------------
507c                     FIN DE BOUCLE SUR K   
508 9999 CONTINUE
509c
510cAA-----------------------------------------------------------
511c
512c Pluie ou neige au sol selon la temperature de la 1ere couche
513c
514      DO i = 1, klon
515      IF ((t(i,1)+d_t(i,1)) .LT. RTT) THEN
516         snow(i) = zrfl(i)
517         zlh_solid(i) = RLSTT-RLVTT
518      ELSE
519         rain(i) = zrfl(i)
520         zlh_solid(i) = 0.
521      ENDIF
522      ENDDO
523C
524C For energy conservation : when snow is present, the solification
525c latent heat is considered.
526      DO k = 1, klev
527        DO i = 1, klon
528          zcpair=RCPD*(1.0+RVTMP2*(q(i,k)+d_q(i,k)))
529          zmair=(paprs(i,k)-paprs(i,k+1))/RG
530          zm_solid = (prfl(i,k)-prfl(i,k+1)+psfl(i,k)-psfl(i,k+1))*dtime
531          d_t(i,k) = d_t(i,k) + zlh_solid(i) *zm_solid / (zcpair*zmair)
532        END DO
533      END DO
534c
535      RETURN
536      END
Note: See TracBrowser for help on using the repository browser.