source: LMDZ.3.3/branches/rel-1-0-patch/libf/dyn3d/nxgraro2.F @ 988

Last change on this file since 988 was 2, checked in by lmdz, 25 years ago

Initial revision

  • Property svn:eol-style set to native
  • Property svn:executable set to *
  • Property svn:keywords set to Author Date Id Revision
File size: 1.8 KB
Line 
1       SUBROUTINE nxgraro2 (klevel,xcov, ycov, lr, grx, gry )
2c
3c      P.Le Van .
4c   ***********************************************************
5c                                 lr
6c      calcul de  ( nxgrad (rot) )   du vect. v  ....
7c
8c       xcov et ycov  etant les compos. covariantes de  v
9c   ***********************************************************
10c     xcov , ycov et lr  sont des arguments  d'entree pour le s-prog
11c      grx   et  gry     sont des arguments de sortie pour le s-prog
12c
13c
14      IMPLICIT NONE
15c
16#include "dimensions.h"
17#include "paramet.h"
18#include "comdissipn.h"
19c
20c    ......  variables en arguments  .......
21c
22      INTEGER klevel
23      REAL xcov( ip1jmp1,klevel ), ycov( ip1jm,klevel )
24      REAL  grx( ip1jmp1,klevel ),  gry( ip1jm,klevel )
25c
26c    ......   variables locales     ........
27c
28      REAL rot(ip1jm,llm) , signe, nugradrs
29      INTEGER l,ij,iter,lr
30c    ........................................................
31c
32      EXTERNAL    filtreg
33      EXTERNAL  SCOPY, rotatf, nxgrad, laplacien_rotgam
34c
35c
36      signe    = (-1.)**lr
37      nugradrs = signe * crot
38c
39      CALL SCOPY ( ip1jmp1* klevel, xcov, 1, grx, 1 )
40      CALL SCOPY (  ip1jm * klevel, ycov, 1, gry, 1 )
41c
42      CALL     rotatf     ( klevel, grx, gry, rot )
43c
44      CALL laplacien_rot ( klevel, rot, rot,grx,gry      )
45
46c
47c    .....   Iteration de l'operateur laplacien_rotgam  .....
48c
49      DO  iter = 1, lr -2
50        CALL laplacien_rotgam ( klevel, rot, rot )
51      ENDDO
52c
53c
54      CALL filtreg( rot, jjm, klevel, 2,1, .FALSE.,1)
55      CALL nxgrad ( klevel, rot, grx, gry )
56c
57      DO    l = 1, klevel
58         DO  ij = 1, ip1jm
59          gry( ij,l ) = gry( ij,l ) * nugradrs
60         ENDDO
61         DO  ij = 1, ip1jmp1
62          grx( ij,l ) = grx( ij,l ) * nugradrs
63         ENDDO
64      ENDDO
65c
66      RETURN
67      END
Note: See TracBrowser for help on using the repository browser.