/[lmdze]/trunk/dyn3d/leapfrog.f90
ViewVC logotype

Diff of /trunk/dyn3d/leapfrog.f90

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

trunk/Sources/dyn3d/leapfrog.f revision 252 by guez, Mon Jan 22 15:02:56 2018 UTC trunk/dyn3d/leapfrog.f revision 325 by guez, Wed Mar 13 15:53:40 2019 UTC
# Line 9  contains Line 9  contains
9      ! From dyn3d/leapfrog.F, version 1.6, 2005/04/13 08:58:34 revision 616      ! From dyn3d/leapfrog.F, version 1.6, 2005/04/13 08:58:34 revision 616
10      ! Authors: P. Le Van, L. Fairhead, F. Hourdin      ! Authors: P. Le Van, L. Fairhead, F. Hourdin
11    
12      ! Intégration temporelle du modèle : Matsuno-leapfrog scheme.      ! Int\'egration temporelle du mod\`ele : Matsuno-leapfrog scheme.
13    
14      use addfi_m, only: addfi      use addfi_m, only: addfi
15      use bilan_dyn_m, only: bilan_dyn      use bilan_dyn_m, only: bilan_dyn
# Line 20  contains Line 20  contains
20      USE comgeom, ONLY: aire_2d, apoln, apols      USE comgeom, ONLY: aire_2d, apoln, apols
21      use covcont_m, only: covcont      use covcont_m, only: covcont
22      USE disvert_m, ONLY: ap, bp      USE disvert_m, ONLY: ap, bp
23      USE conf_gcm_m, ONLY: day_step, iconser, iperiod, iphysiq, nday, &      USE conf_gcm_m, ONLY: day_step, iconser, iperiod, iphysiq, nday, iflag_phys
          iflag_phys, iecri  
24      USE conf_guide_m, ONLY: ok_guide      USE conf_guide_m, ONLY: ok_guide
25      USE dimens_m, ONLY: iim, jjm, llm, nqmx      USE dimensions, ONLY: iim, jjm, llm, nqmx
26      use dissip_m, only: dissip      use dissip_m, only: dissip
27      USE dynetat0_m, ONLY: day_ini      USE dynetat0_m, ONLY: day_ini, itau_dyn
28      use dynredem1_m, only: dynredem1      use dynredem1_m, only: dynredem1
29      use enercin_m, only: enercin      use enercin_m, only: enercin
30      USE exner_hyb_m, ONLY: exner_hyb      USE exner_hyb_m, ONLY: exner_hyb
# Line 35  contains Line 34  contains
34      use inidissip_m, only: idissip      use inidissip_m, only: idissip
35      use integrd_m, only: integrd      use integrd_m, only: integrd
36      use nr_util, only: assert      use nr_util, only: assert
     USE temps, ONLY: itau_dyn  
     use writedynav_m, only: writedynav  
37      use writehist_m, only: writehist      use writehist_m, only: writehist
38    
     ! Variables dynamiques:  
39      REAL, intent(inout):: ucov(:, :, :) ! (iim + 1, jjm + 1, llm) vent covariant      REAL, intent(inout):: ucov(:, :, :) ! (iim + 1, jjm + 1, llm) vent covariant
40      REAL, intent(inout):: vcov(:, :, :) ! (iim + 1, jjm, llm) ! vent covariant      REAL, intent(inout):: vcov(:, :, :) ! (iim + 1, jjm, llm) ! vent covariant
41    
# Line 55  contains Line 51  contains
51    
52      ! Local:      ! Local:
53    
     ! Variables dynamiques:  
   
54      REAL pks(iim + 1, jjm + 1) ! exner au sol      REAL pks(iim + 1, jjm + 1) ! exner au sol
55      REAL pk(iim + 1, jjm + 1, llm) ! exner au milieu des couches      REAL pk(iim + 1, jjm + 1, llm) ! exner au milieu des couches
56      REAL pkf(iim + 1, jjm + 1, llm) ! exner filtr\'e au milieu des couches      REAL pkf(iim + 1, jjm + 1, llm) ! exner filtr\'e au milieu des couches
57      REAL phi(iim + 1, jjm + 1, llm) ! geopotential      REAL phi(iim + 1, jjm + 1, llm) ! geopotential
58      REAL w(iim + 1, jjm + 1, llm) ! vitesse verticale      REAL w(iim + 1, jjm + 1, llm) ! vitesse verticale
59    
60      ! Variables dynamiques intermediaire pour le transport      ! Variables dynamiques interm\'ediaires pour le transport
61      ! Flux de masse :      ! Flux de masse :
62      REAL pbaru(iim + 1, jjm + 1, llm), pbarv(iim + 1, jjm, llm)      REAL pbaru(iim + 1, jjm + 1, llm), pbarv(iim + 1, jjm, llm)
63    
# Line 73  contains Line 67  contains
67      REAL massem1(iim + 1, jjm + 1, llm)      REAL massem1(iim + 1, jjm + 1, llm)
68    
69      ! Tendances dynamiques      ! Tendances dynamiques
70      REAL dv((iim + 1) * jjm, llm), dudyn(iim + 1, jjm + 1, llm)      REAL dv((iim + 1) * jjm, llm), du(iim + 1, jjm + 1, llm)
71      REAL dteta(iim + 1, jjm + 1, llm)      REAL dteta(iim + 1, jjm + 1, llm)
72      real dp(iim + 1, jjm + 1)      real dp(iim + 1, jjm + 1)
73    
# Line 117  contains Line 111  contains
111    
112      time_integration: do itau = 0, itaufin - 1      time_integration: do itau = 0, itaufin - 1
113         leapf = mod(itau, iperiod) /= 0         leapf = mod(itau, iperiod) /= 0
114          
115         if (leapf) then         if (leapf) then
116            dt = 2 * dtvr            dt = 2 * dtvr
117         else         else
# Line 132  contains Line 127  contains
127    
128         ! Calcul des tendances dynamiques:         ! Calcul des tendances dynamiques:
129         CALL geopot(teta, pk, pks, phis, phi)         CALL geopot(teta, pk, pks, phis, phi)
130         CALL caldyn(itau, ucov, vcov, teta, ps, masse, pk, pkf, phis, phi, &         CALL caldyn(itau, ucov, vcov, teta, ps, masse, pk, pkf, phis, phi, du, &
131              dudyn, dv, dteta, dp, w, pbaru, pbarv, &              dv, dteta, dp, w, pbaru, pbarv, conser = MOD(itau, iconser) == 0)
             conser = MOD(itau, iconser) == 0)  
132    
133         CALL caladvtrac(q, pbaru, pbarv, p3d, masse, teta, pk)         CALL caladvtrac(q, pbaru, pbarv, p3d, masse, teta, pk)
134    
135         ! Int\'egrations dynamique et traceurs:         ! Int\'egrations dynamique et traceurs:
136         CALL integrd(vcovm1, ucovm1, tetam1, psm1, massem1, dv, dudyn, dteta, &         CALL integrd(vcovm1, ucovm1, tetam1, psm1, massem1, dv, du, dteta, dp, &
137              dp, vcov, ucov, teta, q(:, :, :, :2), ps, masse, dt, leapf)              vcov, ucov, teta, q(:, :, :, :2), ps, masse, dt, leapf)
138    
139         forall (l = 1: llm + 1) p3d(:, :, l) = ap(l) + bp(l) * ps         forall (l = 1: llm + 1) p3d(:, :, l) = ap(l) + bp(l) * ps
140         CALL exner_hyb(ps, p3d, pks, pk)         CALL exner_hyb(ps, p3d, pks, pk)
# Line 152  contains Line 146  contains
146            ! Calcul des tendances dynamiques:            ! Calcul des tendances dynamiques:
147            CALL geopot(teta, pk, pks, phis, phi)            CALL geopot(teta, pk, pks, phis, phi)
148            CALL caldyn(itau + 1, ucov, vcov, teta, ps, masse, pk, pkf, phis, &            CALL caldyn(itau + 1, ucov, vcov, teta, ps, masse, pk, pkf, phis, &
149                 phi, dudyn, dv, dteta, dp, w, pbaru, pbarv, conser = .false.)                 phi, du, dv, dteta, dp, w, pbaru, pbarv, conser = .false.)
150    
151            ! integrations dynamique et traceurs:            ! integrations dynamique et traceurs:
152            CALL integrd(vcovm1, ucovm1, tetam1, psm1, massem1, dv, dudyn, &            CALL integrd(vcovm1, ucovm1, tetam1, psm1, massem1, dv, du, dteta, &
153                 dteta, dp, vcov, ucov, teta, q(:, :, :, :2), ps, masse, dtvr, &                 dp, vcov, ucov, teta, q(:, :, :, :2), ps, masse, dtvr, &
154                 leapf=.false.)                 leapf=.false.)
155    
156            forall (l = 1: llm + 1) p3d(:, :, l) = ap(l) + bp(l) * ps            forall (l = 1: llm + 1) p3d(:, :, l) = ap(l) + bp(l) * ps
# Line 195  contains Line 189  contains
189    
190            ! Calcul de la valeur moyenne aux p\^oles :            ! Calcul de la valeur moyenne aux p\^oles :
191            forall (l = 1: llm)            forall (l = 1: llm)
192               teta(:, 1, l) = SUM(aire_2d(:iim, 1) * teta(:iim, 1, l)) &               teta(:, 1, l) = SUM(aire_2d(:iim, 1) * teta(:iim, 1, l)) / apoln
                   / apoln  
193               teta(:, jjm + 1, l) = SUM(aire_2d(:iim, jjm + 1) &               teta(:, jjm + 1, l) = SUM(aire_2d(:iim, jjm + 1) &
194                    * teta(:iim, jjm + 1, l)) / apols                    * teta(:iim, jjm + 1, l)) / apols
195            END forall            END forall
196         END IF         END IF
197    
198         IF (MOD(itau + 1, iperiod) == 0) THEN         IF (MOD(itau + 1, iperiod) == 0) THEN
           ! \'Ecriture du fichier histoire moyenne:  
           CALL writedynav(vcov, ucov, teta, pk, phi, q, masse, ps, phis, &  
                time = itau + 1)  
199            call bilan_dyn(ps, masse, pk, pbaru, pbarv, teta, phi, ucov, vcov, &            call bilan_dyn(ps, masse, pk, pbaru, pbarv, teta, phi, ucov, vcov, &
200                 q(:, :, :, 1))                 q(:, :, :, 1))
201         ENDIF         ENDIF
202    
203         IF (MOD(itau + 1, iecri * day_step) == 0) THEN         CALL geopot(teta, pk, pks, phis, phi)
204            CALL geopot(teta, pk, pks, phis, phi)         CALL writehist(vcov, ucov, teta, pk, phi, q, masse, ps, &
205            CALL writehist(itau, vcov, ucov, teta, phi, masse, ps)              itau_w = itau_dyn + itau + 1)
        END IF  
206      end do time_integration      end do time_integration
207    
208      CALL dynredem1(vcov, ucov, teta, q, masse, ps, itau = itau_dyn + itaufin)      CALL dynredem1(vcov, ucov, teta, q, masse, ps, itau = itau_dyn + itaufin)
209    
210      ! Calcul des tendances dynamiques:      ! Calcul des tendances dynamiques:
211      CALL geopot(teta, pk, pks, phis, phi)      CALL geopot(teta, pk, pks, phis, phi)
212      CALL caldyn(itaufin, ucov, vcov, teta, ps, masse, pk, pkf, phis, phi, &      CALL caldyn(itaufin, ucov, vcov, teta, ps, masse, pk, pkf, phis, phi, du, &
213           dudyn, dv, dteta, dp, w, pbaru, pbarv, &           dv, dteta, dp, w, pbaru, pbarv, conser = MOD(itaufin, iconser) == 0)
          conser = MOD(itaufin, iconser) == 0)  
214    
215    END SUBROUTINE leapfrog    END SUBROUTINE leapfrog
216    

Legend:
Removed from v.252  
changed lines
  Added in v.325

  ViewVC Help
Powered by ViewVC 1.1.21