source: LMDZ6/trunk/libf/dyn3d/groupe.F @ 4490

Last change on this file since 4490 was 4470, checked in by Laurent Fairhead, 21 months ago

Replaced STOP instructions by calls to abort_gcm for a cleaner exit

  • Property copyright set to
    Name of program: LMDZ
    Creation date: 1984
    Version: LMDZ5
    License: CeCILL version 2
    Holder: Laboratoire de m\'et\'eorologie dynamique, CNRS, UMR 8539
    See the license file in the root directory
  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 2.5 KB
RevLine 
[524]1!
2! $Header$
3!
4      subroutine groupe(pext,pbaru,pbarv,pbarum,pbarvm,wm)
[2597]5     
6      use comconst_mod, only: ngroup
7     
[524]8      implicit none
9
10c   sous-programme servant a fitlrer les champs de flux de masse aux
11c   poles en "regroupant" les mailles 2 par 2 puis 4 par 4 etc. au fur
12c   et a mesure qu'on se rapproche du pole.
13c
14c   en entree: pext, pbaru et pbarv
15c
16c   en sortie:  pbarum,pbarvm et wm.
17c
18c   remarque, le wm est recalcule a partir des pbaru pbarv et on n'a donc
19c   pas besoin de w en entree.
20
[2597]21      include "dimensions.h"
22      include "paramet.h"
23      include "comgeom2.h"
[524]24
[2442]25!     integer ngroup
26!     parameter (ngroup=3)
[524]27
28
29      real pbaru(iip1,jjp1,llm),pbarv(iip1,jjm,llm)
30      real pext(iip1,jjp1,llm)
31
32      real pbarum(iip1,jjp1,llm),pbarvm(iip1,jjm,llm)
33      real wm(iip1,jjp1,llm)
34
35      real zconvm(iip1,jjp1,llm),zconvmm(iip1,jjp1,llm)
36
37      real uu
38
39      integer i,j,l
40
[1674]41      logical firstcall,groupe_ok
42      save firstcall,groupe_ok
[524]43
44      data firstcall/.true./
[1674]45      data groupe_ok/.true./
[524]46
[1674]47      if (iim==1) then
48         groupe_ok=.false.
49      endif
50
[524]51      if (firstcall) then
[1674]52         if (groupe_ok) then
[4470]53            if(mod(iim,2**ngroup).ne.0)         
54     &        CALL abort_gcm('groupe','probleme du nombre de point',1)
[1674]55         endif
[524]56         firstcall=.false.
57      endif
58
[1674]59
[524]60c   Champs 1D
61
62      call convflu(pbaru,pbarv,llm,zconvm)
63
64      call scopy(ijp1llm,zconvm,1,zconvmm,1)
65      call scopy(ijmllm,pbarv,1,pbarvm,1)
66
[1674]67      if (groupe_ok) then
[524]68      call groupeun(jjp1,llm,zconvmm)
69      call groupeun(jjm,llm,pbarvm)
70
71c   Champs 3D
72      do l=1,llm
73         do j=2,jjm
74            uu=pbaru(iim,j,l)
75            do i=1,iim
76               uu=uu+pbarvm(i,j,l)-pbarvm(i,j-1,l)-zconvmm(i,j,l)
77               pbarum(i,j,l)=uu
78c     zconvm(i,j,l ) =  xflu(i-1,j,l)-xflu(i,j,l)+
79c    *                      yflu(i,j,l)-yflu(i,j-1,l)
80            enddo
81            pbarum(iip1,j,l)=pbarum(1,j,l)
82         enddo
83      enddo
84
[1674]85      else
86         pbarum(:,:,:)=pbaru(:,:,:)
87         pbarvm(:,:,:)=pbarv(:,:,:)
88      endif
89
[524]90c    integration de la convergence de masse de haut  en bas ......
91      do l=1,llm
92         do j=1,jjp1
93            do i=1,iip1
94               zconvmm(i,j,l)=zconvmm(i,j,l)
95            enddo
96         enddo
97      enddo
98      do  l = llm-1,1,-1
99          do j=1,jjp1
100             do i=1,iip1
101                zconvmm(i,j,l)=zconvmm(i,j,l)+zconvmm(i,j,l+1)
102             enddo
103          enddo
104      enddo
105
106      CALL vitvert(zconvmm,wm)
107
108      return
109      end
110
Note: See TracBrowser for help on using the repository browser.