source: LMDZ6/branches/Amaury_dev/libf/dyn3d/caldyn.F90 @ 5159

Last change on this file since 5159 was 5159, checked in by abarral, 7 weeks ago

Put dimensions.h and paramet.h into 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: 4.8 KB
Line 
1! $Id: caldyn.F90 5159 2024-08-02 19:58:25Z abarral $
2
3SUBROUTINE caldyn &
4        (itau, ucov, vcov, teta, ps, masse, pk, pkf, phis, &
5        phi, conser, du, dv, dteta, dp, w, pbaru, pbarv, time)
6
7  USE comvert_mod, ONLY: ap, bp
8  USE lmdz_comgeom
9
10  USE lmdz_dimensions, ONLY: iim, jjm, llm, ndm
11  USE lmdz_paramet
12  IMPLICIT NONE
13
14  !=======================================================================
15
16  !  Auteur :  P. Le Van
17
18  !   Objet:
19  !   ------
20
21  !   Calcul des tendances dynamiques.
22
23  ! Modif 04/93 F.Forget
24  !=======================================================================
25
26  !-----------------------------------------------------------------------
27  !   0. Declarations:
28  !   ----------------
29
30
31
32
33  !   Arguments:
34  !   ----------
35
36  LOGICAL, INTENT(IN) :: conser ! triggers printing some diagnostics
37  INTEGER, INTENT(IN) :: itau ! time step index
38  REAL, INTENT(IN) :: vcov(ip1jm, llm) ! covariant meridional wind
39  REAL, INTENT(IN) :: ucov(ip1jmp1, llm) ! covariant zonal wind
40  REAL, INTENT(IN) :: teta(ip1jmp1, llm) ! potential temperature
41  REAL, INTENT(IN) :: ps(ip1jmp1) ! surface pressure
42  REAL, INTENT(IN) :: phis(ip1jmp1) ! geopotential at the surface
43  REAL, INTENT(IN) :: pk(ip1jmp1, llm) ! Exner at mid-layer
44  REAL, INTENT(IN) :: pkf(ip1jmp1, llm) ! filtered Exner
45  REAL, INTENT(IN) :: phi(ip1jmp1, llm) ! geopotential
46  REAL, INTENT(OUT) :: masse(ip1jmp1, llm) ! air mass
47  REAL, INTENT(OUT) :: dv(ip1jm, llm) ! tendency on vcov
48  REAL, INTENT(OUT) :: du(ip1jmp1, llm) ! tendency on ucov
49  REAL, INTENT(OUT) :: dteta(ip1jmp1, llm) ! tenddency on teta
50  REAL, INTENT(OUT) :: dp(ip1jmp1) ! tendency on ps
51  REAL, INTENT(OUT) :: w(ip1jmp1, llm) ! vertical velocity
52  REAL, INTENT(OUT) :: pbaru(ip1jmp1, llm) ! mass flux in the zonal direction
53  REAL, INTENT(OUT) :: pbarv(ip1jm, llm) ! mass flux in the meridional direction
54  REAL, INTENT(IN) :: time ! current time
55
56  !   Local:
57  !   ------
58
59  REAL :: vcont(ip1jm, llm), ucont(ip1jmp1, llm)
60  REAL :: ang(ip1jmp1, llm), p(ip1jmp1, llmp1)
61  REAL :: massebx(ip1jmp1, llm), masseby(ip1jm, llm), psexbarxy(ip1jm)
62  REAL :: vorpot(ip1jm, llm)
63  REAL :: ecin(ip1jmp1, llm), convm(ip1jmp1, llm)
64  REAL :: bern(ip1jmp1, llm)
65  REAL :: massebxy(ip1jm, llm)
66
67  INTEGER :: ij, l
68
69  !-----------------------------------------------------------------------
70  !   Compute dynamical tendencies:
71  !--------------------------------
72
73  ! compute contravariant winds ucont() and vcont
74  CALL covcont  (llm, ucov, vcov, ucont, vcont)
75  ! compute pressure p()
76  CALL pression (ip1jmp1, ap, bp, ps, p)
77  ! compute psexbarxy() XY-area weighted-averaged surface pressure (what for?)
78  CALL psextbar (ps, psexbarxy)
79  ! compute mass in each atmospheric mesh: masse()
80  CALL massdair (p, masse)
81  ! compute X and Y-averages of mass, massebx() and masseby()
82  CALL massbar  (masse, massebx, masseby)
83  ! compute XY-average of mass, massebxy()
84  CALL massbarxy(masse, massebxy)
85  ! compute mass fluxes pbaru() and pbarv()
86  CALL flumass  (massebx, masseby, vcont, ucont, pbaru, pbarv)
87  ! compute dteta() , horizontal converging flux of theta
88  CALL dteta1   (teta, pbaru, pbarv, dteta)
89  ! compute convm(), horizontal converging flux of mass
90  CALL convmas  (pbaru, pbarv, convm)
91
92  ! compute pressure variation due to mass convergence
93  DO ij = 1, ip1jmp1
94    dp(ij) = convm(ij, 1) / airesurg(ij)
95  ENDDO
96
97  ! compute vertical velocity w()
98  CALL vitvert (convm, w)
99  ! compute potential vorticity vorpot()
100  CALL tourpot (vcov, ucov, massebxy, vorpot)
101  ! compute rotation induced du() and dv()
102  CALL dudv1   (vorpot, pbaru, pbarv, du, dv)
103  ! compute kinetic energy ecin()
104  CALL enercin (vcov, ucov, vcont, ucont, ecin)
105  ! compute Bernouilli function bern()
106  CALL bernoui (ip1jmp1, llm, phi, ecin, bern)
107  ! compute and add du() and dv() contributions from Bernouilli and pressure
108  CALL dudv2   (teta, pkf, bern, du, dv)
109
110  DO l = 1, llm
111    DO ij = 1, ip1jmp1
112      ang(ij, l) = ucov(ij, l) + constang(ij)
113    ENDDO
114  ENDDO
115
116  ! compute vertical advection contributions to du(), dv() and dteta()
117  CALL advect(ang, vcov, teta, w, massebx, masseby, du, dv, dteta)
118
119  !  WARNING probleme de peridocite de dv sur les PC/linux. Pb d'arrondi
120  ! probablement. Observe sur le code compile avec pgf90 3.0-1
121
122  DO l = 1, llm
123    DO ij = 1, ip1jm, iip1
124      IF(dv(ij, l)/=dv(ij + iim, l))  THEN
125        ! PRINT *,'!!!ATTENTION!!! probleme de periodicite sur vcov',
126        !    ,   ' dans caldyn'
127        ! PRINT *,' l,  ij = ', l, ij, ij+iim,dv(ij+iim,l),dv(ij,l)
128        dv(ij + iim, l) = dv(ij, l)
129      ENDIF
130    ENDDO
131  ENDDO
132
133  !-----------------------------------------------------------------------
134  !   Output some control variables:
135  !---------------------------------
136
137  IF(conser)  THEN
138    CALL sortvarc &
139            (itau, ucov, teta, ps, masse, pk, phis, vorpot, phi, bern, dp, time, vcov)
140  ENDIF
141
142END SUBROUTINE caldyn
Note: See TracBrowser for help on using the repository browser.