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

Diff of /trunk/dyn3d/leapfrog.f

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

revision 265 by guez, Tue Mar 20 09:35:59 2018 UTC revision 266 by guez, Thu Apr 19 17:54:55 2018 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 dimensions, ONLY: iim, jjm, llm, nqmx      USE dimensions, ONLY: iim, jjm, llm, nqmx
26      use dissip_m, only: dissip      use dissip_m, only: dissip
# Line 116  contains Line 115  contains
115    
116      time_integration: do itau = 0, itaufin - 1      time_integration: do itau = 0, itaufin - 1
117         leapf = mod(itau, iperiod) /= 0         leapf = mod(itau, iperiod) /= 0
118          
119         if (leapf) then         if (leapf) then
120            dt = 2 * dtvr            dt = 2 * dtvr
121         else         else
# Line 131  contains Line 131  contains
131    
132         ! Calcul des tendances dynamiques:         ! Calcul des tendances dynamiques:
133         CALL geopot(teta, pk, pks, phis, phi)         CALL geopot(teta, pk, pks, phis, phi)
134         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, &
135              du, dv, dteta, dp, w, pbaru, pbarv, &              dv, dteta, dp, w, pbaru, pbarv, conser = MOD(itau, iconser) == 0)
             conser = MOD(itau, iconser) == 0)  
136    
137         CALL caladvtrac(q, pbaru, pbarv, p3d, masse, teta, pk)         CALL caladvtrac(q, pbaru, pbarv, p3d, masse, teta, pk)
138    
139         ! Int\'egrations dynamique et traceurs:         ! Int\'egrations dynamique et traceurs:
140         CALL integrd(vcovm1, ucovm1, tetam1, psm1, massem1, dv, du, dteta, &         CALL integrd(vcovm1, ucovm1, tetam1, psm1, massem1, dv, du, dteta, dp, &
141              dp, vcov, ucov, teta, q(:, :, :, :2), ps, masse, dt, leapf)              vcov, ucov, teta, q(:, :, :, :2), ps, masse, dt, leapf)
142    
143         forall (l = 1: llm + 1) p3d(:, :, l) = ap(l) + bp(l) * ps         forall (l = 1: llm + 1) p3d(:, :, l) = ap(l) + bp(l) * ps
144         CALL exner_hyb(ps, p3d, pks, pk)         CALL exner_hyb(ps, p3d, pks, pk)
# Line 154  contains Line 153  contains
153                 phi, du, dv, dteta, dp, w, pbaru, pbarv, conser = .false.)                 phi, du, dv, dteta, dp, w, pbaru, pbarv, conser = .false.)
154    
155            ! integrations dynamique et traceurs:            ! integrations dynamique et traceurs:
156            CALL integrd(vcovm1, ucovm1, tetam1, psm1, massem1, dv, du, &            CALL integrd(vcovm1, ucovm1, tetam1, psm1, massem1, dv, du, dteta, &
157                 dteta, dp, vcov, ucov, teta, q(:, :, :, :2), ps, masse, dtvr, &                 dp, vcov, ucov, teta, q(:, :, :, :2), ps, masse, dtvr, &
158                 leapf=.false.)                 leapf=.false.)
159    
160            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 194  contains Line 193  contains
193    
194            ! Calcul de la valeur moyenne aux p\^oles :            ! Calcul de la valeur moyenne aux p\^oles :
195            forall (l = 1: llm)            forall (l = 1: llm)
196               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  
197               teta(:, jjm + 1, l) = SUM(aire_2d(:iim, jjm + 1) &               teta(:, jjm + 1, l) = SUM(aire_2d(:iim, jjm + 1) &
198                    * teta(:iim, jjm + 1, l)) / apols                    * teta(:iim, jjm + 1, l)) / apols
199            END forall            END forall
# Line 206  contains Line 204  contains
204                 q(:, :, :, 1))                 q(:, :, :, 1))
205         ENDIF         ENDIF
206    
207         IF (MOD(itau + 1, iecri) == 0) THEN         CALL geopot(teta, pk, pks, phis, phi)
208            CALL geopot(teta, pk, pks, phis, phi)         CALL writehist(vcov, ucov, teta, pk, phi, q, masse, ps, &
209            CALL writehist(vcov, ucov, teta, pk, phi, q, masse, ps, &              itau_w = itau_dyn + itau + 1)
                itau_w = itau_dyn + itau + 1)  
        END IF  
210      end do time_integration      end do time_integration
211    
212      CALL dynredem1(vcov, ucov, teta, q, masse, ps, itau = itau_dyn + itaufin)      CALL dynredem1(vcov, ucov, teta, q, masse, ps, itau = itau_dyn + itaufin)
213    
214      ! Calcul des tendances dynamiques:      ! Calcul des tendances dynamiques:
215      CALL geopot(teta, pk, pks, phis, phi)      CALL geopot(teta, pk, pks, phis, phi)
216      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, &
217           du, dv, dteta, dp, w, pbaru, pbarv, &           dv, dteta, dp, w, pbaru, pbarv, conser = MOD(itaufin, iconser) == 0)
          conser = MOD(itaufin, iconser) == 0)  
218    
219    END SUBROUTINE leapfrog    END SUBROUTINE leapfrog
220    

Legend:
Removed from v.265  
changed lines
  Added in v.266

  ViewVC Help
Powered by ViewVC 1.1.21