source: LMDZ4/branches/LMDZ4_par_0/libf/dyn3dpar/gradiv_p.F @ 4038

Last change on this file since 4038 was 630, checked in by Laurent Fairhead, 20 years ago

Import d'une version parallele de la dynamique YM
LF

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 2.1 KB
Line 
1      SUBROUTINE gradiv_p(klevel, xcov, ycov, ld, gdx, gdy )
2c
3c    Auteur :   P. Le Van
4c
5c   ***************************************************************
6c
7c                                ld
8c       calcul  de  (grad (div) )   du vect. v ....
9c
10c     xcov et ycov etant les composant.covariantes de v
11c   ****************************************************************
12c    xcov , ycov et ld  sont des arguments  d'entree pour le s-prog
13c     gdx   et  gdy     sont des arguments de sortie pour le s-prog
14c
15c     
16      USE parallel
17      USE times
18      IMPLICIT NONE
19c
20#include "dimensions.h"
21#include "paramet.h"
22#include "comdissipn.h"
23#include "logic.h"
24
25      INTEGER klevel
26c
27      REAL xcov( ip1jmp1,klevel ), ycov( ip1jm,klevel )
28      REAL gdx( ip1jmp1,klevel ),   gdy( ip1jm,klevel )
29
30      REAL div(ip1jmp1,llm)
31
32      INTEGER l,ij,iter,ld
33c
34      EXTERNAL   SCOPY, diverg,  grad
35      EXTERNAL   filtreg
36      INTEGER ijb,ije,jjb,jje
37c
38c
39c      CALL SCOPY( ip1jmp1*klevel,xcov,1,gdx,1 )
40c      CALL SCOPY( ip1jm*klevel,  ycov,1,gdy,1 )
41     
42      ijb=ij_begin
43      ije=ij_end
44      gdx(ijb:ije,1:klevel)=xcov(ijb:ije,1:klevel)
45
46      ijb=ij_begin
47      ije=ij_end
48      if(pole_sud) ije=ij_end-iip1
49      gdy(ijb:ije,1:klevel)=ycov(ijb:ije,1:klevel)
50     
51c
52      DO 10 iter = 1,ld
53     
54      call suspend_timer(timer_dissip)
55      call exchange_Hallo(gdy,ip1jm,llm,1,0)
56      call resume_timer(timer_dissip)
57     
58      CALL  diverg_p( klevel,  gdx , gdy, div          )
59     
60      jjb=jj_begin
61      jje=jj_end
62      CALL filtreg_p( div,jjb,jje, jjp1, klevel, 2,1, .true.,2 )
63     
64c      call exchange_Hallo(div,ip1jmp1,llm,0,1)
65     
66      call suspend_timer(timer_dissip)
67      call exchange_Hallo(div,ip1jmp1,llm,1,1)
68      call resume_timer(timer_dissip)
69     
70      CALL    grad_p( klevel,  div, gdx, gdy           )
71c
72      DO 5  l = 1, klevel
73     
74      if(pole_sud) ije=ij_end
75      DO 3 ij = ijb, ije
76        gdx( ij,l ) = - gdx( ij,l ) * cdivu
77   3  CONTINUE
78   
79      if(pole_sud) ije=ij_end-iip1
80      DO 4 ij = ijb, ije
81        gdy( ij,l ) = - gdy( ij,l ) * cdivu
82   4  CONTINUE
83
84   5  CONTINUE
85c
86  10  CONTINUE
87      RETURN
88      END
Note: See TracBrowser for help on using the repository browser.