source: LMDZ6/trunk/libf/dyn3dmem/geopot_loc.f90 @ 5272

Last change on this file since 5272 was 5272, checked in by abarral, 3 months ago

Turn paramet.h into a module

  • 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
File size: 1.8 KB
Line 
1SUBROUTINE geopot_loc ( ngrid, teta, pk, pks, phis, phi )
2  USE parallel_lmdz
3  USE dimensions_mod, ONLY: iim, jjm, llm, ndm
4  USE paramet_mod_h, ONLY: iip1, iip2, iip3, jjp1, llmp1, llmp2, llmm1, kftd, ip1jm, ip1jmp1, &
5          ip1jmi1, ijp1llm, ijmllm, mvar, jcfil, jcfllm
6IMPLICIT NONE
7  !=======================================================================
8  !
9  !   Auteur:  P. Le Van
10  !   -------
11  !
12  !   Objet:
13  !   ------
14  !
15  !    *******************************************************************
16  !    ....   calcul du geopotentiel aux milieux des couches    .....
17  !    *******************************************************************
18  !
19  ! ....   l'integration se fait de bas en haut  ....
20  !
21  ! .. ngrid,teta,pk,pks,phis sont des argum. d'entree pour le s-pg ..
22  !          phi               est un  argum. de sortie pour le s-pg .
23  !
24  !=======================================================================
25  !-----------------------------------------------------------------------
26
27  !   Arguments:
28  !   ----------
29  INTEGER :: ngrid
30  REAL :: teta(ijb_u:ije_u,llm),pks(ijb_u:ije_u),phis(ijb_u:ije_u), &
31        pk(ijb_u:ije_u,llm) , phi(ijb_u:ije_u,llm)
32
33
34  !   Local:
35  !   ------
36
37  INTEGER :: l, ij,ijb,ije
38
39
40  !-----------------------------------------------------------------------
41  ! calcul de phi au niveau 1 pres du sol  .....
42  ijb=ij_begin
43  ije=ij_end+iip1
44
45  IF (pole_sud)  ije=ij_end
46
47  DO  ij  = ijb, ije
48  phi( ij,1 ) = phis( ij ) + teta(ij,1) * ( pks(ij) - pk(ij,1) )
49  ENDDO
50
51  ! calcul de phi aux niveaux superieurs  .......
52
53  DO  l = 2,llm
54    DO  ij    = ijb,ije
55    phi(ij,l) = phi(ij,l-1) + 0.5 * ( teta(ij,l)  + teta(ij,l-1) ) &
56          *   (  pk(ij,l-1) -  pk(ij,l)    )
57    ENDDO
58  ENDDO
59
60  RETURN
61END SUBROUTINE geopot_loc
Note: See TracBrowser for help on using the repository browser.