source: LMDZ4/trunk/libf/phylmd/nflxtr.F @ 1040

Last change on this file since 1040 was 766, checked in by Laurent Fairhead, 17 years ago

Merge entre la version V3_conv et le HEAD
YM, JG, 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 nflxtr(pdtime,pmfu,pmfd,pen_u,pde_u,pen_d,pde_d,
5     .                 pplay,paprs,x,dx)
6      USE dimphy
7      IMPLICIT NONE
8c=====================================================================
9c Objet : Melange convectif de traceurs a partir des flux de masse
10c Date : 13/12/1996 -- 13/01/97
11c Auteur: O. Boucher (LOA) sur inspiration de Z. X. Li (LMD),
12c         Brinkop et Sausen (1996) et Boucher et al. (1996).
13c ATTENTION : meme si cette routine se veut la plus generale possible,
14c             elle a herite de certaines notations et conventions du
15c             schema de Tiedtke (1993).
16c --En particulier, les couches sont numerotees de haut en bas !!!
17c   Ceci est valable pour les flux
18c   mais pas pour les entrees x, pplay, paprs !!!!
19c --pmfu est positif, pmfd est negatif
20c --Tous les flux d'entrainements et de detrainements sont positifs
21c   contrairement au schema de Tiedtke d'ou les changements de signe!!!!
22c=====================================================================
23c
24cym#include "dimensions.h"
25cym#include "dimphy.h"
26#include "YOMCST.h"
27#include "YOECUMF.h"
28c
29      REAL pdtime
30c--les flux sont definis au 1/2 niveaux
31c--pmfu(klev+1) et pmfd(klev+1) sont implicitement nuls
32      REAL pmfu(klon,klev)  ! flux de masse dans le panache montant
33      REAL pmfd(klon,klev)  ! flux de masse dans le panache descendant
34      REAL pen_u(klon,klev) ! flux entraine dans le panache montant
35      REAL pde_u(klon,klev) ! flux detraine dans le panache montant
36      REAL pen_d(klon,klev) ! flux entraine dans le panache descendant
37      REAL pde_d(klon,klev) ! flux detraine dans le panache descendant
38
39      REAL pplay(klon,klev)    ! pression aux couches (bas en haut)
40      REAL paprs(klon,klev+1)  ! pression aux 1/2 couches (bas en haut)
41      REAL x(klon,klev)        ! q de traceur (bas en haut)
42      REAL dx(klon,klev)     ! tendance de traceur  (bas en haut)
43c
44c--flux convectifs mais en variables locales
45      REAL zmfu(klon,klev+1)
46      REAL zmfd(klon,klev+1)
47      REAL zen_u(klon,klev)
48      REAL zde_u(klon,klev)
49      REAL zen_d(klon,klev)
50      REAL zde_d(klon,klev)
51      real zmfe
52c
53c--variables locales     
54c--les flux de x sont definis aux 1/2 niveaux
55c--xu et xd sont definis aux niveaux complets
56      REAL xu(klon,klev)        ! q de traceurs dans le panache montant
57      REAL xd(klon,klev)        ! q de traceurs dans le panache descendant
58      REAL zmfux(klon,klev+1)   ! flux de x dans le panache montant
59      REAL zmfdx(klon,klev+1)   ! flux de x dans le panache descendant
60      REAL zmfex(klon,klev+1)   ! flux de x dans l'environnement
61      INTEGER i, k
62      REAL zmfmin
63      PARAMETER (zmfmin=1.E-10)
64
65c =========================================
66c
67c
68c   Extension des flux UP et DN sur klev+1 niveaux
69c =========================================
70      do k=1,klev
71         do i=1,klon
72            zmfu(i,k)=pmfu(i,k)
73            zmfd(i,k)=pmfd(i,k)
74         enddo
75      enddo
76      do i=1,klon
77         zmfu(i,klev+1)=0.
78         zmfd(i,klev+1)=0.
79      enddo
80
81c--modif pour diagnostiquer les detrainements
82c =========================================
83c   on privilegie l'ajustement de l'entrainement dans l'ascendance.
84
85      do k=1, klev
86         do i=1, klon
87            zen_d(i,k)=pen_d(i,k)
88            zde_u(i,k)=pde_u(i,k)
89            zde_d(i,k) =-zmfd(i,k+1)+zmfd(i,k)+zen_d(i,k)
90            zen_u(i,k) = zmfu(i,k+1)-zmfu(i,k)+zde_u(i,k)
91         enddo
92      enddo
93c
94c--calcul des flux dans le panache montant
95c =========================================
96c
97c Dans la premiere couche, on prend q comme valeur de qu
98c
99      do i=1, klon
100         zmfux(i,1)=0.0
101      enddo
102c
103c Autres couches
104      do k=1,klev
105         do i=1, klon
106            if ((zmfu(i,k+1)+zde_u(i,k)).lt.zmfmin) THEN
107               xu(i,k)=x(i,k)
108            else
109               xu(i,k)=(zmfux(i,k)+zen_u(i,k)*x(i,k))
110     s               /(zmfu(i,k+1)+zde_u(i,k))
111            endif
112            zmfux(i,k+1)=zmfu(i,k+1)*xu(i,k)
113         enddo
114      enddo
115c
116c--calcul des flux dans le panache descendant
117c =========================================
118c   
119      do i=1, klon
120         zmfdx(i,klev+1)=0.0
121      enddo
122c
123      do k=klev,1,-1
124         do i=1, klon
125            if ((zde_d(i,k)-zmfd(i,k)).lt.zmfmin) THEN
126               xd(i,k)=x(i,k)
127            else
128               xd(i,k)=(zmfdx(i,k+1)-zen_d(i,k)*x(i,k)) /
129     .               (zmfd(i,k)-zde_d(i,k))
130            endif
131            zmfdx(i,k)=zmfd(i,k)*xd(i,k)
132         enddo
133      enddo
134c
135c--introduction du flux de retour dans l'environnement
136c =========================================
137c
138      do k=2, klev
139         do i=1, klon
140            zmfe=-zmfu(i,k)-zmfd(i,k)
141            if (zmfe.le.0.) then
142               zmfex(i,k)= zmfe*x(i,k)
143            else
144               zmfex(i,k)= zmfe*x(i,k-1)
145            endif
146         enddo
147      enddo
148
149      do i=1, klon
150         zmfex(i,1)=0.
151         zmfex(i,klev+1)=0.
152      enddo
153c
154c--calcul final des tendances
155c
156      do k=1, klev
157         do i=1, klon
158            dx(i,k)=RG/(paprs(i,k)-paprs(i,k+1))*pdtime*
159     .                      ( zmfux(i,k) - zmfux(i,k+1) +
160     .                        zmfdx(i,k) - zmfdx(i,k+1) +
161     .                        zmfex(i,k) - zmfex(i,k+1) )
162         enddo
163      enddo
164c
165      return
166      end
Note: See TracBrowser for help on using the repository browser.