source: LMDZ4/trunk/libf/dyn3dpar/exner_hyb_p.F @ 1200

Last change on this file since 1200 was 985, checked in by Laurent Fairhead, 16 years ago

Mise a jour de dyn3dpar par rapport a dyn3d, inclusion OpenMP et filtre FFT YM
LF

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 4.1 KB
RevLine 
[630]1      SUBROUTINE  exner_hyb_p ( ngrid, ps, p,alpha,beta, pks, pk, pkf )
2c
3c     Auteurs :  P.Le Van  , Fr. Hourdin  .
4c    ..........
5c
6c    ....  ngrid, ps,p             sont des argum.d'entree  au sous-prog ...
7c    .... alpha,beta, pks,pk,pkf   sont des argum.de sortie au sous-prog ...
8c
9c   ************************************************************************
10c    Calcule la fonction d'Exner pk = Cp * p ** kappa , aux milieux des
11c    couches .   Pk(l) sera calcule aux milieux  des couches l ,entre les
12c    pressions p(l) et p(l+1) ,definis aux interfaces des llm couches .
13c   ************************************************************************
14c  .. N.B : Au sommet de l'atmosphere,  p(llm+1) = 0. , et ps et pks sont
15c    la pression et la fonction d'Exner  au  sol  .
16c
17c                                 -------- z                                   
18c    A partir des relations  ( 1 ) p*dz(pk) = kappa *pk*dz(p)      et
19c                            ( 2 ) pk(l) = alpha(l)+ beta(l)*pk(l-1)
20c    ( voir note de Fr.Hourdin )  ,
21c
22c    on determine successivement , du haut vers le bas des couches, les
23c    coef. alpha(llm),beta(llm) .,.,alpha(l),beta(l),,,alpha(2),beta(2),
24c    puis pk(ij,1). Ensuite ,on calcule,du bas vers le haut des couches, 
25c     pk(ij,l)  donne  par la relation (2),  pour l = 2 a l = llm .
26c
27c
28      USE parallel
29      IMPLICIT NONE
30c
31#include "dimensions.h"
32#include "paramet.h"
33#include "comconst.h"
34#include "comgeom.h"
35#include "comvert.h"
36#include "serre.h"
37
38      INTEGER  ngrid
39      REAL p(ngrid,llmp1),pk(ngrid,llm),pkf(ngrid,llm)
40      REAL ps(ngrid),pks(ngrid), alpha(ngrid,llm),beta(ngrid,llm)
41
42c    .... variables locales   ...
43
44      INTEGER l, ij
45      REAL unpl2k,dellta
46
47      REAL ppn(iim),pps(iim)
48      REAL xpn, xps
49      REAL SSUM
[764]50      EXTERNAL SSUM
[630]51      INTEGER ije,ijb,jje,jjb
52c
[985]53c$OMP BARRIER           
[630]54      unpl2k    = 1.+ 2.* kappa
55c
56      ijb=ij_begin
57      ije=ij_end
[774]58
[985]59c$OMP DO SCHEDULE(STATIC)
[630]60      DO   ij  = ijb, ije
61        pks(ij) = cpp * ( ps(ij)/preff ) ** kappa
62      ENDDO
[985]63c$OMP ENDDO
64c Synchro OPENMP ici
[630]65
[985]66c$OMP MASTER
[630]67      if (pole_nord) then
68        DO  ij   = 1, iim
69          ppn(ij) = aire(   ij   ) * pks(  ij     )
70        ENDDO
71        xpn      = SSUM(iim,ppn,1) /apoln
72 
73        DO ij   = 1, iip1
74          pks(   ij     )  =  xpn
75        ENDDO
76      endif
77     
78      if (pole_sud) then
79        DO  ij   = 1, iim
80          pps(ij) = aire(ij+ip1jm) * pks(ij+ip1jm )
81        ENDDO
82        xps      = SSUM(iim,pps,1) /apols
83 
84        DO ij   = 1, iip1
85          pks( ij+ip1jm )  =  xps
86        ENDDO
87      endif
[985]88c$OMP END MASTER
[630]89c
90c
91c    .... Calcul des coeff. alpha et beta  pour la couche l = llm ..
92c
[985]93c$OMP DO SCHEDULE(STATIC)
[630]94      DO     ij      = ijb,ije
95       alpha(ij,llm) = 0.
96       beta (ij,llm) = 1./ unpl2k
97      ENDDO
[985]98c$OMP ENDDO NOWAIT
[630]99c
100c     ... Calcul des coeff. alpha et beta  pour l = llm-1  a l = 2 ...
101c
102      DO l = llm -1 , 2 , -1
103c
[985]104c$OMP DO SCHEDULE(STATIC)
[630]105        DO ij = ijb, ije
106        dellta = p(ij,l)* unpl2k + p(ij,l+1)* ( beta(ij,l+1)-unpl2k )
107        alpha(ij,l)  = - p(ij,l+1) / dellta * alpha(ij,l+1)
108        beta (ij,l)  =   p(ij,l  ) / dellta   
109        ENDDO
[985]110c$OMP ENDDO NOWAIT
[630]111c
112      ENDDO
[774]113
[630]114c
115c  ***********************************************************************
116c     .....  Calcul de pk pour la couche 1 , pres du sol  ....
117c
[985]118c$OMP DO SCHEDULE(STATIC)
[630]119      DO   ij   = ijb, ije
120       pk(ij,1) = ( p(ij,1)*pks(ij) - 0.5*alpha(ij,2)*p(ij,2) )  /
121     *    (  p(ij,1)* (1.+kappa) + 0.5*( beta(ij,2)-unpl2k )* p(ij,2) )
122      ENDDO
[985]123c$OMP ENDDO NOWAIT
[630]124c
125c    ..... Calcul de pk(ij,l) , pour l = 2 a l = llm  ........
126c
127      DO l = 2, llm
[985]128c$OMP DO SCHEDULE(STATIC)
[630]129        DO   ij   = ijb, ije
130         pk(ij,l) = alpha(ij,l) + beta(ij,l) * pk(ij,l-1)
131        ENDDO
[985]132c$OMP ENDDO NOWAIT       
[630]133      ENDDO
134c
135c
136c      CALL SCOPY   ( ngrid * llm, pk, 1, pkf, 1 )
[985]137      DO l = 1, llm
138c$OMP DO SCHEDULE(STATIC)
139         DO   ij   = ijb, ije
140           pkf(ij,l)=pk(ij,l)
141         ENDDO
142c$OMP ENDDO NOWAIT             
143      ENDDO
144
[774]145c$OMP BARRIER
[630]146     
147      jjb=jj_begin
148      jje=jj_end
149      CALL filtreg_p ( pkf,jjb,jje, jmp1, llm, 2, 1, .TRUE., 1 )
150     
151
152      RETURN
153      END
Note: See TracBrowser for help on using the repository browser.