Ignore:
Timestamp:
Mar 11, 2024, 5:26:53 PM (11 months ago)
Author:
afalco
Message:

Pluto PCM:
Methane/CO taken into account in callcorrk
AF

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/LMDZ.PLUTO/libf/phypluto/dyn1d/rcm1d.F

    r3232 r3258  
    3939
    4040!==================================================================
    41 !     
     41!
    4242!     Purpose
    4343!     -------
    4444!     Run the physics package of the universal model in a 1D column.
    45 !     
     45!
    4646!     It can be compiled with a command like (e.g. for 25 layers):
    4747!                                  "makegcm -p std -d 25 rcm1d"
     
    8282      REAL play(llm)        ! Pressure at the middle of the layers (Pa)
    8383      REAL plev(llm+1)      ! intermediate pressure levels (pa)
    84       REAL psurf,tsurf(1)     
     84      REAL psurf,tsurf(1)
    8585      REAL u(llm),v(llm)    ! zonal, meridional wind
    8686      REAL gru,grv          ! prescribed "geostrophic" background wind
     
    9090      REAL,ALLOCATABLE :: tsoil(:)    ! subsurface soil temperature (K)
    9191!      REAL n2ice               ! n2ice layer (kg.m-2) !not used anymore
    92       integer :: i_n2_ice=0     ! tracer index of n2 ice
    93       integer :: i_h2o_ice=0     ! tracer index of h2o ice
    94       integer :: i_h2o_vap=0     ! tracer index of h2o vapor
     92      integer :: i_n2=0     ! tracer index of n2 ice
     93      integer :: i_ch4_ice=0     ! tracer index of ch4 ice
     94      integer :: i_ch4_gas=0     ! tracer index of ch4 gas
     95      integer :: i_co_ice=0      ! tracer index of co ice
     96      integer :: i_co_gas=0      ! tracer index of co gas
     97      integer :: i_prec_haze=0   ! tracer index of haze
     98      integer :: i_haze=0  ! tracer index of haze
     99      integer :: i_haze10=0  ! tracer index of haze
     100      integer :: i_haze30=0  ! tracer index of haze
     101      integer :: i_haze50=0  ! tracer index of haze
     102      integer :: i_haze100=0  ! tracer index of haze
     103
    95104      REAL emis(1)               ! surface layer
    96105      REAL q2(llm+1)             ! Turbulent Kinetic Energy
     
    100109      REAL du(llm),dv(llm),dtemp(llm)
    101110      REAL dudyn(llm),dvdyn(llm),dtempdyn(llm)
    102       REAL dpsurf(1)   
     111      REAL dpsurf(1)
    103112      REAL,ALLOCATABLE :: dq(:,:)
    104113      REAL,ALLOCATABLE :: dqdyn(:,:)
     
    112121      REAL tmp1(0:llm),tmp2(0:llm)
    113122      integer :: nq !=1 ! number of tracers
    114  
     123
    115124      character*2 str2
    116125      character (len=7) :: str7
     
    123132      real Hscale, Hmax, rho, dz
    124133
     134!     pluto specific
     135      real ch4ref ! % ch4
     136      real coref ! % co
     137      real hazeref ! haze kg/kg
     138      real prechazeref ! prec haze kg/kg
     139
     140
    125141!     added by RW for autozlevs computation
    126142      logical autozlevs
     
    144160c INITIALISATION
    145161c=======================================================================
    146 ! check if 'rcm1d.def' file is around 
     162! check if 'rcm1d.def' file is around
    147163      open(90,file='rcm1d.def',status='old',form='formatted',
    148164     &     iostat=ierr)
     
    203219      endif
    204220      close(90)
    205      
     221
    206222      ! Initialize dimphy module
    207       call init_dimphy(1,llm) 
    208      
     223      call init_dimphy(1,llm)
     224
    209225      ! now initialize arrays using phys_state_var_init
    210226      ! but first initialise naerkind (from callphys.def)
    211227      naerkind=0 !default
    212228      call getin("naerkind",naerkind)
    213      
     229
    214230      call phys_state_var_init(nq)
    215      
     231
    216232      saveprofile=.false.
    217233      saveprofile=.true.
     
    223239      pi=2.E+0*asin(1.E+0)
    224240
    225 c     Parametres Couche limite et Turbulence 
     241c     Parametres Couche limite et Turbulence
    226242c     --------------------------------------
    227       z0 =  1.e-2                ! surface roughness (m) ~0.01 
     243      z0 =  1.e-2                ! surface roughness (m) ~0.01
    228244      emin_turb = 1.e-6          ! energie minimale ~1.e-8
    229245      lmixmin = 30               ! longueur de melange ~100
    230  
     246
    231247c     propriete optiques des calottes et emissivite du sol
    232248c     ----------------------------------------------------
    233249      emissiv= 0.95              ! Emissivite du sol martien ~.95
    234250      emisice(1)=0.95            ! Emissivite calotte nord
    235       emisice(2)=0.95            ! Emissivite calotte sud 
     251      emisice(2)=0.95            ! Emissivite calotte sud
    236252
    237253      iceradius(1) = 100.e-6     ! mean scat radius of n2 snow (north)
     
    242258
    243259c ------------------------------------------------------
    244 c  Load parameters from "run.def" and "gases.def" 
     260c  Load parameters from "run.def" and "gases.def"
    245261c ------------------------------------------------------
    246262
     
    303319            stop
    304320          endif
    305        
     321
    306322          do iq=1,nq
    307323          ! minimal version, just read in the tracer names, 1 per line
     
    313329            endif
    314330          enddo !of do iq=1,nq
    315 ! check for n2_ice / h2o_ice tracers:
    316          i_n2_ice=0
    317          i_h2o_ice=0
    318          i_h2o_vap=0
     331! check for n2 / h2o_ice tracers:
     332         i_n2=0
    319333         do iq=1,nq
    320334           if (tname(iq)=="n2") then
    321              i_n2_ice=iq
    322            elseif (tname(iq)=="h2o_ice") then
    323              i_h2o_ice=iq
    324            elseif (tname(iq)=="h2o_vap") then
    325              i_h2o_vap=iq
     335             i_n2=iq
     336           elseif (tname(iq)=="ch4_ice") then
     337             i_ch4_ice=iq
     338           elseif (tname(iq)=="co_ice") then
     339             i_co_ice=iq
     340           elseif (tname(iq)=="ch4_gas") then
     341             i_ch4_gas=iq
     342           elseif (tname(iq)=="co_gas") then
     343             i_co_gas=iq
    326344           endif
    327345         enddo
     
    339357        nq=0
    340358        ! still, make allocations for 1 dummy tracer
    341         allocate(tname(1)) 
     359        allocate(tname(1))
    342360        allocate(qsurf(1))
    343361        allocate(q(llm,1))
    344362        allocate(dq(llm,1))
    345      
     363
    346364       ! Check that tracer boolean is compliant with number of tracers
    347365       ! -- otherwise there is an error (and more generally we have to be consistent)
     
    361379     !!! GEOPOTENTIAL. useless in 1D because control by surface pressure
    362380      phisfi(1)=0.E+0
    363      !!! LATITUDE. can be set. 
     381     !!! LATITUDE. can be set.
    364382      latitude=0 ! default value for latitude
    365383      PRINT *,'latitude (in degrees) ?'
     
    416434          PRINT *,"STOP. I NEED year_day IN RCM1D.DEF."
    417435          STOP
    418       ELSE 
     436      ELSE
    419437          PRINT *,"--> year_day = ",year_day
    420438      ENDIF
     
    449467          PRINT *,"STOP. peri_day.gt.year_day"
    450468          STOP
    451       ELSE 
     469      ELSE
    452470          PRINT *,"--> peri_day = ", peri_day
    453       ENDIF 
    454 
    455       obliquit = -99999. 
     471      ENDIF
     472
     473      obliquit = -99999.
    456474      PRINT *,'OBLIQUITY in deg ?'
    457475      call getin("obliquit",obliquit)
     
    461479      ELSE
    462480          PRINT *,"--> obliquit = ",obliquit
    463       ENDIF 
     481      ENDIF
    464482
    465483      psurf = -99999.
     
    519537      nday=ndt
    520538
    521       ndt=ndt*day_step     
    522       dtphys=daysec/day_step 
     539      ndt=ndt*day_step
     540      dtphys=daysec/day_step
    523541      write(*,*)"-------------------------------------"
    524542      write(*,*)"-------------------------------------"
     
    545563!!! - read callphys.def
    546564!!! - calculate sine and cosine of longitude and latitude
    547 !!! - calculate mugaz and cp 
     565!!! - calculate mugaz and cp
    548566!!! NB: some operations are being done dummily in inifis in 1D
    549567!!! - physical constants: nevermind, things are done allright below
     
    608626        ENDDO
    609627      ENDDO
    610      
     628
    611629      DO iq=1,nq
    612630        qsurf(iq) = 0.
    613631      ENDDO
    614      
    615       if (tracer) then ! Initialize tracers here. 
    616              
     632
     633      if (tracer) then ! Initialize tracers here.
     634
    617635         write(*,*) "rcm1d : initializing tracers profiles"
    618636
    619637         do iq=1,nq
    620          
    621             txt=""
    622             write(txt,"(a)") tname(iq)
    623             write(*,*)"  tracer:",trim(txt)
    624              
    625             ! n2
    626             if (txt.eq."n2_ice") then
    627                q(:,iq)=0.   ! kg/kg of atmosphere
    628                qsurf(iq)=0. ! kg/m2 at the surface               
    629                ! Look for a "profile_n2_ice" input file
    630                open(91,file='profile_n2_ice',status='old',
    631      &         form='formatted',iostat=ierr)
    632                if (ierr.eq.0) then
    633                   read(91,*) qsurf(iq)
    634                   do ilayer=1,nlayer
    635                      read(91,*) q(ilayer,iq)
    636                   enddo
    637                else
    638                   write(*,*) "No profile_n2_ice file!"
    639                endif
    640                close(91)
    641             endif ! of if (txt.eq."n2")
    642          
    643             ! WATER VAPOUR
    644             if (txt.eq."h2o_vap") then
    645                q(:,iq)=0.   ! kg/kg of atmosphere
    646                qsurf(iq)=0. ! kg/m2 at the surface
    647                ! Look for a "profile_h2o_vap" input file   
    648                open(91,file='profile_h2o_vap',status='old',
    649      &         form='formatted',iostat=ierr)
    650                if (ierr.eq.0) then
    651                   read(91,*) qsurf(iq)
    652                   do ilayer=1,nlayer
    653                      read(91,*) q(ilayer,iq)
    654                   enddo
    655                else
    656                   write(*,*) "No profile_h2o_vap file!"
    657                endif
    658                close(91)
    659             endif ! of if (txt.eq."h2o_vap")
    660            
    661             ! WATER ICE
    662             if (txt.eq."h2o_ice") then
    663                q(:,iq)=0.   ! kg/kg of atmosphere
    664                qsurf(iq)=0. ! kg/m2 at the surface
    665                ! Look for a "profile_h2o_ice" input file
    666                open(91,file='profile_h2o_ice',status='old',
    667      &         form='formatted',iostat=ierr)
    668                if (ierr.eq.0) then
    669                   read(91,*) qsurf(iq)
    670                   do ilayer=1,nlayer
    671                      read(91,*) q(ilayer,iq)
    672                   enddo
    673                else
    674                   write(*,*) "No profile_h2o_ice file!"
    675                endif
    676                close(91)
    677             endif ! of if (txt.eq."h2o_ice")
    678 
    679             !_vap
    680             if((txt .ne. 'h2o_vap') .and.
    681      &                     (index(txt,'_vap'   ) .ne. 0))   then
    682                   q(:,iq)=0. !kg/kg of atmosphere
    683                   qsurf(iq) = 0. !kg/kg of atmosphere
    684                   ! Look for a "profile_...._vap" input file
    685                   tracer_profile_file_name=""
    686                   tracer_profile_file_name='profile_'//txt
    687                   open(91,file=tracer_profile_file_name,status='old',
    688      &            form="formatted",iostat=ierr)
    689                   if (ierr .eq. 0) then
    690                         read(91,*)qsurf(iq)
    691                         do ilayer=1,nlayer
    692                               read(91,*)q(ilayer,iq)
    693                         enddo
    694                   else
    695                         write(*,*) "No initial profile "
    696                         write(*,*) " for this tracer :"
    697                         write(*,*) txt
    698                   endif
    699                   close(91)
    700             endif ! (txt .eq. "_vap")
    701             !_ice
    702             if((txt.ne."h2o_ice") .and.
    703      &                      (index(txt,'_ice'   ) /= 0)) then
    704                   q(:,iq)=0. !kg/kg of atmosphere
    705                   qsurf(iq) = 0. !kg/kg of atmosphere
    706             endif ! we only initialize the solid at 0
     638
     639            if (iq.eq.i_n2) then
     640                DO ilayer=1,nlayer
     641                    q(ilayer,iq) = 1
     642                ENDDO
     643            else if (iq.eq.i_ch4_gas) then
     644                ch4ref=0.5 ! default value for vmr ch4
     645                PRINT *,'vmr CH4 (%) ?'
     646                call getin("ch4ref",ch4ref)
     647                write(*,*) " CH4 ref (%) = ",ch4ref
     648                DO ilayer=1,nlayer
     649                    q(ilayer,iq) = 0.01*ch4ref*16./28.
     650                ENDDO
     651            else if (iq.eq.i_co_gas) then
     652                coref=0.05 ! default value for vmr ch4
     653                PRINT *,'vmr CO (%) ?'
     654                call getin("coref",coref)
     655                write(*,*) " CO ref (%) = ",coref
     656                DO ilayer=1,nlayer
     657                q(ilayer,iq) = 0.01*coref*28./28.
     658                ENDDO
     659            ! else if ((iq.eq.i_haze10).or.(iq.eq.i_haze30).or.(iq.eq.i_haze).or.(iq.eq.i_haze50).or.(iq.eq.i_haze100)) then
     660            !     hazeref=0. ! default value for haze mmr
     661            !     PRINT *,'qhaze (kg/kg) ?'
     662            !     call getin("hazeref",hazeref)
     663            !     write(*,*) " haze ref (kg/kg) = ",hazeref
     664            !     DO ilayer=1,nlayer
     665            !         q(ilayer,iq) = hazeref
     666            !     ENDDO
     667            ! else if (iq.eq.i_prec_haze) then
     668            !     prechazeref=0. ! default value for vmr ch4
     669            !     PRINT *,'qprechaze (kg/kg) ?'
     670            !     call getin("prechazeref",prechazeref)
     671            !     write(*,*) " prec haze ref (kg/kg) = ",prechazeref
     672            !     DO ilayer=1,nlayer
     673            !         q(ilayer,iq) = prechazeref
     674            !     ENDDO
     675
     676            else
     677                DO ilayer=1,nlayer
     678                    q(ilayer,iq) = 0.
     679                ENDDO
     680            endif
    707681         enddo ! of do iq=1,nq
    708          
     682
    709683      endif ! of tracer
    710684
     
    712686c   ------------------------------------------------------
    713687      ptif=2.E+0*omeg*sinlat(1)
    714  
     688
    715689
    716690c    vent geostrophique
     
    748722                   ! value if there is no snow
    749723
    750       if(i_n2_ice.gt.0)then
    751          qsurf(i_n2_ice)=0 ! default value for n2ice
     724      if(i_n2.gt.0)then
     725         qsurf(i_n2)=0 ! default value for n2ice
    752726         print*,'Initial n2 ice on the surface (kg.m-2)'
    753          call getin("n2ice",qsurf(i_n2_ice))
    754          write(*,*) " n2ice = ",qsurf(i_n2_ice)
    755          IF (qsurf(i_n2_ice).ge.1.E+0) THEN
     727         call getin("n2ice",qsurf(i_n2))
     728         write(*,*) " n2ice = ",qsurf(i_n2)
     729         IF (qsurf(i_n2).ge.1.E+0) THEN
    756730            ! if we have some n2 ice on the surface, change emissivity
    757731            if (latitude(1).ge.0) then ! northern hemisphere
     
    793767
    794768      if(autozlevs)then
    795            
     769
    796770         open(91,file="z2sig.def",form='formatted')
    797771         read(91,*) Hscale
     
    800774         enddo
    801775         close(91)
    802  
    803            
     776
     777
    804778         print*,'Hmax = ',Hmax,' km'
    805779         print*,'Auto-shifting Hscale to:'
     
    807781         Hscale = Hmax / log(psurf/pceil)
    808782         print*,'Hscale = ',Hscale,' km'
    809          
     783
    810784! none of this matters if we dont care about zlay
    811          
     785
    812786      endif
    813787
     
    833807            plev(ilevel)=ap(ilevel)+psurf*bp(ilevel)
    834808         ENDDO
    835          
     809
    836810         DO ilayer=1,nlayer
    837811            play(ilayer)=aps(ilayer)+psurf*bps(ilayer)
    838812         ENDDO
    839          
     813
    840814
    841815
     
    914888
    915889c=======================================================================
    916 c  BOUCLE TEMPORELLE DU MODELE 1D 
     890c  BOUCLE TEMPORELLE DU MODELE 1D
    917891c=======================================================================
    918892
     
    933907        ENDIF
    934908
    935 c    calcul du geopotentiel 
     909c    calcul du geopotentiel
    936910c     ~~~~~~~~~~~~~~~~~~~~~
    937911
     
    968942     ,     day,time,dtphys,
    969943     ,     plev,play,phi,
    970      ,     u, v,temp, q, 
     944     ,     u, v,temp, q,
    971945     ,     w,
    972946C - sorties
     
    976950c       evolution du vent : modele 1D
    977951c       -----------------------------
    978  
     952
    979953c       la physique calcule les derivees temporelles de u et v.
    980954c       on y rajoute betement un effet Coriolis.
     
    992966          ENDDO
    993967c       end if
    994 c     
     968c
    995969c
    996970c       Calcul du temps au pas de temps suivant
     
    10561030c    ========================================================
    10571031      end                       !rcm1d
    1058  
    1059 
     1032
     1033
Note: See TracChangeset for help on using the changeset viewer.