/[lmdze]/trunk/Sources/phylmd/phystokenc.f
ViewVC logotype

Diff of /trunk/Sources/phylmd/phystokenc.f

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

trunk/libf/phylmd/phystokenc.f90 revision 61 by guez, Fri Apr 20 14:58:43 2012 UTC trunk/Sources/phylmd/phystokenc.f revision 134 by guez, Wed Apr 29 15:47:56 2015 UTC
# Line 10  contains Line 10  contains
10    
11      ! From phylmd/phystokenc.F, version 1.2 2004/06/22 11:45:35      ! From phylmd/phystokenc.F, version 1.2 2004/06/22 11:45:35
12      ! Author: Frédéric Hourdin      ! Author: Frédéric Hourdin
13      ! Objet: moniteur général des tendances traceurs                              ! Objet : écriture des variables pour transport offline
14    
15      USE histwrite_m, ONLY : histwrite      USE histwrite_m, ONLY: histwrite
16      USE histsync_m, ONLY : histsync      USE histsync_m, ONLY: histsync
17      USE dimens_m, ONLY : iim, jjm, nqmx      USE dimens_m, ONLY: iim, jjm, nqmx
18      USE indicesol, ONLY : nbsrf      USE indicesol, ONLY: nbsrf
19      USE dimphy, ONLY : klev, klon      USE dimphy, ONLY: klev, klon
20      USE tracstoke, ONLY : istphy      USE tracstoke, ONLY: istphy
21    
22      ! Arguments:                                                                  REAL, INTENT (IN):: pdtphys ! pas d'integration pour la physique (seconde)
23        REAL, INTENT (IN):: rlon(klon), rlat(klon)
24        REAL, intent(in):: pt(klon, klev)
25    
26      !   EN ENTREE:                                                                ! convection:
27    
28      !   divers:                                                                  REAL, INTENT (IN):: pmfu(klon, klev) ! flux de masse dans le panache montant
29    
30      REAL, INTENT (IN) :: pdtphys ! pas d'integration pour la physique (seconde)      REAL, intent(in):: pmfd(klon, klev)
31      INTEGER, INTENT (IN) :: itap      ! flux de masse dans le panache descendant
32    
33      !   convection:                                                              REAL, intent(in):: pen_u(klon, klev) ! flux entraine dans le panache montant
34        REAL, intent(in):: pde_u(klon, klev) ! flux detraine dans le panache montant
35    
36      REAL pmfu(klon, klev) ! flux de masse dans le panache montant      REAL, intent(in):: pen_d(klon, klev)
37      REAL pmfd(klon, klev) ! flux de masse dans le panache descendant      ! flux entraine dans le panache descendant
     REAL pen_u(klon, klev) ! flux entraine dans le panache montant  
     REAL pde_u(klon, klev) ! flux detraine dans le panache montant  
     REAL pen_d(klon, klev) ! flux entraine dans le panache descendant  
     REAL pde_d(klon, klev) ! flux detraine dans le panache descendant  
     REAL, intent(in):: pt(klon, klev)  
38    
39      REAL, INTENT (IN) :: rlon(klon), rlat(klon)      REAL, intent(in):: pde_d(klon, klev)
40      REAL, INTENT (IN) :: dtime      ! flux detraine dans le panache descendant
41    
42      !   Les Thermiques      ! Les Thermiques
43      REAL pfm_therm(klon, klev+1)      REAL pfm_therm(klon, klev+1)
44      REAL pentr_therm(klon, klev)      REAL pentr_therm(klon, klev)
45    
46      !   Couche limite:                                                            ! Couche limite:
47    
     REAL yv1(klon)  
     REAL yu1(klon), paire(klon)  
     REAL, INTENT(IN):: pphis(klon)  
48      REAL pcoefh(klon, klev) ! coeff melange Couche limite      REAL pcoefh(klon, klev) ! coeff melange Couche limite
49        REAL yu1(klon)
50        REAL yv1(klon)
51    
52      ! Arguments necessaires pour les sources et puits de traceur                  ! Arguments necessaires pour les sources et puits de traceur
53    
54      REAL ftsol(klon, nbsrf) ! Temperature du sol (surf)(Kelvin)      REAL ftsol(klon, nbsrf) ! Temperature du sol (surf)(Kelvin)
55      REAL pctsrf(klon, nbsrf) ! Pourcentage de sol f(nature du sol)      REAL pctsrf(klon, nbsrf) ! Pourcentage de sol f(nature du sol)
56    
57      !   Lessivage:                                                                ! Lessivage:
58    
59      REAL frac_impa(klon, klev)      REAL frac_impa(klon, klev)
60      REAL frac_nucl(klon, klev)      REAL frac_nucl(klon, klev)
61    
62        REAL, INTENT(IN):: pphis(klon)
63        real paire(klon)
64        REAL, INTENT (IN):: dtime
65        INTEGER, INTENT (IN):: itap
66    
67      ! Variables local to the procedure:      ! Variables local to the procedure:
68    
69      real t(klon, klev)      real t(klon, klev)
70      INTEGER, SAVE:: physid      INTEGER, SAVE:: physid
71      REAL zx_tmp_3d(iim, jjm+1, klev), zx_tmp_2d(iim, jjm+1)      REAL zx_tmp_3d(iim, jjm+1, klev), zx_tmp_2d(iim, jjm+1)
72    
73      !   Les Thermiques      ! Les Thermiques
74    
75      REAL fm_therm1(klon, klev)      REAL fm_therm1(klon, klev)
76      REAL entr_therm(klon, klev)      REAL entr_therm(klon, klev)
# Line 76  contains Line 78  contains
78    
79      INTEGER i, k      INTEGER i, k
80    
81      REAL mfu(klon, klev) ! flux de masse dans le panache montant      REAL, save:: mfu(klon, klev) ! flux de masse dans le panache montant
82      REAL mfd(klon, klev) ! flux de masse dans le panache descendant      REAL mfd(klon, klev) ! flux de masse dans le panache descendant
83      REAL en_u(klon, klev) ! flux entraine dans le panache montant      REAL en_u(klon, klev) ! flux entraine dans le panache montant
84      REAL de_u(klon, klev) ! flux detraine dans le panache montant      REAL de_u(klon, klev) ! flux detraine dans le panache montant
# Line 91  contains Line 93  contains
93    
94      REAL dtcum      REAL dtcum
95    
96      INTEGER iadvtr, irec      INTEGER:: iadvtr = 0, irec = 1
97      REAL zmin, zmax      REAL zmin, zmax
98      LOGICAL ok_sync      LOGICAL ok_sync
99    
100      SAVE t, mfu, mfd, en_u, de_u, en_d, de_d, coefh, dtcum      SAVE t, mfd, en_u, de_u, en_d, de_d, coefh, dtcum
101      SAVE fm_therm, entr_therm      SAVE fm_therm, entr_therm
     SAVE iadvtr, irec  
102      SAVE pyu1, pyv1, pftsol, ppsrf      SAVE pyu1, pyv1, pftsol, ppsrf
103    
     DATA iadvtr, irec/0, 1/  
   
104      !------------------------------------------------------      !------------------------------------------------------
105    
106      !   Couche limite:                                                            ! Couche limite:
107    
108      ok_sync = .TRUE.      ok_sync = .TRUE.
109    
# Line 123  contains Line 122  contains
122    
123      iadvtr = iadvtr + 1      iadvtr = iadvtr + 1
124    
125      IF (mod(iadvtr, istphy)==1 .OR. istphy==1) THEN      IF (mod(iadvtr, istphy) == 1 .OR. istphy == 1) THEN
126         PRINT *, 'reinitialisation des champs cumules a iadvtr=', iadvtr         PRINT *, 'reinitialisation des champs cumules a iadvtr =', iadvtr
127         DO k = 1, klev         DO k = 1, klev
128            DO i = 1, klon            DO i = 1, klon
129               mfu(i, k) = 0.               mfu(i, k) = 0.
# Line 180  contains Line 179  contains
179    
180      dtcum = dtcum + pdtphys      dtcum = dtcum + pdtphys
181    
182      IF (mod(iadvtr, istphy)==0) THEN      IF (mod(iadvtr, istphy) == 0) THEN
183         !   normalisation par le temps cumule                                           ! normalisation par le temps cumule
184         DO k = 1, klev         DO k = 1, klev
185            DO i = 1, klon            DO i = 1, klon
186               mfu(i, k) = mfu(i, k)/dtcum               mfu(i, k) = mfu(i, k)/dtcum
# Line 214  contains Line 213  contains
213               ppsrf2(i) = ppsrf(i, 2)               ppsrf2(i) = ppsrf(i, 2)
214               ppsrf3(i) = ppsrf(i, 3)               ppsrf3(i) = ppsrf(i, 3)
215               ppsrf4(i) = ppsrf(i, 4)               ppsrf4(i) = ppsrf(i, 4)
   
216            END DO            END DO
217         END DO         END DO
218    
219         !   ecriture des champs                                                         ! ecriture des champs
220    
221         irec = irec + 1         irec = irec + 1
222    
        !cccc                                                                    
223         CALL gr_fi_ecrit(klev, klon, iim, jjm+1, t, zx_tmp_3d)         CALL gr_fi_ecrit(klev, klon, iim, jjm+1, t, zx_tmp_3d)
224         CALL histwrite(physid, 't', itap, zx_tmp_3d)         CALL histwrite(physid, 't', itap, zx_tmp_3d)
225    
# Line 241  contains Line 238  contains
238         CALL gr_fi_ecrit(klev, klon, iim, jjm+1, coefh, zx_tmp_3d)         CALL gr_fi_ecrit(klev, klon, iim, jjm+1, coefh, zx_tmp_3d)
239         CALL histwrite(physid, 'coefh', itap, zx_tmp_3d)         CALL histwrite(physid, 'coefh', itap, zx_tmp_3d)
240    
        ! ajou...                                                                
241         DO k = 1, klev         DO k = 1, klev
242            DO i = 1, klon            DO i = 1, klon
243               fm_therm1(i, k) = fm_therm(i, k)               fm_therm1(i, k) = fm_therm(i, k)
# Line 253  contains Line 249  contains
249    
250         CALL gr_fi_ecrit(klev, klon, iim, jjm+1, entr_therm, zx_tmp_3d)         CALL gr_fi_ecrit(klev, klon, iim, jjm+1, entr_therm, zx_tmp_3d)
251         CALL histwrite(physid, 'en_th', itap, zx_tmp_3d)         CALL histwrite(physid, 'en_th', itap, zx_tmp_3d)
252         !ccc                                                                             !ccc
253         CALL gr_fi_ecrit(klev, klon, iim, jjm+1, frac_impa, zx_tmp_3d)         CALL gr_fi_ecrit(klev, klon, iim, jjm+1, frac_impa, zx_tmp_3d)
254         CALL histwrite(physid, 'frac_impa', itap, zx_tmp_3d)         CALL histwrite(physid, 'frac_impa', itap, zx_tmp_3d)
255    
# Line 285  contains Line 281  contains
281         CALL histwrite(physid, 'psrf4', itap, zx_tmp_2d)         CALL histwrite(physid, 'psrf4', itap, zx_tmp_2d)
282    
283         IF (ok_sync) CALL histsync(physid)         IF (ok_sync) CALL histsync(physid)
        !     if (ok_sync) call histsync                                          
284    
285           ! Test sur la valeur des coefficients de lessivage
        !AA Test sur la valeur des coefficients de lessivage                      
286    
287         zmin = 1E33         zmin = 1E33
288         zmax = -1E33         zmax = -1E33
# Line 298  contains Line 292  contains
292               zmin = min(zmin, frac_nucl(i, k))               zmin = min(zmin, frac_nucl(i, k))
293            END DO            END DO
294         END DO         END DO
295         PRINT *, '------ coefs de lessivage (min et max) --------'         PRINT *, 'coefs de lessivage (min et max)'
296         PRINT *, 'facteur de nucleation ', zmin, zmax         PRINT *, 'facteur de nucleation ', zmin, zmax
297         zmin = 1E33         zmin = 1E33
298         zmax = -1E33         zmax = -1E33
# Line 309  contains Line 303  contains
303            END DO            END DO
304         END DO         END DO
305         PRINT *, 'facteur d impaction ', zmin, zmax         PRINT *, 'facteur d impaction ', zmin, zmax
   
306      END IF      END IF
307    
308    END SUBROUTINE phystokenc    END SUBROUTINE phystokenc

Legend:
Removed from v.61  
changed lines
  Added in v.134

  ViewVC Help
Powered by ViewVC 1.1.21