Changeset 2316


Ignore:
Timestamp:
May 12, 2020, 11:51:22 AM (5 years ago)
Author:
lrossi
Message:

Mars GCM:
Fixing some errors in vdifc_mod related to variable watercap. This variable was also integrated to the hdo cycle.
Also added watercap output for the 1D model.
LR

Location:
trunk/LMDZ.MARS
Files:
4 edited

Legend:

Unmodified
Added
Removed
  • trunk/LMDZ.MARS/README

    r2313 r2316  
    30143014Improved ergonomics of the user interface, with no more request to the user
    30153015in the midst of computations
     3016
     3017== 12/05/2020 == LR
     3018Fixing some errors in vdifc_mod related to variable watercap. This variable was also integrated to the hdo cycle.
     3019Also added watercap output for the 1D model.
  • trunk/LMDZ.MARS/libf/phymars/hdo_surfex_mod.F

    r2312 r2316  
    77      subroutine hdo_surfex(ngrid,nlay,nq,ptimestep,
    88     &                      zt,zq,pqsurf,
    9      &                      old_h2o_vap,pdqsdif,h2oflux,
     9     &                      old_h2o_vap,pdqsdif,dwatercap_dif,
    1010     &                      hdoflux)
    1111
     
    3737      REAL, INTENT(IN) :: old_h2o_vap(ngrid)     ! traceur d'eau avant
    3838                                           !traitement de l'eau (kg/kg)
     39      REAL, INTENT(IN) :: dwatercap_dif(ngrid)  ! trend related to permanent ice
    3940      REAL, INTENT(INOUT) :: pdqsdif(ngrid,nq)    ! tendance towards surface
    4041                                 !   (kg/kg.s-1)
    41       REAL, INTENT(IN) :: h2oflux(ngrid)       ! value of vapour flux of H2O
    42                                       ! same sign as pdqsdif
    4342
    4443c     Output:
     
    5150      REAL extrasublim ! sublimation in excess of surface ice
    5251      REAL tmpratio(ngrid)   ! D/H ratio in flux to surf
     52      REAL h2oflux(ngrid)       ! value of vapour flux of H2O
     53                                      ! same sign as pdqsdif
    5354
    5455      INTEGER ig,l
     
    6263
    6364        DO ig=1,ngrid
     65             
     66            h2oflux(ig) = pdqsdif(ig,igcm_h2o_ice) +
     67     &          dwatercap_dif(ig)
    6468
    6569            !! IF Sublimation
     
    8791     &           .gt.pqsurf(ig,igcm_h2o_ice)) then
    8892
    89 C               This is how much we sublimate in excess of
     93C               dwatercap_dif is how much we sublimate in excess of
    9094C               pqsurf for H2O                       
    91                   extrasublim=
    92      &              ( pqsurf(ig,igcm_h2o_ice) /ptimestep
    93      &                   +h2oflux(ig))
    94 c               extrasublim has same sign conv. as pdqsdif
    95  
    9695C               hdoflux(ig) is the flux of HDO from atm. to surf.
    9796c               The D/H of the old ice is supposed to be 5 SMOW
    9897c               We need D/H of the flux to be 5, so we need
    99 c               extrasublim* 5 * 2 * 155.76e-6 (=1 SMOW)
     98c               dwatercap_dif* 5 * 2 * 155.76e-6 (=1 SMOW)
    10099                    hdoflux(ig)= hdoflux(ig)
    101      &                       +(extrasublim*(2.*155.76e-6)*5.)
    102 !    &                       +extrasublim
    103 !                 hdoflux(ig) = h2oflux(ig) !test
    104               endif
    105                 endif ! watercap
     100     &                   +(dwatercap_dif(ig)*(2.*155.76e-6)*5.)
     101                endif
     102             endif ! watercap
    106103
    107104            else ! condensation
  • trunk/LMDZ.MARS/libf/phymars/physiq_mod.F

    r2312 r2316  
    36883688           end do
    36893689     
     3690        call WRITEDIAGFI(ngrid,"watercap","Water ice thickness"
     3691     &                                  ,"kg.m-2",0,watercap)
    36903692        call WRITEDIAGFI(ngrid,'zdqcloud_ice','cloud ice',
    36913693     &            'kg.m-2.s-1',1,zdqcloud(1,:,igcm_h2o_ice))
  • trunk/LMDZ.MARS/libf/phymars/vdifc_mod.F

    r2312 r2316  
    835835            CALL hdo_surfex(ngrid,nlay,nq,ptimestep,
    836836     &                      zt,zq,pqsurf,
    837      &                      old_h2o_vap,pdqsdif,h2oflux,
     837     &                      old_h2o_vap,pdqsdif,dwatercap_dif,
    838838     &                      hdoflux)
    839839            DO ig=1,ngrid
     
    879879                if(watercaptag(ig)) then
    880880c              dwatercap_dif same sign as pdqsdif (pos. toward ground)
    881                    dwatercap_dif(ig) = -pdqsdif(ig,igcm_h2o_ice)
    882      &                         - pqsurf(ig,igcm_h2o_ice)/ptimestep
     881                   dwatercap_dif(ig) = pdqsdif(ig,igcm_h2o_ice)
     882     &                         + pqsurf(ig,igcm_h2o_ice)/ptimestep
    883883                   pdqsdif(ig,igcm_h2o_ice)=
    884884     &                         -pqsurf(ig,igcm_h2o_ice)/ptimestep
     
    892892                   endif
    893893
    894                 endif   
    895894c                 write(*,*)'flux vers le sol=',pdqsdif(ig,nq)
    896895                  z1(ig)=1./(za(ig,1)+ zb(ig,2)*(1.-zd(ig,2)))
    897896                  zc(ig,1)=(za(ig,1)*zq(ig,1,igcm_h2o_vap)+
    898      $            zb(ig,2)*zc(ig,2) + (dwatercap_dif(ig)-
    899 c     $            zb(ig,2)*zc(ig,2) + (-
    900      $            pdqsdif(ig,igcm_h2o_ice)) *ptimestep) *z1(ig)
     897     $            zb(ig,2)*zc(ig,2) +
     898     $              (-pdqsdif(ig,igcm_h2o_ice)) *ptimestep) *z1(ig)
    901899                  zq1temp(ig)=zc(ig,1)
    902               endif ! if (.not.watercaptag(ig))
     900                endif  !if .not.watercaptag(ig)
     901              endif ! if sublim more than surface
     902
    903903c             Starting upward calculations for water :
    904904              zq(ig,1,igcm_h2o_vap)=zq1temp(ig)
     
    925925
    926926               if(pqsurf(ig,igcm_h2o_ice)
    927      &           +(dwatercap_dif(ig)+pdqsdif(ig,igcm_h2o_ice))*ptimestep
     927     &           +pdqsdif(ig,igcm_h2o_ice)*ptimestep
    928928     &           .gt.frost_albedo_threshold) ! if there is still ice, T cannot exceed To
    929929     &           pdtsrf(ig) = min(pdtsrf(ig),(To-ptsrf(ig))/ptimestep) ! ice melt case
Note: See TracChangeset for help on using the changeset viewer.