Ignore:
Timestamp:
Mar 20, 2020, 6:42:17 PM (5 years ago)
Author:
emillour
Message:

Mars GCM:
Save "dtau", the opacity difference between model and target dust scenario
in the restartfi.nc file so that we have 1+1=2 when running with dust
injection schemes.
EM

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

Legend:

Unmodified
Added
Removed
  • trunk/LMDZ.MARS/libf/phymars/compute_dtau_mod.F90

    r2166 r2265  
    1         MODULE compute_dtau_mod
     1       MODULE compute_dtau_mod
    22
    3         IMPLICIT NONE
     3        IMPLICIT NONE
    44
    55        include "callkeys.h"
    66
    7         REAL,SAVE :: ti_injection_sol ! time of beginning injection
    8         REAL,SAVE :: tf_injection_sol ! time of end injection
     7        REAL,SAVE :: ti_injection_sol ! time of beginning injection
     8        REAL,SAVE :: tf_injection_sol ! time of end injection
    99        REAL,PARAMETER :: t_scenario_sol=14/24.   ! time of tauref_scenario
    1010
    11         CONTAINS
     11        REAL,SAVE,ALLOCATABLE :: dtau(:) ! Dust opacity difference (at 610Pa)
     12                                         ! between GCM and dust scenario
    1213
    13         SUBROUTINE compute_dtau(ngrid,nlayer,                           &
    14        &                        zday,pplev,tauref,                      &
    15        &                        ptimestep,dustliftday,local_time)
     14       CONTAINS
    1615
    17         USE geometry_mod, only: longitude_deg
     16        SUBROUTINE compute_dtau(ngrid,nlayer,                           &
     17                                 zday,pplev,tauref,                     &
     18                                 ptimestep,dustliftday,local_time)
     19
     20        USE geometry_mod, only: longitude_deg
    1821        USE time_phylmdz_mod, only: dtphys, daysec
    1922        USE comcstfi_h, only: g
    2023        USE tracer_mod, only: alpha_lift,igcm_dust_mass,igcm_dust_number
    21         USE dimradmars_mod, only: tauvis
    22        
    23         IMPLICIT NONE
     24        USE dimradmars_mod, only: tauvis
     25       
     26        IMPLICIT NONE
    2427       
    2528        include "callkeys.h"
    26        
     29       
    2730        INTEGER, INTENT(in) :: ngrid
    28         INTEGER, INTENT(in) :: nlayer
     31        INTEGER, INTENT(in) :: nlayer
    2932        REAL, INTENT(in) :: zday ! date at lon=0, in fraction of sols
    30         REAL, INTENT(in) :: pplev(ngrid,nlayer+1) ! pressure (Pa)
    31         REAL, INTENT(in) :: tauref(ngrid) ! Computed dust opacity at 610Pa
    32         REAL, INTENT(in) :: ptimestep
     33        REAL, INTENT(in) :: pplev(ngrid,nlayer+1) ! pressure (Pa)
     34        REAL, INTENT(in) :: tauref(ngrid) ! Computed dust opacity at 610Pa
     35        REAL, INTENT(in) :: ptimestep
    3336        REAL, INTENT(in) :: local_time(ngrid)
    3437        REAL, INTENT(out) :: dustliftday(ngrid) ! Dust injection rate (s-1)
    3538       
    3639        INTEGER :: ig, l
    37         INTEGER, SAVE :: nb_daystep ! nomber of step a day
     40        INTEGER, SAVE :: nb_daystep ! nomber of step a day
    3841        REAL :: tauref_scenario(ngrid) ! from dust scenario
    3942        REAL :: zday_scenario
    4043        REAL,ALLOCATABLE,SAVE :: local_time_prev(:)
    41         REAL,ALLOCATABLE,SAVE :: dtau(:) ! Dust opacity increment (at 610Pa)
    4244        REAL,PARAMETER :: odpref=610. !DOD reference pressure (Pa)
    4345       
     
    4749        IF(firstcall)THEN
    4850                ALLOCATE(local_time_prev(ngrid))
    49                 ALLOCATE(dtau(ngrid))
    5051                DO ig=1,ngrid
    5152                   local_time_prev(ig)=modulo(1.+(zday-ptimestep/daysec)&
    52                                       -INT(zday-ptimestep/daysec)       &
     53                                      -INT(zday-ptimestep/daysec)       &
    5354                                      +(longitude_deg(ig)/15)/24,1.)
    54                    dtau(ig)=0.
    5555                ENDDO
    5656                nb_daystep=(daysec/dtphys)
     
    6161        ENDIF
    6262       
    63         ! 1. Obtain tauref_scenario from dust scenario at zday+1
    64         if (iaervar.eq.1) then
    65           tauref_scenario = tauvis
    66         else
    67           zday_scenario=zday-modulo(zday,1.) ! integer value of the day: the scenario opacity is measured at 14:00
     63        ! 1. Obtain tauref_scenario from dust scenario at zday+1
     64        if (iaervar.eq.1) then
     65          tauref_scenario = tauvis
     66        else
     67          zday_scenario=zday-modulo(zday,1.) ! integer value of the day: the scenario opacity is measured at 14:00
    6868          zday_scenario=zday_scenario+1      ! opacity of the dust scenario is read the day after
    69           call read_dust_scenario(ngrid,nlayer,zday_scenario,pplev,     &
    70        &                          tauref_scenario)
     69          call read_dust_scenario(ngrid,nlayer,zday_scenario,pplev,     &
     70                                         tauref_scenario)
    7171        endif
    7272       ! for diagnostics
    7373        call WRITEDIAGFI(ngrid,"tauref_scenario","tauref_scenario",     &
    74        &                  "",2,tauref_scenario)
     74                          "",2,tauref_scenario)
    7575
    76         ! 2. Compute dtau
    77         DO ig=1,ngrid
    78          IF ((local_time(ig).ge.t_scenario_sol).and.                    &
    79        &          (local_time_prev(ig).lt.(t_scenario_sol)))THEN
    80                  dtau(ig)=tauref_scenario(ig)-tauref(ig)
     76        ! 2. Compute dtau() and dustliftday()
     77        DO ig=1,ngrid
     78         IF ((local_time(ig).ge.t_scenario_sol).and.                    &
     79                 (local_time_prev(ig).lt.(t_scenario_sol)))THEN
     80                 dtau(ig)=tauref_scenario(ig)-tauref(ig)
    8181         ENDIF
     82
     83        ! Use dtau (when positiove) to compute dustliftday
    8284         IF (dtau(ig).LT.0) THEN
    83                   dtau(ig)=0.
     85             dustliftday(ig)=0.
     86         ELSE
     87             dustliftday(ig)=coeff_injection*                           &
     88                        (dtau(ig)*pplev(ig,1)/odpref)                   &
     89                        /(daysec*(tf_injection_sol-ti_injection_sol))
    8490         ENDIF
    85          
    86         ! 3. Use dtau to compute dustliftday
    87          dustliftday(ig)=coeff_injection*                               &
    88        &                (dtau(ig)*pplev(ig,1)/odpref)                   &
    89        &                /(daysec*(tf_injection_sol-ti_injection_sol))
    90         ENDDO
     91        ENDDO ! of DO ig=1,ngrid
     92
     93       ! for diagnostics
     94        call WRITEDIAGFI(ngrid,"dtau","opacity difference wrt scenario",&
     95                          "",2,dtau)
     96        call WRITEDIAGFI(ngrid,"dustliftday","dust injection rate",     &
     97                          "s-1",2,dustliftday)
    9198         
    9299        ! 4. Save local time
     
    95102        end subroutine compute_dtau
    96103
    97         end module compute_dtau_mod
     104!=======================================================================
     105! Initialization of the module variables
     106
     107        subroutine ini_compute_dtau_mod(ngrid)
     108       
     109          implicit none
     110       
     111          integer, intent(in) :: ngrid
     112       
     113          allocate(dtau(ngrid))
     114       
     115        end subroutine ini_compute_dtau_mod
     116       
     117        subroutine end_compute_dtau_mod
     118       
     119          implicit none
     120       
     121          if (allocated(dtau)) deallocate(dtau)
     122
     123          end subroutine end_compute_dtau_mod       
     124
     125       END MODULE compute_dtau_mod
  • trunk/LMDZ.MARS/libf/phymars/phyetat0_mod.F90

    r2264 r2265  
    1818  use ioipsl_getincom, only : getin
    1919  use nonoro_gwd_ran_mod, only: du_nonoro_gwd, dv_nonoro_gwd
     20  use compute_dtau_mod, only: dtau
     21
    2022  implicit none
    2123 
     
    342344endif
    343345
     346! dtau: opacity difference between GCM and dust scenario
     347call get_field("dtau",dtau,found,indextime)
     348if (.not.found) then
     349  write(*,*) "phyetat0: <dtau> not in file; set to zero"
     350  dtau(:) = 0
     351else
     352  write(*,*) "phyetat0: opacity diff wrt scenario <dtau> range:", &
     353             minval(dtau), maxval(dtau)
     354endif
     355
     356
    344357! Sub-grid cloud fraction
    345358call get_field("totcloudfrac",totcloudfrac,found,indextime)
  • trunk/LMDZ.MARS/libf/phymars/phyredem.F90

    r2260 r2265  
    156156  use tracer_mod, only: noms ! tracer names
    157157  use nonoro_gwd_ran_mod, only: du_nonoro_gwd, dv_nonoro_gwd
     158  use compute_dtau_mod, only: dtau
    158159
    159160  implicit none
     
    226227  call put_field("tauscaling","dust conversion factor",tauscaling,time)
    227228
     229  if (dustinjection.gt.0) then
     230    call put_field("dtau","dust opacity difference between GCM and scenario",&
     231                   dtau,time)
     232  endif
     233
    228234  if (calltherm) then
    229235    call put_field("wstar","Max vertical velocity in thermals",wstar,time)
  • trunk/LMDZ.MARS/libf/phymars/phys_state_var_init_mod.F90

    r2223 r2265  
    4848      use time_phylmdz_mod, only: init_time
    4949      use co2cloud_mod, only: ini_co2cloud,end_co2cloud
     50      use compute_dtau_mod, only: ini_compute_dtau_mod, &
     51                                  end_compute_dtau_mod
    5052      use rocketduststorm_mod, only: ini_rocketduststorm_mod, &
    5153                                     end_rocketduststorm_mod
     
    126128      call ini_co2cloud(ngrid,nlayer)
    127129     
     130      ! allocate arrays in "compute_dtau_mod":
     131      call end_compute_dtau_mod
     132      call ini_compute_dtau_mod(ngrid)
     133
    128134      ! allocate arrays in "rocketduststorm_mod":
    129135      call end_rocketduststorm_mod
  • trunk/LMDZ.MARS/libf/phymars/physiq_mod.F

    r2260 r2265  
    909909            ENDIF ! (CLFvarying)
    910910           
    911 !           ! Dustinjection
    912 !           if (dustinjection.gt.0) then
    913 !             CALL compute_dtau(ngrid,nlayer,
    914 !     &                         zday,pplev,tauref,
    915 !     &                         ptimestep,dustliftday,local_time)
    916 !           endif
    917 c============================================================================
     911!============================================================================
    918912           
    919913#ifdef DUSTSTORM
     
    20242018      ENDDO
    20252019
    2026 c     Test watercap
    2027 c      DO ig=1,ngrid
    2028 c         qsurf(iq,igcm_h2o_ice)=qsurf(iq,igcm_h2o_ice)+watercap(ig)
    2029 c      ENDDO
    2030 
    20312020c-----------------------------------------------------------------------
    20322021c  13. Write output files
Note: See TracChangeset for help on using the changeset viewer.