source: LMDZ6/trunk/libf/dyn3d_common/divergst.f90 @ 5440

Last change on this file since 5440 was 5285, checked in by abarral, 2 months ago

As discussed internally, remove generic ONLY: ... for new _mod_h modules

  • 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: 1.5 KB
RevLine 
[524]1!
2! $Header$
3!
[5246]4SUBROUTINE divergst(klevel,x,y,div)
[5281]5  USE comgeom_mod_h
[5271]6  USE dimensions_mod, ONLY: iim, jjm, llm, ndm
[5285]7  USE paramet_mod_h
[5272]8
[5246]9  IMPLICIT NONE
10  !
11  ! P. Le Van
12  !
13  !  ******************************************************************
14  !  ... calcule la divergence a tous les niveaux d'1 vecteur de compos. x et y...
15  !       x et y  etant des composantes contravariantes   ...
16  !  ****************************************************************
17  !  x  et  y  sont des arguments  d'entree pour le s-prog
18  !    div      est  un argument  de sortie pour le s-prog
19  !
20  !
21  !   -------------------------------------------------------------------
22  !
[524]23
[5246]24  INTEGER :: klevel
25  REAL :: x( ip1jmp1,klevel ),y( ip1jm,klevel ),div( ip1jmp1,klevel )
26  INTEGER :: ij,l,i
27  REAL :: aiy1( iip1 ) , aiy2( iip1 )
28  REAL :: sumypn,sumyps
[524]29
[5246]30  REAL :: SSUM
31  !
32  !
33  DO l = 1,klevel
34  !
35  DO ij = iip2, ip1jm - 1
36  div( ij + 1, l ) = x(ij+1,l) - x(ij,l)+ y(ij-iim,l)-y(ij+1,l)
37  END DO
38  !
39  ! ....  correction pour  div( 1,j,l)  ......
40  ! ....   div(1,j,l)= div(iip1,j,l) ....
41  !
42  !DIR$ IVDEP
43  DO ij = iip2,ip1jm,iip1
44  div( ij,l ) = div( ij + iim,l )
45  END DO
46  !
47  ! ....  calcul  aux poles  .....
48  !
49  !
50  DO i  = 1,iim
51  aiy1(i)= y(i,l)
52  aiy2(i)= y(i+ip1jmi1,l)
53  END DO
54  sumypn = SSUM ( iim,aiy1,1 )
55  sumyps = SSUM ( iim,aiy2,1 )
56  DO i = 1,iip1
57  div(     i    , l ) = - sumypn/iim
58  div( i + ip1jm, l ) =   sumyps/iim
59  END DO
60  !
61  END DO
62  RETURN
63END SUBROUTINE divergst
Note: See TracBrowser for help on using the repository browser.