/[lmdze]/trunk/phylmd/Interface_surf/clqh.f
ViewVC logotype

Diff of /trunk/phylmd/Interface_surf/clqh.f

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

revision 295 by guez, Thu Jul 26 13:23:28 2018 UTC revision 297 by guez, Thu Jul 26 16:02:11 2018 UTC
# Line 15  contains Line 15  contains
15      ! Objet : diffusion verticale de "q" et de "h"      ! Objet : diffusion verticale de "q" et de "h"
16    
17      use climb_hq_down_m, only: climb_hq_down      use climb_hq_down_m, only: climb_hq_down
18        use climb_hq_up_m, only: climb_hq_up
19      USE dimphy, ONLY: klev, klon      USE dimphy, ONLY: klev, klon
20      USE interfsurf_hq_m, ONLY: interfsurf_hq      USE interfsurf_hq_m, ONLY: interfsurf_hq
21      USE suphec_m, ONLY: rcpd      USE suphec_m, ONLY: rkappa
22    
23      REAL, intent(in):: dtime ! intervalle du temps (s)      REAL, intent(in):: dtime ! intervalle du temps (s)
24      integer, intent(in):: julien ! jour de l'annee en cours      integer, intent(in):: julien ! jour de l'annee en cours
# Line 102  contains Line 103  contains
103      INTEGER k      INTEGER k
104      REAL evap(size(knindex)) ! (knon) evaporation au sol      REAL evap(size(knindex)) ! (knon) evaporation au sol
105      REAL, dimension(size(knindex), klev):: cq, dq, ch, dh ! (knon, klev)      REAL, dimension(size(knindex), klev):: cq, dq, ch, dh ! (knon, klev)
     REAL h(size(knindex), klev) ! (knon, klev) enthalpie potentielle  
     REAL local_q(size(knindex), klev) ! (knon, klev)  
106      REAL pkf(size(knindex), klev) ! (knon, klev)      REAL pkf(size(knindex), klev) ! (knon, klev)
107      real tsurf_new(size(knindex)) ! (knon)      real tsurf_new(size(knindex)) ! (knon)
108    
109      !----------------------------------------------------------------      !----------------------------------------------------------------
110    
111        forall (k = 1:klev) pkf(:, k) = (paprs(:, 1) / pplay(:, k))**RKAPPA
112        ! (La pression de r\'ef\'erence est celle au sol.)
113    
114      call climb_hq_down(pkf, cq, dq, ch, dh, paprs, pplay, t, coef, dtime, &      call climb_hq_down(pkf, cq, dq, ch, dh, paprs, pplay, t, coef, dtime, &
115         delp, q)           delp, q)
116      CALL interfsurf_hq(dtime, julien, rmu0, nisurf, knindex, debut, tsoil, &      CALL interfsurf_hq(dtime, julien, rmu0, nisurf, knindex, debut, tsoil, &
117           qsol, u1lay, v1lay, t(:, 1), q(:, 1), tq_cdrag, ch(:, 1), cq(:, 1), &           qsol, u1lay, v1lay, t(:, 1), q(:, 1), tq_cdrag, ch(:, 1), cq(:, 1), &
118           dh(:, 1), dq(:, 1), precip_rain, precip_snow, rugos, rugoro, snow, &           dh(:, 1), dq(:, 1), precip_rain, precip_snow, rugos, rugoro, snow, &
119           qsurf, ts, pplay(:, 1), paprs(:, 1), radsol, evap, flux_t, fluxlat, &           qsurf, ts, pplay(:, 1), paprs(:, 1), radsol, evap, flux_t, fluxlat, &
120           dflux_l, dflux_s, tsurf_new, albedo, z0_new, pctsrf_new_sic, agesno, &           dflux_l, dflux_s, tsurf_new, albedo, z0_new, pctsrf_new_sic, agesno, &
121           fqcalving, ffonte, run_off_lic_0)           fqcalving, ffonte, run_off_lic_0)
   
122      flux_q = - evap      flux_q = - evap
123      d_ts = tsurf_new - ts      d_ts = tsurf_new - ts
124        call climb_hq_up(d_t, d_q, cq, dq, ch, dh, flux_t, flux_q, dtime, pkf, t, q)
     h(:, 1) = ch(:, 1) + dh(:, 1) * flux_t * dtime  
     local_q(:, 1) = cq(:, 1) + dq(:, 1) * flux_q * dtime  
   
     DO k = 2, klev  
        h(:, k) = ch(:, k) + dh(:, k) * h(:, k - 1)  
        local_q(:, k) = cq(:, k) + dq(:, k) * local_q(:, k - 1)  
     ENDDO  
   
     d_t = h / pkf / RCPD - t  
     d_q = local_q - q  
125    
126    END SUBROUTINE clqh    END SUBROUTINE clqh
127    

Legend:
Removed from v.295  
changed lines
  Added in v.297

  ViewVC Help
Powered by ViewVC 1.1.21