GCC Code Coverage Report
Directory: ./ Exec Total Coverage
File: dyn3d/groupe.F Lines: 25 28 89.3 %
Date: 2023-06-30 12:56:34 Branches: 19 24 79.2 %

Line Branch Exec Source
1
!
2
! $Header$
3
!
4
288
      subroutine groupe(pext,pbaru,pbarv,pbarum,pbarvm,wm)
5
6
      use comconst_mod, only: ngroup
7
8
      implicit none
9
10
c   sous-programme servant a fitlrer les champs de flux de masse aux
11
c   poles en "regroupant" les mailles 2 par 2 puis 4 par 4 etc. au fur
12
c   et a mesure qu'on se rapproche du pole.
13
c
14
c   en entree: pext, pbaru et pbarv
15
c
16
c   en sortie:  pbarum,pbarvm et wm.
17
c
18
c   remarque, le wm est recalcule a partir des pbaru pbarv et on n'a donc
19
c   pas besoin de w en entree.
20
21
      include "dimensions.h"
22
      include "paramet.h"
23
      include "comgeom2.h"
24
25
!     integer ngroup
26
!     parameter (ngroup=3)
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
41
      logical firstcall,groupe_ok
42
      save firstcall,groupe_ok
43
44
      data firstcall/.true./
45
      data groupe_ok/.true./
46
47
      if (iim==1) then
48
         groupe_ok=.false.
49
      endif
50
51
288
      if (firstcall) then
52
1
         if (groupe_ok) then
53

1
            if(mod(iim,2**ngroup).ne.0)
54
     &        CALL abort_gcm('groupe','probleme du nombre de point',1)
55
         endif
56
1
         firstcall=.false.
57
      endif
58
59
60
c   Champs 1D
61
62
288
      call convflu(pbaru,pbarv,llm,zconvm)
63
64
288
      call scopy(ijp1llm,zconvm,1,zconvmm,1)
65
288
      call scopy(ijmllm,pbarv,1,pbarvm,1)
66
67
288
      if (groupe_ok) then
68
288
      call groupeun(jjp1,llm,zconvmm)
69
288
      call groupeun(jjm,llm,pbarvm)
70
71
c   Champs 3D
72
11520
      do l=1,llm
73
359712
         do j=2,jjm
74
348192
            uu=pbaru(iim,j,l)
75
11490336
            do i=1,iim
76
11142144
               uu=uu+pbarvm(i,j,l)-pbarvm(i,j-1,l)-zconvmm(i,j,l)
77
11490336
               pbarum(i,j,l)=uu
78
c     zconvm(i,j,l ) =  xflu(i-1,j,l)-xflu(i,j,l)+
79
c    *                      yflu(i,j,l)-yflu(i,j-1,l)
80
            enddo
81
359424
            pbarum(iip1,j,l)=pbarum(1,j,l)
82
         enddo
83
      enddo
84
85
      else
86
         pbarum(:,:,:)=pbaru(:,:,:)
87
         pbarvm(:,:,:)=pbarv(:,:,:)
88
      endif
89
90
c    integration de la convergence de masse de haut  en bas ......
91
      do l=1,llm
92
288
         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
11232
      do  l = llm-1,1,-1
99
372384
          do j=1,jjp1
100
12290112
             do i=1,iip1
101
12279168
                zconvmm(i,j,l)=zconvmm(i,j,l)+zconvmm(i,j,l+1)
102
             enddo
103
          enddo
104
      enddo
105
106
288
      CALL vitvert(zconvmm,wm)
107
108
288
      return
109
      end
110