source: trunk/LMDZ.GENERIC/libf/dyn3d/nxgraro2.F @ 832

Last change on this file since 832 was 135, checked in by aslmd, 14 years ago

CHANGEMENT ARBORESCENCE ETAPE 2 -- NON COMPLET

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.