source: LMDZ4/trunk/libf/phylmd/thermcell_dv2.F90 @ 970

Last change on this file since 970 was 938, checked in by lmdzadmin, 17 years ago

Enleve prints par defaut
IM

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 4.0 KB
Line 
1      subroutine thermcell_dv2(ngrid,nlay,ptimestep,fm,entr,masse  &
2     &    ,fraca,larga  &
3     &    ,u,v,du,dv,ua,va,lev_out)
4      implicit none
5
6#include "iniprint.h"
7!=======================================================================
8!
9!   Calcul du transport verticale dans la couche limite en presence
10!   de "thermiques" explicitement representes
11!   calcul du dq/dt une fois qu'on connait les ascendances
12!
13!=======================================================================
14
15
16      integer ngrid,nlay
17
18      real ptimestep
19      real masse(ngrid,nlay),fm(ngrid,nlay+1)
20      real fraca(ngrid,nlay+1)
21      real larga(ngrid)
22      real entr(ngrid,nlay)
23      real u(ngrid,nlay)
24      real ua(ngrid,nlay)
25      real du(ngrid,nlay)
26      real v(ngrid,nlay)
27      real va(ngrid,nlay)
28      real dv(ngrid,nlay)
29      integer lev_out                           ! niveau pour les print
30
31      real qa(ngrid,nlay),detr(ngrid,nlay),zf,zf2
32      real wvd(ngrid,nlay+1),wud(ngrid,nlay+1)
33      real gamma0,gamma(ngrid,nlay+1)
34      real ue(ngrid,nlay),ve(ngrid,nlay)
35      real dua,dva
36      integer iter
37
38      integer ig,k
39
40!   calcul du detrainement
41
42      do k=1,nlay
43         do ig=1,ngrid
44            detr(ig,k)=fm(ig,k)-fm(ig,k+1)+entr(ig,k)
45         enddo
46      enddo
47
48!   calcul de la valeur dans les ascendances
49      do ig=1,ngrid
50         ua(ig,1)=u(ig,1)
51         va(ig,1)=v(ig,1)
52         ue(ig,1)=u(ig,1)
53         ve(ig,1)=v(ig,1)
54      enddo
55
56      do k=2,nlay
57         do ig=1,ngrid
58            if ((fm(ig,k+1)+detr(ig,k))*ptimestep.gt.  &
59     &         1.e-5*masse(ig,k)) then
60!   On itère sur la valeur du coeff de freinage.
61!              gamma0=rho(ig,k)*(zlev(ig,k+1)-zlev(ig,k))
62               gamma0=masse(ig,k)  &
63     &         *sqrt( 0.5*(fraca(ig,k+1)+fraca(ig,k)) )  &
64     &         *0.5/larga(ig)  &
65     &         *1.
66!    s         *0.5
67!              gamma0=0.
68               zf=0.5*(fraca(ig,k)+fraca(ig,k+1))
69               zf=0.
70               zf2=1./(1.-zf)
71!   la première fois on multiplie le coefficient de freinage
72!   par le module du vent dans la couche en dessous.
73               dua=ua(ig,k-1)-u(ig,k-1)
74               dva=va(ig,k-1)-v(ig,k-1)
75               do iter=1,5
76!   On choisit une relaxation lineaire.
77                  gamma(ig,k)=gamma0
78!   On choisit une relaxation quadratique.
79                  gamma(ig,k)=gamma0*sqrt(dua**2+dva**2)
80                  ua(ig,k)=(fm(ig,k)*ua(ig,k-1)  &
81     &               +(zf2*entr(ig,k)+gamma(ig,k))*u(ig,k))  &
82     &               /(fm(ig,k+1)+detr(ig,k)+entr(ig,k)*zf*zf2  &
83     &                 +gamma(ig,k))
84                  va(ig,k)=(fm(ig,k)*va(ig,k-1)  &
85     &               +(zf2*entr(ig,k)+gamma(ig,k))*v(ig,k))  &
86     &               /(fm(ig,k+1)+detr(ig,k)+entr(ig,k)*zf*zf2  &
87     &                 +gamma(ig,k))
88!                 print*,k,ua(ig,k),va(ig,k),u(ig,k),v(ig,k),dua,dva
89                  dua=ua(ig,k)-u(ig,k)
90                  dva=va(ig,k)-v(ig,k)
91                  ue(ig,k)=(u(ig,k)-zf*ua(ig,k))*zf2
92                  ve(ig,k)=(v(ig,k)-zf*va(ig,k))*zf2
93               enddo
94            else
95               ua(ig,k)=u(ig,k)
96               va(ig,k)=v(ig,k)
97               ue(ig,k)=u(ig,k)
98               ve(ig,k)=v(ig,k)
99               gamma(ig,k)=0.
100            endif
101         enddo
102      enddo
103
104      do k=2,nlay
105         do ig=1,ngrid
106            wud(ig,k)=fm(ig,k)*ue(ig,k)
107            wvd(ig,k)=fm(ig,k)*ve(ig,k)
108         enddo
109      enddo
110      do ig=1,ngrid
111         wud(ig,1)=0.
112         wud(ig,nlay+1)=0.
113         wvd(ig,1)=0.
114         wvd(ig,nlay+1)=0.
115      enddo
116
117      do k=1,nlay
118         do ig=1,ngrid
119            du(ig,k)=((detr(ig,k)+gamma(ig,k))*ua(ig,k)  &
120     &               -(entr(ig,k)+gamma(ig,k))*ue(ig,k)  &
121     &               -wud(ig,k)+wud(ig,k+1))  &
122     &               /masse(ig,k)
123            dv(ig,k)=((detr(ig,k)+gamma(ig,k))*va(ig,k)  &
124     &               -(entr(ig,k)+gamma(ig,k))*ve(ig,k)  &
125     &               -wvd(ig,k)+wvd(ig,k+1))  &
126     &               /masse(ig,k)
127         enddo
128      enddo
129
130      return
131      end
Note: See TracBrowser for help on using the repository browser.