Changeset 2184 for trunk/LMDZ.MARS/libf


Ignore:
Timestamp:
Dec 4, 2019, 7:29:38 PM (5 years ago)
Author:
abierjon
Message:

Mars GCM:
Add the instantaneous scavenging by CO2 of dust, ccn and water ice in co2condens_mod. It can be activated or deactivated with the new flag "scavco2cond" (=false by default). Expected to be replaced by the CO2 clouds microphysics in the future.
AB

Location:
trunk/LMDZ.MARS/libf/phymars
Files:
3 edited

Legend:

Unmodified
Added
Removed
  • trunk/LMDZ.MARS/libf/phymars/co2condens_mod.F

    r2155 r2184  
    33      IMPLICIT NONE
    44
     5      logical, save :: scavco2cond = .false. ! flag for using scavenging_by_co2
     6     
    57      CONTAINS
    68
     
    810     $                  pcapcal,pplay,pplev,ptsrf,pt,
    911     $                  pphi,pdt,pdu,pdv,pdtsrf,pu,pv,pq,pdq,
    10      $                  piceco2,psolaralb,pemisurf,
     12     $                  piceco2,psolaralb,pemisurf,rdust,
    1113     $                  pdtc,pdtsrfc,pdpsrf,pduc,pdvc,pdqc,
    1214     $                  fluxsurf_sw,zls,
    1315     $                  zdqssed_co2,pcondicea_co2microp,
    14      $                  zdtcloudco2)
     16     $                  zdtcloudco2,pdqsc)
    1517                                                   
    16        use tracer_mod, only: noms
     18       use tracer_mod, only: noms, igcm_h2o_ice,
     19     &                      igcm_dust_mass, igcm_dust_number,
     20     &                      igcm_ccn_mass, igcm_ccn_number
    1721       use surfdat_h, only: emissiv, phisfi
    1822       use geometry_mod, only: latitude, ! grid point latitudes (rad)
     
    2024       use planete_h, only: obliquit
    2125       use comcstfi_h, only: cpp, g, r, pi
     26       
    2227#ifndef MESOSCALE
    2328       USE vertical_layers_mod, ONLY: ap, bp
     
    7782      REAL,INTENT(INOUT) :: psolaralb(ngrid,2) ! albedo of the surface
    7883      REAL,INTENT(INOUT) :: pemisurf(ngrid) ! emissivity of the surface
     84      REAL,INTENT(IN) :: rdust(ngrid,nlayer) ! dust effective radius
    7985     
    8086      ! tendencies due to CO2 condensation/sublimation:
     
    8591      REAL,INTENT(OUT) :: pdvc(ngrid,nlayer) ! tendency on meridional wind (m.s-2)
    8692      REAL,INTENT(OUT) :: pdqc(ngrid,nlayer,nq) ! tendency on tracers
     93      REAL,INTENT(OUT) :: pdqsc(ngrid,nq) ! tendency on surface tracers
    8794     
    8895      ! added to calculate flux dependent albedo:
     
    107114      REAL zmflux(nlayer+1)
    108115      REAL zu(nlayer),zv(nlayer)
    109       REAL zq(nlayer,nq),zq1(nlayer)
     116      REAL zqc(nlayer,nq),zq1(nlayer)
    110117      REAL ztsrf(ngrid)
    111118      REAL ztc(nlayer), ztm(nlayer+1)
     
    118125
    119126      real :: emisref(ngrid)
     127     
     128      REAL zdq_scav(ngrid,nlayer,nq) ! tendancy due to scavenging by co2
     129      REAL zq(ngrid,nlayer,nq)
    120130
    121131c variable speciale diagnostique
     
    197207c
    198208c
    199 c     Tendencies set to 0 (except pdtc)
     209c     Tendencies set to 0
    200210c     -------------------------------------
    201211      DO l=1,nlayer
     
    205215           pduc(ig,l)  = 0
    206216           pdvc(ig,l)  = 0
     217           pdtc(ig,l) = 0.
    207218         END DO
    208219      END DO
     
    225236      ENDDO
    226237      zfallheat=0
    227 
     238     
     239      zdq_scav(:,:,:)=0.
     240
     241c     Update tendencies from previous processes
     242c     -------------------------------------
     243      DO l=1,nlayer
     244         DO ig=1,ngrid
     245            zt(ig,l)=pt(ig,l)+ pdt(ig,l)*ptimestep
     246            do iq=1,nq
     247             zq(ig,l,iq)=pq(ig,l,iq)+pdq(ig,l,iq)*ptimestep
     248            enddo
     249         ENDDO
     250      ENDDO
     251     
    228252c     *************************
    229253c     ATMOSPHERIC CONDENSATION
     
    247271            ENDDO
    248272         ENDDO
    249       end if
     273      endif
    250274
    251275      IF (.NOT. co2clouds) then
     
    255279      DO l=1,nlayer
    256280         DO ig=1,ngrid
    257             zt(ig,l)=pt(ig,l)+ pdt(ig,l)*ptimestep
    258281!            ztcond(ig,l)=1./(bcond-acond*log(.0095*pplay(ig,l)))
    259282            if (pplay(ig,l).ge.1e-4) then
     
    300323      ENDDO
    301324     
    302       ELSE
    303          
     325      if (scavco2cond) then
     326        call scavenging_by_co2(ngrid,nlayer,nq,ptimestep,pplev,zq,
     327     &                       rdust,zcondicea,zfallice,zdq_scav,pdqsc)
     328      endif
     329     
     330      ELSE ! if co2 clouds
    304331        DO ig=1,ngrid
    305332         zfallice(ig,1) = zdqssed_co2(ig)
     
    311338            ENDDO
    312339        ENDDO
    313         DO l=nlayer, 1, -1
    314          DO ig=1, ngrid
    315             zt(ig,l)=pt(ig,l)+ pdt(ig,l)*ptimestep
    316             pdtc(ig,l)=0.
    317          ENDDO
    318       ENDDO
    319       ENDIF ! if not co2clouds
     340 
     341      ENDIF ! end of if co2clouds
    320342
    321343      call WRITEdiagfi(ngrid,"pdtc_atm",
     
    330352     &         "",
    331353     &         " ",2,zfallice(ngrid,1))
     354     
    332355
    333356c     *************************
     
    402425#endif
    403426
    404 c           If the entire CO_2 ice layer sublimes
     427c           If the entire CO2 ice layer sublimes
    405428c           """"""""""""""""""""""""""""""""""""""""""""""""""""
    406429c           (including what has just condensed in the atmosphere)
     
    430453               STOP
    431454            ENDIF
    432          END IF ! if there is condensation/sublimmation
     455         END IF ! if there is condensation/sublimation
    433456      ENDDO ! of DO ig=1,ngrid
    434457
     
    471494             zv(l)   =pv(ig,l)   +pdv( ig,l)  *ptimestep
    472495            do iq=1,nq
    473              zq(l,iq)=pq(ig,l,iq)+pdq(ig,l,iq)*ptimestep
     496             zqc(l,iq)=zq(ig,l,iq)+zdq_scav(ig,l,iq)*ptimestep ! zdq_scav=0 if watercloud=false
    474497            enddo
    475            end do
     498           enddo
    476499
    477500c  Mass fluxes through the sigma levels (kg.m-2.s-1)  (>0 when up)
     
    527550            do iq=1,nq
    528551             do l=1,nlayer
    529               zq1(l)=zq(l,iq)
     552              zq1(l)=zqc(l,iq)
    530553             enddo
    531554             zqm1(1)=zqm(1,iq)
    532555             call vl1d(nlayer,zq1,2.,masse,w,zqm1)
    533556             do l=2,nlayer
    534               zq( l,iq)=zq1(l)
     557              zqc(l,iq)=zq1(l)
    535558              zqm(l,iq)=zqm1(l)
    536559             enddo
     
    551574            zvm(nlayer+1)= zv(nlayer)  ! should not be used, but...
    552575            do iq=1,nq
    553              zqm(nlayer+1,iq)= zq(nlayer,iq)
     576             zqm(nlayer+1,iq)= zqc(nlayer,iq)
    554577            enddo
    555578
     
    602625                DO l=1,nlayer
    603626                  pdqc(ig,l,iq)= (1/masse(l)) *
    604      &           ( zmflux(l)*(zqm(l,iq) - zq(l,iq))
    605      &           - zmflux(l+1)*(zqm(l+1,iq) - zq(l,iq))
    606      &           + zcondicea(ig,l)*(zq(l,iq)-1.) )
     627     &           ( zmflux(l)*(zqm(l,iq) - zqc(l,iq))
     628     &           - zmflux(l+1)*(zqm(l+1,iq) - zqc(l,iq))
     629     &           + zcondicea(ig,l)*(zqc(l,iq)-1.) )
    607630                END DO
    608631              else
    609632                DO l=1,nlayer
    610633                  pdqc(ig,l,iq)= (1/masse(l)) *
    611      &           ( zmflux(l)*(zqm(l,iq) - zq(l,iq))
    612      &           - zmflux(l+1)*(zqm(l+1,iq) - zq(l,iq))
    613      &           + zcondicea(ig,l)*zq(l,iq) )
     634     &           ( zmflux(l)*(zqm(l,iq) - zqc(l,iq))
     635     &           - zmflux(l+1)*(zqm(l+1,iq) - zqc(l,iq))
     636     &           + zcondicea(ig,l)*zqc(l,iq) )
     637     
     638                  pdqc(ig,l,iq)=pdqc(ig,l,iq)+zdq_scav(ig,l,iq) ! zdq_scav=0 if watercloud=false
    614639                END DO
    615640              end if
     
    793818
    794819      END SUBROUTINE vl1d
     820         
     821c *****************************************************************
     822      SUBROUTINE scavenging_by_co2(ngrid,nlayer,nq,ptimestep,pplev,pq,
     823     &                          rdust,pcondicea,pfallice,pdq_scav,pdqsc)
     824                     
     825c
     826c   
     827c     Calcul de la quantite de poussiere lessivee par les nuages de CO2
     828c     
     829c   --------------------------------------------------------------------
     830      use tracer_mod, only: nqmx, igcm_h2o_vap, igcm_h2o_ice,
     831     &                      igcm_dust_mass, igcm_dust_number,
     832     &                      igcm_ccn_mass, igcm_ccn_number,
     833     &                      rho_dust, nuice_sed, nuice_ref,r3n_q
     834      use comcstfi_h, only: g
     835     
     836      IMPLICIT NONE
     837      include "callkeys.h" ! for the flags water, microphys and freedust
     838c
     839c
     840c   Arguments:
     841      INTEGER,INTENT(IN) :: ngrid  ! number of atmospheric columns
     842      INTEGER,INTENT(IN) :: nlayer ! number of vertical layers
     843      INTEGER,INTENT(IN) :: nq  ! number of tracers
     844      REAL,INTENT(IN) :: ptimestep ! physics timestep (s)
     845      REAL,INTENT(IN) :: pplev(ngrid,nlayer+1) ! inter-layer pressure (Pa)
     846      REAL,INTENT(IN) :: pq(ngrid,nlayer,nq)
     847      REAL,INTENT(IN) :: rdust(ngrid,nlayer) ! dust effective radius
     848      REAL,INTENT(IN) :: pcondicea(ngrid,nlayer) ! condensation rate in layer  l  (kg/m2/s)
     849      REAL,INTENT(IN) :: pfallice(ngrid,nlayer+1) ! amount of ice falling from layer l (kg/m2/s)
     850     
     851      REAL,INTENT(OUT) :: pdq_scav(ngrid,nlayer,nq) ! tendancy due to scavenging by co2
     852      REAL,INTENT(OUT) :: pdqsc(ngrid,nq) ! tendency on surface tracers
     853     
     854c   Locals:
     855      INTEGER l,ig
     856      REAL scav_ratio_dust, scav_ratio_wice ! ratio of the dust/water ice mass mixing ratios in condensing CO2 ice and in air
     857      REAL scav_dust_mass(nlayer+1) ! dust flux (mass) scavenged towards the lower layer (kg/m2/s) (POSITIVE WHEN DOWNWARD)
     858      REAL scav_dust_number(nlayer+1) ! dust flux (number) scavenged towards the lower layer (kg/m2/s) (POSITIVE WHEN DOWNWARD)
     859      REAL scav_ccn_mass(nlayer+1) ! ccn flux (mass) scavenged towards the lower layer
     860      REAL scav_ccn_number(nlayer+1) ! ccn flux (number) scavenged towards the lower layer
     861      REAL scav_h2o_ice(nlayer+1) ! water ice flux (mass) scavenged towards the lower layer
     862      REAL massl ! mass of the layer l at point ig (kg/m2)
     863     
     864c   Initialization:
     865      scav_ratio_dust = 100 !1 !10 !100 !1000
     866      scav_ratio_wice = scav_ratio_dust
     867      pdq_scav(:,:,:)=0.
     868     
     869      DO ig=1,ngrid
     870        scav_dust_mass(nlayer+1)=0.
     871        scav_dust_number(nlayer+1)=0.
     872        scav_ccn_mass(nlayer+1)=0.
     873        scav_ccn_number(nlayer+1)=0.
     874        scav_h2o_ice(nlayer+1)=0.
     875       
     876        DO l=nlayer , 1, -1
     877         massl=(pplev(ig,l)-pplev(ig,l+1))/g
     878         IF(pcondicea(ig,l).GT.0.)THEN ! if CO2 condenses and traps dust/water ice
     879           ! Calculation of the tendencies
     880           if (freedust) then
     881             pdq_scav(ig,l,igcm_dust_mass)=-pq(ig,l,igcm_dust_mass)
     882     &                                     /ptimestep*(1-exp(
     883     &              -scav_ratio_dust*pcondicea(ig,l)*ptimestep/massl))
     884             
     885             pdq_scav(ig,l,igcm_dust_number)=pdq_scav(ig,l,igcm_dust_mass)
     886     &                                    *r3n_q/rdust(ig,l)
     887           endif
     888           if (freedust.AND.microphys) then
     889             pdq_scav(ig,l,igcm_ccn_mass)=-pq(ig,l,igcm_ccn_mass)
     890     &                                     /ptimestep*(1-exp(
     891     &              -scav_ratio_wice*pcondicea(ig,l)*ptimestep/massl))
     892             pdq_scav(ig,l,igcm_ccn_number)=pdq_scav(ig,l,igcm_ccn_mass)
     893     &                                    *r3n_q/rdust(ig,l)
     894           endif
     895           if (water) then
     896             pdq_scav(ig,l,igcm_h2o_ice)=-pq(ig,l,igcm_h2o_ice)
     897     &                                     /ptimestep*(1-exp(
     898     &              -scav_ratio_wice*pcondicea(ig,l)*ptimestep/massl))
     899           endif
     900     
     901         ELSE IF(pcondicea(ig,l).LT.0.)THEN ! if CO2 sublimates and releases dust/water ice
     902           ! Calculation of the tendencies
     903           if (freedust) then
     904             pdq_scav(ig,l,igcm_dust_mass)=-pcondicea(ig,l)/massl*
     905     &                              scav_dust_mass(l+1)/pfallice(ig,l+1)
     906           
     907             pdq_scav(ig,l,igcm_dust_number)=-pcondicea(ig,l)/massl*
     908     &                            scav_dust_number(l+1)/pfallice(ig,l+1)
     909           endif
     910           if (freedust.AND.microphys) then
     911             pdq_scav(ig,l,igcm_ccn_mass)=-pcondicea(ig,l)/massl*
     912     &                              scav_ccn_mass(l+1)/pfallice(ig,l+1)
     913           
     914             pdq_scav(ig,l,igcm_ccn_number)=-pcondicea(ig,l)/massl*
     915     &                            scav_ccn_number(l+1)/pfallice(ig,l+1)
     916           endif
     917           if (water) then
     918             pdq_scav(ig,l,igcm_h2o_ice)=-pcondicea(ig,l)/massl*
     919     &                              scav_h2o_ice(l+1)/pfallice(ig,l+1)
     920           endif
     921 
     922         END IF
     923         ! Calculation of the scavenged dust/wice flux towards the lower layers
     924         if (freedust) then
     925           scav_dust_mass(l)=-pdq_scav(ig,l,igcm_dust_mass)*massl
     926     &                     +scav_dust_mass(l+1)
     927         
     928           scav_dust_number(l)=-pdq_scav(ig,l,igcm_dust_number)*massl
     929     &                     +scav_dust_number(l+1)
     930         endif
     931         if (freedust.AND.microphys) then
     932           scav_ccn_mass(l)=-pdq_scav(ig,l,igcm_ccn_mass)*massl
     933     &                     +scav_ccn_mass(l+1)
     934         
     935           scav_ccn_number(l)=-pdq_scav(ig,l,igcm_ccn_number)*massl
     936     &                     +scav_dust_number(l+1)
     937         endif
     938         if (water) then
     939           scav_h2o_ice(l)=-pdq_scav(ig,l,igcm_h2o_ice)*massl
     940     &                     +scav_h2o_ice(l+1)
     941         endif
     942         
     943       ENDDO
     944       ! Calculation of the surface tendencies
     945       pdqsc(ig,igcm_dust_mass)=0.
     946       pdqsc(ig,igcm_dust_number)=0.
     947       
     948       if (freedust) then
     949         pdqsc(ig,igcm_dust_mass)=pdqsc(ig,igcm_dust_mass)
     950     &                           +scav_dust_mass(1)
     951         pdqsc(ig,igcm_dust_number)=pdqsc(ig,igcm_dust_number)
     952     &                             +scav_dust_number(1)
     953       endif
     954       if (freedust.AND.microphys) then
     955         pdqsc(ig,igcm_dust_mass)=pdqsc(ig,igcm_dust_mass)
     956     &                           +scav_ccn_mass(1)
     957         pdqsc(ig,igcm_dust_number)=pdqsc(ig,igcm_dust_number)
     958     &                             +scav_ccn_number(1)
     959       endif
     960       if (water) then
     961         pdqsc(ig,igcm_h2o_ice)=scav_h2o_ice(1)
     962       endif
     963      ENDDO
     964     
     965      END SUBROUTINE scavenging_by_co2
    795966     
    796967      END MODULE co2condens_mod
  • trunk/LMDZ.MARS/libf/phymars/conf_phys.F

    r2179 r2184  
    4545      use datafile_mod, only: datadir
    4646      use calchim_mod, only: ichemistry
    47 
     47      use co2condens_mod, only: scavco2cond
     48     
    4849      IMPLICIT NONE
    4950      include "callkeys.h"
     
    661662        endif
    662663
     664! Instantaneous scavenging by CO2
     665! -> expected to be replaced by scavenging with microphysics (flag scavenging) one day
     666        write(*,*)"Dust scavenging by instantaneous CO2 snowfall ?"
     667        scavco2cond=.false.      ! default value
     668        call getin("scavco2cond",scavco2cond)
     669        write(*,*)" scavco2cond = ",scavco2cond
     670! Test of incompatibility:
     671! if scavco2cond is used, then dustbin should be > 0
     672        if (scavco2cond.and.(dustbin.lt.1))then
     673           print*,'if scavco2cond is used, then dustbin should be > 0'
     674           stop
     675        endif
     676! if co2clouds is used, then there is no need for scavco2cond
     677        if (co2clouds.and.scavco2cond) then
     678           print*,''
     679           print*,'----------------WARNING-----------------'
     680           print*,'     microphys scavenging is used so    '
     681           print*,'        no need for scavco2cond !!!     '
     682           print*,'----------------WARNING-----------------'
     683           print*,''
     684           stop
     685        endif
     686       
    663687! Test of incompatibility:
    664688
  • trunk/LMDZ.MARS/libf/phymars/physiq_mod.F

    r2182 r2184  
    310310      REAL zdqc(ngrid,nlayer,nq)
    311311      REAL zdqcloudco2(ngrid,nlayer,nq)
     312      REAL zdqsc(ngrid,nq)
    312313
    313314      REAL zdteuv(ngrid,nlayer)    ! (K/s)
     
    16721673#endif
    16731674
    1674 c   9d. Updates
    1675 c     ---------
    1676 
    1677         DO iq=1, nq
    1678           DO ig=1,ngrid
    1679 
    1680 c       ---------------------------------
    1681 c       Updating tracer budget on surface
    1682 c       ---------------------------------
    1683             qsurf(ig,iq)=qsurf(ig,iq)+ptimestep*dqsurf(ig,iq)
    1684 
    1685           ENDDO  ! (ig)
    1686         ENDDO    ! (iq)
    1687 
    16881675      endif !  of if (tracer)
    16891676
     
    17331720     $              capcal,zplay,zplev,tsurf,pt,
    17341721     $              pphi,pdt,pdu,pdv,zdtsurf,pu,pv,pq,pdq,
    1735      $              co2ice,albedo,emis,
     1722     $              co2ice,albedo,emis,rdust,
    17361723     $              zdtc,zdtsurfc,pdpsrf,zduc,zdvc,zdqc,
    17371724     $              fluxsurf_sw,zls,
    17381725     $              zdqssed_co2,zcondicea_co2microp,
    1739      &              zdtcloudco2)
     1726     &              zdtcloudco2,zdqsc)
    17401727
    17411728         DO l=1,nlayer
     
    17581745            ENDDO
    17591746           ENDDO
     1747                   
     1748           DO iq=1, nq
     1749            DO ig=1,ngrid
     1750              dqsurf(ig,iq)=dqsurf(ig,iq)+zdqsc(ig,iq)
     1751            ENDDO  ! (ig)
     1752           ENDDO    ! (iq)
     1753           
    17601754         ENDIF ! of IF (tracer)
    17611755
     
    17871781      ENDIF  ! of IF (callcond)
    17881782
     1783c-----------------------------------------------------------------------
     1784c  Updating tracer budget on surface
     1785c-----------------------------------------------------------------------         
     1786      IF (tracer) THEN
     1787        DO iq=1, nq
     1788          DO ig=1,ngrid
     1789
     1790            qsurf(ig,iq)=qsurf(ig,iq)+ptimestep*dqsurf(ig,iq)
     1791
     1792          ENDDO  ! (ig)
     1793        ENDDO    ! (iq)
     1794      ENDIF
     1795     
    17891796c-----------------------------------------------------------------------
    17901797c   12. Surface  and sub-surface soil temperature
Note: See TracChangeset for help on using the changeset viewer.