Ignore:
Timestamp:
May 13, 2020, 5:14:02 PM (5 years ago)
Author:
mvals
Message:

Mars GCM:
Extent of the transport of the isotopic ratio implemented in the dynamics to all the Van Leer transport schemes used in the physics (for now it only
concerns the tracer HDO).

  • libf/dynphy_lonlat/phymars/: iniphysiq_mod.F90: transmission of the content of variables describing the isotopes defined in the dynamics (precisely by dyn3d_common/infotrac.F90,

which reads traceur.def) to the physics

  • libf/phymars/: phys_state_var_init_mod.F90, tracer_mod.F : initialisation of the variables describing the isotopes in the physics callsedim_mod.F: implementation of the transport of the isotopic ratio in the Van Leer scheme used for sedimentation (applies to hdo ice) co2condens_mod.F: implementation of the transport of the isotopic ratio in the Van Leer scheme used for condensation of CO2 (applies to hdo ice and

vapour)
MV

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

Legend:

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

    r2312 r2322  
    2222     &                      igcm_co2_ice, igcm_stormdust_mass,
    2323     &                      igcm_stormdust_number,igcm_topdust_mass,
    24      &                      igcm_topdust_number
     24     &                      igcm_topdust_number,
     25     &                      iqfils,nqfils,qperemin,masseqmin ! MVals: variables isotopes
    2526      USE newsedim_mod, ONLY: newsedim
    2627      USE comcstfi_h, ONLY: g
     
    9192      real masse (ngrid,nlay) ! Layer mass (kg.m-2)
    9293      real epaisseur (ngrid,nlay) ! Layer thickness (m)
    93       real wq(ngrid,nlay+1) ! displaced tracer mass (kg.m-2)
     94      real wq(ngrid,nlay+1),w(ngrid,nlay) ! displaced tracer mass wq (kg.m-2), MVals: displaced "pere" tracer mass w (kg.m-2)
    9495      real r0(ngrid,nlay) ! geometric mean radius used for
    9596                                !   sedimentation (m)
     
    105106      REAl ccntyp
    106107      character(len=20),parameter :: modname="callsedim"
     108c     MVals: transport of the isotopic ratio
     109      REAL Ratio0(ngrid,nlay),Ratio(ngrid,nlay)
     110      REAL masseq(ngrid,nlay)
     111      REAL newmasse
     112      REAL zq0(ngrid,nlay,nq)
     113      INTEGER ifils,iq2
    107114
    108115
     
    388395        if(radius(iq).gt.1.e-9 .and.(iq.ne.ico2_ice) .and.
    389396     &        (iq .ne. iccnco2_mass) .and. (iq .ne.
    390      &        iccnco2_number)) then  ! no sedim for gaz or CO2 clouds  (done in microtimestep)
    391 
     397     &        iccnco2_number) .and. ! no sedim for gaz or CO2 clouds  (done in microtimestep)
     398     &        iq .ne. igcm_hdo_ice) then !MVals: hdo is transported by h2o
    392399c -----------------------------------------------------------------
    393400c         DOUBLEQ CASE
     
    500507c -----------------------------------------------------------------
    501508           else if ((iq .eq. iccn_mass) .or. (iq .eq. iccn_number)
    502      &       .or. (iq .eq. igcm_h2o_ice)
    503      &       .or. (iq .eq. igcm_hdo_ice)) then
     509     &       .or. (iq .eq. igcm_h2o_ice)) then
    504510            if (microphys) then
    505               ! water ice sedimentation
     511c             water ice sedimentation
     512c             ~~~~~~~~~~
    506513              call newsedim(ngrid,nlay,ngrid*nlay,ngrid*nlay,
    507514     &        ptimestep,pplev,masse,epaisseur,zt,rsedcloud,rhocloud,
    508515     &        zqi(1,1,iq),wq,beta)
     516c             Surface Tendencies
     517c             ~~~~~~~~~~
     518              do ig=1,ngrid
     519                pdqs_sed(ig,iq)=wq(ig,1)/ptimestep
     520              end do
    509521            else
    510               ! water ice sedimentation
     522c             water ice sedimentation
     523c             ~~~~~~~~~~
    511524              call newsedim(ngrid,nlay,ngrid*nlay,1,
    512525     &        ptimestep,pplev,masse,epaisseur,zt,rsedcloud,rho_q(iq),
    513526     &        zqi(1,1,iq),wq,beta)
     527c             Surface tendencies
     528c             ~~~~~~~~~~
     529              do ig=1,ngrid
     530                pdqs_sed(ig,iq)=wq(ig,1)/ptimestep
     531              end do
     532c             Special case of isotopes
     533c             ~~~~~~~~~~
     534              !MVals: Loop over the sons ("fils")
     535              if (nqfils(iq).gt.0) then
     536                iq2=iqfils(nqfils(iq),iq) ! for now always nqfils(iq)=1 (special case of HDO only son of H2O)
     537                !MVals: input paramters in vlz_fi for hdo
     538                do l=1,nlay
     539                 do ig=1,ngrid
     540                  if (zq0(ig,l,iq).gt.qperemin) then
     541                   Ratio0(ig,l)=zq0(ig,l,iq2)/zq0(ig,l,iq)
     542                  else
     543                   Ratio0(ig,l)=0.
     544                  endif
     545                  Ratio(ig,l)=Ratio0(ig,l)
     546                  masseq(ig,l)=max(masse(ig,l)*zq0(ig,l,iq),masseqmin)
     547                  w(ig,l)=wq(ig,l) !MVals: very important: hdo is transported by h2o (see vlsplt_p.F: correction bugg 15 mai 2015)
     548                 enddo !ig=1,ngrid
     549                enddo !l=1,nlay
     550                !MVals: no need to enter newsedim as the transporting mass w has been already calculated
     551                call vlz_fi(ngrid,nlay,Ratio,2.,masseq,w,wq)
     552                zqi(:,nlay,iq2)=zqi(:,nlay,iq)*Ratio0(:,nlay)
     553                do l=1,nlay-1
     554                 do ig=1,ngrid
     555                  newmasse=max(masseq(ig,l)+w(ig,l+1)-w(ig,l),masseqmin)
     556                  Ratio(ig,l)=(Ratio0(ig,l)*masseq(ig,l)
     557     &                         +wq(ig,l+1)-wq(ig,l))/newmasse               
     558                  zqi(ig,l,iq2)=zqi(ig,l,iq)*Ratio(ig,l)   
     559                 enddo
     560                enddo !l=1,nlay-1
     561                !MVals: hdo surface tendency
     562                do ig=1,ngrid
     563                 if (w(ig,1).gt.masseqmin) then
     564                   pdqs_sed(ig,iq2)=pdqs_sed(ig,iq)*(wq(ig,1)/w(ig,1))
     565                 else
     566                   pdqs_sed(ig,iq2)=pdqs_sed(ig,iq)*Ratio0(ig,1)
     567                 endif
     568                end do
     569              endif !(nqfils(iq).gt.0)
    514570            endif ! of if (microphys)
    515 c           Tendencies
    516 c           ~~~~~~~~~~
    517             do ig=1,ngrid
    518               pdqs_sed(ig,iq)=wq(ig,1)/ptimestep
    519             end do
     571
    520572c -----------------------------------------------------------------
    521573c         GENERAL CASE
     
    539591              pdqsed(ig,l,iq)=(zqi(ig,l,iq)-
    540592     $        (pq(ig,l,iq) + pdqfi(ig,l,iq)*ptimestep))/ptimestep
     593              !MVals: Special case of isotopes: for now only HDO
     594              if (nqfils(iq).gt.0) then
     595               iq2=iqfils(nqfils(iq),iq)
     596               pdqsed(ig,l,iq2)=(zqi(ig,l,iq2)-
     597     $            (pq(ig,l,iq2) + pdqfi(ig,l,iq2)*ptimestep))/ptimestep
     598              endif
    541599            ENDDO
    542600          ENDDO
  • trunk/LMDZ.MARS/libf/phymars/co2condens_mod.F

    r2189 r2322  
    1818       use tracer_mod, only: noms, igcm_h2o_ice,
    1919     &                      igcm_dust_mass, igcm_dust_number,
    20      &                      igcm_ccn_mass, igcm_ccn_number
     20     &                      igcm_ccn_mass, igcm_ccn_number,
     21     &                      iqfils,nqperes,nqfils, ! MVals: variables isotopes
     22     &                      qperemin,masseqmin
    2123       use surfdat_h, only: emissiv, phisfi
    2224       use geometry_mod, only: latitude, ! grid point latitudes (rad)
     
    155157      REAL ztm3D(ngrid,nlayer)
    156158      REAL zmflux3D(ngrid,nlayer)
     159
     160c MVals: variables isotopes
     161      REAL Ratio1(nlayer),Ratiom1(nlayer+1)
     162      REAL masseq(nlayer),wq(nlayer+1)
     163      INTEGER ifils,iq2
    157164c----------------------------------------------------------------------
    158165
     
    537544            call vl1d(nlayer,zu ,2.,masse,w,zum)
    538545            call vl1d(nlayer,zv ,2.,masse,w,zvm)
    539             do iq=1,nq
     546            ! MVals: loop over the fathers ("peres")
     547            do iq=1,nqperes
    540548             do l=1,nlayer
    541549              zq1(l)=zqc(l,iq)
     
    547555              zqm(l,iq)=zqm1(l)
    548556             enddo
    549             enddo
     557             ! MVals: loop over the sons ("fils")
     558             if (nqfils(iq).gt.0) then
     559              iq2=iqfils(nqfils(iq),iq) ! for now it is always nqfils(iq)=1 (special case of HDO only son of H2O)
     560              do l=1,nlayer
     561               if (zqc(l,iq).gt.qperemin) then
     562                 Ratio1(l)=zqc(l,iq2)/zqc(l,iq)
     563               else
     564                 Ratio1(l)=0.
     565               endif
     566               masseq(l)=max(masse(l)*zqc(l,iq),masseqmin)
     567               wq(l)=w(l)*zqm(l,iq)
     568              enddo
     569              Ratiom1(1)=zqm(1,iq2)
     570              call vl1d(nlayer,Ratio1,2.,masseq,wq,Ratiom1)
     571              zqm(1,iq2)=Ratiom1(1)*zqc(1,iq)
     572              do l=2,nlayer
     573               zqm(l,iq2)=Ratiom1(l)*zqm(l,iq)
     574              enddo
     575             endif !if (nqfils(iq).gt.0) then
     576            enddo !iq=1,nqperes
    550577
    551578c           Surface condensation affects low winds
  • trunk/LMDZ.MARS/libf/phymars/dyn1d/testphys1d.F

    r2312 r2322  
    55      use dimphy, only : init_dimphy
    66      use mod_grid_phy_lmdz, only : regular_lonlat
    7       use infotrac, only: nqtot, tname
     7      use infotrac, only: nqtot, tname, nqperes,nqdesc,iqfils,nqfils,
     8     &                    iqpere, nqdesc_tot
    89      use comsoil_h, only: volcapa, layer, mlayer, inertiedat, nsoilmx
    910      use comgeomfi_h, only: sinlat, ini_fillgeom
     
    127128      REAL halfaxe, excentric, Lsperi
    128129      Logical paleomars
     130
     131c   MVals: isotopes as in the dynamics (CRisi)
     132      INTEGER :: ifils,ipere,generation
     133      CHARACTER(len=30), ALLOCATABLE, DIMENSION(:) :: tnom_transp ! transporting fluid short name
     134      CHARACTER(len=80) :: line ! to store a line of text     
     135      INTEGER ierr0
     136      LOGICAL :: continu
    129137
    130138c=======================================================================
     
    240248        allocate(dqdyn(nlayer,nq))
    241249        allocate(mqtot(nq))
     250        allocate(tnom_transp(nq))
    242251       
    243252        ! read tracer names from file traceur.def
    244253        do iq=1,nq
    245           read(90,*,iostat=ierr) tname(iq)
     254          read(90,'(80a)',iostat=ierr) line ! store the line from traceur.def
    246255          if (ierr.ne.0) then
    247256            write(*,*) 'testphys1d: error reading tracer names...'
    248257            stop
    249258          endif
     259          ! if format is tnom_0, tnom_transp (isotopes)
     260          read(line,*,iostat=ierr0) tname(iq),tnom_transp(iq)
     261          if (ierr0.ne.0) then
     262            read(line,*) tname(iq)
     263            tnom_transp(iq)='air'
     264          endif
     265
    250266        enddo
    251267        close(90)
     268
     269       ! Isotopes: as in the 3D case we have to determine father/son relations for isotopes and carrying fluid
     270       ALLOCATE(nqfils(nqtot),nqdesc(nqtot))   
     271       ALLOCATE(iqfils(nqtot,nqtot))   
     272       ALLOCATE(iqpere(nqtot))
     273       nqperes=0
     274       nqfils(:)=0
     275       nqdesc(:)=0
     276       iqfils(:,:)=0
     277       iqpere(:)=0
     278       nqdesc_tot=0   
     279       DO iq=1,nqtot
     280       if (tnom_transp(iq) == 'air') then
     281         ! ceci est un traceur père
     282         WRITE(*,*) 'Le traceur',iq,', appele ',
     283     &          trim(tname(iq)),', est un pere'
     284         nqperes=nqperes+1
     285         iqpere(iq)=0
     286       else !if (tnom_transp(iq) == 'air') then
     287         ! ceci est un fils. Qui est son père?
     288         WRITE(*,*) 'Le traceur',iq,', appele ',
     289     &                trim(tname(iq)),', est un fils'
     290         continu=.true.
     291         ipere=1
     292         do while (continu)           
     293           if (tnom_transp(iq) .eq. tname(ipere)) then
     294             ! Son père est ipere
     295             WRITE(*,*) 'Le traceur',iq,'appele ',
     296     &   trim(tname(iq)),' est le fils de ',
     297     &   ipere,'appele ',trim(tname(ipere))
     298             nqfils(ipere)=nqfils(ipere)+1 
     299             iqfils(nqfils(ipere),ipere)=iq
     300             iqpere(iq)=ipere         
     301             continu=.false.
     302           else !if (tnom_transp(iq) == tnom_0(ipere)) then
     303             ipere=ipere+1
     304             if (ipere.gt.nqtot) then
     305                 WRITE(*,*) 'Le traceur',iq,'appele ',
     306     &           trim(tname(iq)),', est orpelin.'
     307                 CALL abort_gcm('infotrac_init',
     308     &                  'Un traceur est orphelin',1)
     309             endif !if (ipere.gt.nqtot) then
     310           endif !if (tnom_transp(iq) == tnom_0(ipere)) then
     311         enddo !do while (continu)
     312       endif !if (tnom_transp(iq) == 'air') then
     313       enddo !DO iq=1,nqtot
     314       WRITE(*,*) 'nqperes=',nqperes   
     315       WRITE(*,*) 'nqfils=',nqfils
     316       WRITE(*,*) 'iqpere=',iqpere
     317       WRITE(*,*) 'iqfils=',iqfils
     318       ! Calculer le nombre de descendants à partir de iqfils et de nbfils
     319       DO iq=1,nqtot   
     320       generation=0
     321       continu=.true.
     322       ifils=iq
     323       do while (continu)
     324          ipere=iqpere(ifils)
     325         if (ipere.gt.0) then
     326          nqdesc(ipere)=nqdesc(ipere)+1   
     327          nqdesc_tot=nqdesc_tot+1     
     328          iqfils(nqdesc(ipere),ipere)=iq
     329          ifils=ipere
     330          generation=generation+1
     331         else !if (ipere.gt.0) then
     332          continu=.false.
     333         endif !if (ipere.gt.0) then
     334       enddo !do while (continu)   
     335       WRITE(*,*) 'Le traceur ',iq,', appele ',trim(tname(iq)),
     336     &               ' est un traceur de generation: ',generation
     337       ENDDO !DO iq=1,nqtot
     338       WRITE(*,*) 'infotrac: nqdesc=',nqdesc
     339       WRITE(*,*) 'iqfils=',iqfils
     340       WRITE(*,*) 'nqdesc_tot=',nqdesc_tot
    252341
    253342        ! initialize tracers here:
     
    583672      call init_dimphy(1,nlayer) ! Initialize dimphy module
    584673      call phys_state_var_init(1,llm,nq,tname,
    585      .          day0,time,daysec,dtphys,rad,g,r,cpp)
     674     .          day0,time,daysec,dtphys,rad,g,r,cpp,
     675     .          nqdesc,iqfils,nqperes,nqfils)! MVals: variables isotopes
    586676      call ini_fillgeom(1,latitude,longitude,(/1.0/))
    587677      call conf_phys(1,llm,nq)
  • trunk/LMDZ.MARS/libf/phymars/phys_state_var_init_mod.F90

    r2265 r2322  
    55      SUBROUTINE phys_state_var_init(ngrid,nlayer,nq,tname, &
    66                                     day_ini,hour_ini,pdaysec,ptimestep, &
    7                                      prad,pg,pr,pcpp)
     7                                     prad,pg,pr,pcpp, &
     8                                     dyn_nqdesc,dyn_iqfils,dyn_nqperes,dyn_nqfils)! MVals: variables isotopes
    89
    910!=======================================================================
     
    6768      REAL,INTENT(IN) :: hour_ini
    6869      REAL,INTENT(IN) :: pdaysec,ptimestep,prad,pg,pr,pcpp
     70!MVals isotopes
     71      INTEGER,INTENT(in) :: dyn_nqperes
     72      INTEGER,INTENT(in) :: dyn_nqfils(nq)
     73      INTEGER,INTENT(in) :: dyn_nqdesc(nq)
     74      INTEGER,INTENT(in) :: dyn_iqfils(nq,nq)
    6975
    7076      ! set dimension and allocate arrays in tracer_mod
    7177      call end_tracer_mod
    72       call ini_tracer_mod(nq,tname)
     78      call ini_tracer_mod(nq,tname,dyn_nqdesc,dyn_iqfils,dyn_nqperes,dyn_nqfils)! MVals: variables isotopes
    7379
    7480
  • trunk/LMDZ.MARS/libf/phymars/tracer_mod.F90

    r2321 r2322  
    9595      ! other tracers
    9696      integer,save :: igcm_ar_n2 ! for simulations using co2 +neutral gas
    97 
     97      ! MVals: isotopes
     98      integer, save                 :: nqperes ! numbers of tracers defined as "peres"
     99      integer, allocatable, save    :: nqfils(:) ! numbers of sons ("fils") of the considered tracer
     100      integer, allocatable, save    :: iqfils(:,:) ! indice of a son, ex: iqfils(nqfils(ipere),ipere)
     101      real, parameter               :: qperemin=1.e-16 ! threschold for the "pere" mixing ratio qpere to calculate Ratio=qfils/qpere
     102      real, parameter               :: masseqmin=1.e-16 ! threschold for the "pere" transporting masse
     103      !integer, allocatable, save    :: nqdesc(:) ! number of sons + all gran-sons over all generations: not useful for now in the martian case as there are no gran-sons
    98104
    99105!-----------------------------------------------------------------------
     
    101107  contains
    102108 
    103     subroutine ini_tracer_mod(nq,tname)
     109    subroutine ini_tracer_mod(nq,tname,dyn_nqdesc,dyn_iqfils,dyn_nqperes,dyn_nqfils)! MVals: variables isotopes
    104110      implicit none
    105111     
    106112      integer,intent(in) :: nq ! number of tracers
    107113      character(len=*),intent(in) :: tname(nq) ! tracer names
     114      !MVals: variables isotopes
     115      integer,intent(in) :: dyn_nqperes
     116      integer,intent(in) :: dyn_nqfils(nq)
     117      integer,intent(in) :: dyn_nqdesc(nq)
     118      integer,intent(in) :: dyn_iqfils(nq,nq)
    108119     
    109120      integer :: iq, count
     
    117128        write(*,*) "tracer_mod names : ", trim(noms(iq))
    118129      enddo
     130
     131      !MVals: isotopes variables initialisation
     132      do iq=1,nq
     133        if (dyn_nqfils(iq).ne.dyn_nqdesc(iq)) then
     134          write(*,*) ' for now all descendants must be sons: check the', &
     135                     '  relations between tracers in traceur.def !'
     136          call abort_physic("ini_tracer_mod","relatives pattern between tracers not accepted",1)
     137        endif
     138      enddo
     139      allocate(nqfils(nq))!,nqdesc(nq))   
     140      allocate(iqfils(nq,nq))
     141      nqperes=dyn_nqperes   
     142      nqfils(:)=dyn_nqfils(:)
     143      iqfils(:,:)=dyn_iqfils(:,:)
    119144     
    120145#ifndef MESOSCALE
Note: See TracChangeset for help on using the changeset viewer.