Difference between revisions of "Dust Cycle in Mars PCM6"

From Planets
Jump to: navigation, search
(Level 2 (developper) : Parametrizations and tunable parameters)
 
(18 intermediate revisions by the same user not shown)
Line 1: Line 1:
Beginning a page on the dust cycle in Mars PCM6. '''This is still work in progress for now !'''
+
This page details at different levels how to use and what is featured in the dust cycle in Mars PCM6. '''This is still work in progress for now !'''
  
 +
== Level 1 (user) : Flags for PCM6 dust cycle ==
 +
To run a simulation with the PCM6 dust cycle, you need to set up several flags and parameters in your ''callphys.def'' (see an example here: https://trac.lmd.jussieu.fr/Planeto/browser/trunk/LMDZ.MARS/deftank/callphys.def.GCM6)
  
À 14h, si le scénario du jour d'après donne une opacité de 5 alors que le jour actuel, le GCM a une opacité disons de 1 dans la colonne :
+
We list below all the relevant flags and parameters directly related to PCM6 dust cycle :
 +
<syntaxhighlight lang="bash" line>
 +
##General options
 +
##~~~~~~~~~~~~~~~
 +
#Directory where external input files are:
 +
datadir=/path/to/datadir
  
1. on calcule le dtau=5-1=4, puis ce que ça ferait comme quantité de poussière à 3µm à ajouter dans l'atmosphère
+
#Run with or without tracer transport ?
 +
tracer=.true.
 +
.
 +
.
 +
.
  
2. on injecte cette quantité de poussière nuancée par un coef Cinj pour prendre en compte que le saut de tau_scenario peut venir non pas d'injection locale mais de transports depuis les autres mailles. En pratique, Cinj=0.25, ce qui donne une injection de ~5e-8kg/m²/s
+
## Dust scenario. Used to prescribe the dust
 +
## ~~~~~~~~~~~~~
 +
#  =1 Dust opt.deph read in startfi; =2 Viking scenario; =3 MGS scenario [default],
 +
=4 Mars Year 24 from TES assimilation (old version of MY24; dust_tes.nc file)
 +
#  =6 "cold" (low dust) scenario ; =7 "warm" (high dust) scenario
 +
#  =8 "climatology" (our best guess of a typical Mars year) scenario
 +
#  =24 Mars Year 24 from TES assimilation (ie: MCD reference case)
 +
#  =25 Mars Year 25 from TES assimilation (ie: a year with a global dust storm)
 +
#  =26 Mars Year 26 from TES assimilation
 +
#  ...
 +
#  =35 Mars Year 35 from observers assimilation
 +
iaervar = 8
 +
.
 +
.
 +
.
  
3. toute cette poussière est injectée de manière uniforme entre le 14h actuel et 14h du jour d'après sous forme de stormdust dans la 1ère couche par vdifc, qui la mélange déjà un peu sur plusieurs couches, avant qu'elle ne passe par les thermiques/l'ajustement convectif, la sédimentation (mais on empêche la stormdust de tomber au sol, elle reste dans la 1ère couche à la place), et 5 pas de temps de dynamique
+
# Dust IR opacity ref. wavelength (for dso diagnostics only)
 +
# "tes" (9.3 microns) [default] or "mcs" (21.6 microns)
 +
dustiropacity = tes
 +
# Use an IR to VIS scenario conversion coefficient that is
 +
# dependent on the GCM dust effective radius,
 +
# instead of a fixed 2.6 coefficient ?
 +
#(only if dustiropacity = tes ; default = .false.)
 +
reff_driven_IRtoVIS_scenario = .true.
  
4. une fois retourné au pas de temps physique suivant, on calcule la fraction sous-maille à partir du maximum de mass mixing ratio de stormdust dans toute la colonne (à part la 1ère couche (?) ), par rapport à un mixing ratio de référence mmr_ref=5e-4kg/kg que l'on considère représentatif d'une opacité de 10 (telle que mesurée dans une local dust storm par OMEGA)
+
## Physical Parameterizations :
 +
## ~~~~~~~~~~~~~~~~~~~~~~~~~~
 +
# call radiative transfer ? (default=.true.)
 +
callrad  = .true.
 +
.
 +
.
 +
.
  
5. enfin, on rentre dans la routine rocketduststorm, où on regarde si qqpart dans la colonne, le mmr de stormdust (non-concentré dans la fraction sous-maille) est supérieur à 10^(-4) fois celui du background dust. Si c'est le cas, on active le schéma dans la colonne, et on calcule l'écart de chauffage entre la fraction sous-maille et la maille totale, le transport vertical qui en résulte dans la fraction sous-maille, et le détraînement. Si ce n'est pas le cas (pas assez de stormdust nulle part dans la colonne) on détraîne tout
 
  
 +
## Radiative transfer options :
 +
## ~~~~~~~~~~~~~~~~~~~~~~~~~~
 +
.
 +
.
 +
.
 +
 +
# SCATTERERS: set number of scatterers.
 +
# Must be compliant with other options: +1 if active, +1 if rdstorm, +1 if topflows, +1 if activice ; default=1)
 +
naerkind = 4
 +
 +
## Tracer (dust water, ice and/or chemical species) options (used if tracer=T):
 +
## ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 +
# DUST: Transported dust ? (if >0, use 'dustbin' dust bins ; default=0)
 +
dustbin    = 2
 +
# DUST: Radiatively active dust ? (matters if dustbin>0 ; default=.false.)
 +
active  = .true.
 +
# DUST: use mass and number mixing ratios to predict dust size ? (default=.false.)
 +
doubleq  = .true.
 +
.
 +
.
 +
.
 +
# DUST: lifted by GCM surface winds ? (default=.false.)
 +
lifting = .true.
 +
.
 +
.
 +
.
 +
# DUST: Scavenging by H2O snowfall ? (default=.false.)
 +
scavenging = .true.
 +
 +
# DUST: freedust ? (default=.false.)
 +
freedust=.true.
 +
# DUST: dustscaling_mode?
 +
#    =0 --> freedust, tauscaling=1
 +
#    =1 --> GCM5.3-like, tauscaling
 +
#    =2 --> tauscaling=1,dust_rad_adjust
 +
dustscaling_mode=2
 +
# DUST: dust injection scheme (if >0, use 'dustinjection' ; default=0)
 +
dustinjection=1
 +
# DUST: dust injection scheme coefficient (default=0.25)
 +
coeff_injection=0.25
 +
# DUST: dust injection scheme initial local time (default=0.)
 +
ti_injection=0.
 +
# DUST: dust injection scheme final local time (default=24.)
 +
tf_injection=24.
 +
# DUST: Rocket Dust Storm scheme (default=.false.)
 +
rdstorm=.true.
 +
# DUST: RDS detrainment coefficient (default=0.02)
 +
coeff_detrainment=0.02
 +
# DUST: Dust entrainment by subgrid-scale slope winds (default=.false.)
 +
topflows=.true.
 +
 +
# DUST/WATERICE: Scavenging by CO2 condensation? (default=.false.)
 +
scavco2cond = .true.
 +
# DUST/WATERICE: Gravitationnal sedimentation ? (default=.true.)
 +
sedimentation = .true.
 +
 +
.
 +
.
 +
.
 +
 +
</syntaxhighlight>
 +
 +
'''Note''' that the PCM6 dust cycle has mainly been tested with the non-dust-related flags and parameters that are featured in ''callphys.def.GCM6'' and ''callphys.def.MCD6'' (cf https://trac.lmd.jussieu.fr/Planeto/browser/trunk/LMDZ.MARS/deftank/), and in general with the ''*.def'' files (''run.def'', ''traceur.def'', ''z2sig.def'') that are suffixed with ''.GCM6'' or ''.MCD6''. If you depart from these files, even for non-dust related processes, we do not ensure the good tuning of the dust cycle, nor to a lesser extent the good compilation/execution of the model. If this happens, please reach out to us !
 +
 +
 +
== Level 2 (developper) : Parametrizations and tunable parameters ==
 +
The technical document that sums up the features of the dust cycle in the PCM6, referred to as TN2022_ESA below, can be found here : https://www-mars.lmd.jussieu.fr/esa/contract2020_2022/deliverables/MS3/D2.1_dust_cycle.pdf
 +
 +
For more insights into the development and tuning of all the parametrizations related to the PCM6 Dust Cycle, please find below the reference technical documents :
 +
* TN2019_ESA : https://www-mars.lmd.jussieu.fr/WP2018/LMD_gcm_report_part1_dust.pdf
 +
* TN2019_CNES : https://www-mars.lmd.jussieu.fr/cnes/2019/LMD_CNES_EXM_gcm6.0.pdf
 +
* TN2020_CNES : https://www-mars.lmd.jussieu.fr/cnes/2020/note_technique_GCM_dust.pdf
 +
* TN2021_CNES : https://www-mars.lmd.jussieu.fr/cnes/2021/note_technique_dust_cycle2021.pdf
 +
* TN2022_ESA : https://www-mars.lmd.jussieu.fr/esa/contract2020_2022/deliverables/MS3/D2.1_dust_cycle.pdf ; ''Erratum : in section 2 of this document, it is said that "Corrected values for [ the assumptions done on the tuple ($$r_{eff}$$,$$Q_{ext}$$) ] which were a bit erroneous, lead to a typical opacity of 6 instead of 10 for the dust storm we simulate in the model using $$q_{storm,ref}$$ = $$5 × 10^{−4}$$kg/kg" (<span style="color:red;">mmr_ref</span>). These "corrected" values were actually wrong. If we consider $$r_{eff}$$=2µm like in [https://doi.org/10.1002/2017JE005255 Wang et al. (2018)] or TN2019_ESA, using a mmr_ref of 5e-4kg/kg leads to an opacity of 10.5. If we use $$r_{eff}$$=3µm like the default <span style="color:red;">reff_lift</span>, this leads to an opacity of 6.6.''
 +
 +
The table below sums up all the parameters related to PCM6 Dust Cycle, a short description, their default value in PCM6, a reasonable range that can explored for tuning, where to find/modify them in the code, and references addressing their tuning in the PCM or their explorable range according to our current knowledge of Mars climate.
 +
 +
{| class="wikitable" style="margin:auto"
 +
! Process !! Parameter !! Description !! Default value !! Reasonable range for tuning !! In the code
 +
(D: declaration ; A: assignment ; U: use)
 +
! References
 +
|-
 +
|rowspan="7"|Injection
 +
|| <span style="color:red;">'''coeff_injection'''</span> || Injection coefficient $$C_{inj}$$ [no unit] || style="text-align:center;"| 0.25 || style="text-align:center;"| 0 - 1 || ''callkeys.h'' (D) ; ''conf_phys.F'' (A) ; ''compute_dtau_mod.F90'' (U) || TN2019_CNES, TN2020_CNES, TN2022_ESA
 +
|-
 +
|| <span style="color:red;">'''ti_injection'''</span> || Beginning local time for injection window [h] || style="text-align:center;"| 0 || style="text-align:center;"| 0 - 18 || ''callkeys.h'' (D) ; ''conf_phys.F'' (A) ; ''compute_dtau_mod.F90'' (U) ; ''vdifc_mod.F'' (U) || TN2019_ESA, TN2019_CNES, TN2020_CNES, TN2022_ESA
 +
|-
 +
|| <span style="color:red;">'''tf_injection'''</span> || Ending local time for injection window [h] || style="text-align:center;"| 24 || style="text-align:center;"| 6 - 24 || ''callkeys.h'' (D) ; ''conf_phys.F'' (A) ; ''compute_dtau_mod.F90'' (U) ; ''vdifc_mod.F'' (U) || TN2019_ESA, TN2019_CNES, TN2020_CNES, TN2022_ESA
 +
|-
 +
|| <span style="color:red;">'''reff_lift'''</span> || Effective radius of injected dust [m] || style="text-align:center;"| 3e-6 || style="text-align:center;"| 1e-6 - 5e-6 || ''initracer.F'' (D,A,U) ; impacts ''vdifc_mod.F''  || TN2021_CNES
 +
|-
 +
|| <span style="color:red;">'''reff_storm'''</span> || Effective radius of injected dust when <span style="color:red;">rdstorm</span>=.true. [m] || style="text-align:center;"| 3e-6 || style="text-align:center;"| (should be equal to reff_lift) || ''initracer.F'' (D,A,U) ; impacts ''vdifc_mod.F'' || TN2021_CNES
 +
|-
 +
|| <span style="color:red;">'''nueff_lift'''</span> || Effective variance of injected dust [no unit] ; is also the variance in the atmosphere <span style="color:red;">nueffdust</span> || style="text-align:center;"| 0.5 || style="text-align:center;"| 0.2 - 0.6 || ''initracer.F'' (D,A,U) ; impacts ''aeroptproperties.F'', ''callsedim_mod.F'' || [https://doi.org/10.1029/2006JE002786 Wolff et al. (2006)], [https://doi.org/10.1029/2020JE006419 Luginin et al. (2020)]
 +
|-
 +
|| $$Q_{ext}$$ for <span style="color:red;">'''alpha_lift(igcm_[dust<nowiki>|</nowiki>stormdust]_mass)'''</span> || Extinction coefficient in the visible [no unit] used for the lifted mass coefficient ; should depend on <span style="color:red;">reff_[lift<nowiki>|</nowiki>storm]</span> and <span style="color:red;">nueff_lift</span> || style="text-align:center;"| 2.4  (hard-coded, no variable) || style="text-align:center;"| (for $$\nu _{eff}$$=0.5)
 +
$$r_{eff}$$=3µm -> $$Q_{ext}$$=2.46 ;
 +
$$r_{eff}$$=2.5µm -> $$Q_{ext}$$=2.5 ;
 +
$$r_{eff}$$=2µm -> $$Q_{ext}$$=2.6 ;
 +
$$r_{eff}$$=1µm -> $$Q_{ext}$$=2.85 ;
 +
|| ''initracer.F'' (A,U) ; impacts ''vdifc_mod.F''
 +
|-
 +
|-
 +
|rowspan="3"|Rocket dust storm
 +
|| <span style="color:red;">'''mmr_ref'''</span> || Reference mass mixing ratio [kg/kg] for the rocket dust storm sub-mesh fraction || style="text-align:center;"| 5e-4 || style="text-align:center;"| 2.5e-4 - 7.5e-4 || ''calcstormfract_mod.F90'' (D,A,U) ; impacts ''rocketduststorm_mod.F90'', ''callradite_mod.F90'' || TN2019_ESA, [https://doi.org/10.1002/2017JE005255 Wang et al. (2018)], TN2022_ESA
 +
|-
 +
|| <span style="color:red;">'''fracmin'''</span> ; <span style="color:red;">'''fracmax'''</span> || Bounds for the rocket dust storm sub-mesh fraction [no unit] || style="text-align:center;"| 0.01 ; 0.6 || style="text-align:center;"| 0 - 1 || ''calcstormfract_mod.F90'' (D,A,U) ; impacts ''rocketduststorm_mod.F90'', ''callradite_mod.F90'' || TN2022_ESA
 +
|-
 +
|| <span style="color:red;">'''coeff_detrainment'''</span> || Detrainment coefficient $$C_{det}$$ [no unit] || style="text-align:center;"| 0.02 || style="text-align:center;"| 0 - 1'''*''' || ''callkeys.h'' (D) ; ''conf_phys.F'' (A) ; ''rocketduststorm_mod.F90'' (U) || TN2019_CNES, TN2020_CNES, TN2022_ESA
 +
|-
 +
|rowspan="3"|Mountain top flows
 +
|| $$C_{mons}$$ for <span style="color:red;">'''alpha_hmons'''</span> || Dampening coefficient $$C_{mons}$$ [no unit] for the mountain top flows sub-mesh fraction || style="text-align:center;"| 0.5 (hard-coded, no variable) || style="text-align:center;"| 0 - 1 || ''topmons_mod.F90'' (A,U) || TN2020_CNES, TN2021_CNES, TN2022_ESA
 +
|-
 +
|| <span style="color:red;">'''k0'''</span> ; <span style="color:red;">'''k1'''</span> ; <span style="color:red;">'''k2'''</span> || Coefficients [m/s ; m$$^{-1}$$ ; no unit] for the slope winds vertical velocity || style="text-align:center;"| 0.25 ; 5e-4 ; 5e-3  (wmax = 3m/s) || style="text-align:center;"| 1. ; 5e-4 ; 30e-3  (wmax = 10m/s) || ''topmons_mod.F90'' (D,A,U) || TN2019_CNES
 +
|-
 +
|| $$C_{detr}$$ for <span style="color:red;">'''coefdetrain'''</span> || Dampening coefficient $$C_{detr}$$ [no unit] for the mountain top flows detrainment || style="text-align:center;"| 1. (hard-coded, no variable) || style="text-align:center;"| 0 - 1 || ''topmons_mod.F90'' (A,U) || TN2019_CNES
 +
|-
 +
|rowspan="1"|Sedimentation
 +
|| $$\beta$$ in call of newsedim for dust, stormdust and topdust || Particle shape correction factor for the Stokes-Cunningham sedimentation velocity [no unit] || style="text-align:center;"| 0.5 (hard-coded, no variable) || style="text-align:center;"| 0.5 - 1
 +
(disk -> irregular -> sphere)
 +
|| ''callsedim_mod.F90'' (A,U) || [https://doi.org/10.1029/JB095iB09p14629 Murphy et al. (1990)]
 +
|}
 +
 +
'''''*'''Note on the rocket dust storm detrainment : The rocket dust storm detrainment, currently tuned with the coefficient <span style="color:red;">coeff_detrainment</span>, should actually be revisited to match the one that is done for mountain top flows. (ticket [ #...])''
 +
 +
== What's going on for rocket dust storms and injection : a detailed example through the physics parametrizations ==
 +
We detail below the successive steps and processes performed concerning the coupling between the rocket dust storms and the dust injection. We place ourselves in one column of the model, which will serve as an example. The Fortran subroutines that are involved at each step are referred as '''''subroutine'''''.
 +
 +
0. as we reach 2pm in this column, we read and interpolate the value of the optical depth scenario for the next day ('''''compute_dtau'''''). Let's say the scenario features an opacity of 5 (big dusty event), while the current day's GCM column has an opacity of 1 (which has been computed before, in '''''aeropacity''''')
 +
 +
1. ('''''compute_dtau''''') we calculate the optical depth difference dtau=5-1=4, then what this means in terms of dust mass to be added to the atmosphere, assuming an effective size reff_lift = 3µm by default (defined in '''''initracer'''''). We dampen this quantity of dust by a coefficient Cinj (=0.25 by default) to take into account that the jump in tau_pref_scenario from the current day to the next may not come from local injection but from transport from adjacent meshes. For the values considered in this example, this gives an injection of ~5e-8 kg/m²/s.
 +
 +
2. all this dust is injected uniformly during the injection window, by default between 2 p.m. this day and 2 p.m. the next day (when we are supposed to reach the scenario target), in the form of stormdust into the 1st layer by '''''vdifc''''', which already mixes it a little on several layers. Then this stormdust undergoes processes like thermals ('''''calltherm_interface'''''), convective adjustment ('''''convadj''''') and sedimentation ('''''callsedim''''') that further mix it in the atmosphere. For the latter, stormdust is prevented from falling to the ground, and remains in the 1st layer instead. We need to do so, because the main process responsible for the stormdust rising, represented by the routine '''''rocketduststorm''''', only happens at the beginning of the next timestep (see point 5).
 +
 +
3. the stormdust is further mixed by the dynamics, and may also be transported to adjacent meshes. The column may also receive stormdust from other meshes.
 +
 +
4. once back to the next physical time step, we calculate a sub-mesh fraction that is representative of the size of the stormdust plume ('''''calcstormfract'''''). To do so, we use the maximum mass mixing ratio of stormdust in the entire column (apart from the 1st layer), and compute the sub-mesh fraction that is needed to reach a reference mixing ratio mmr_ref=5e-4kg/kg. This reference mmr is a value that we consider representative of an opacity of 10 that was measured in a local dust storm by OMEGA, given some assumptions like a vertical extent of $$\Delta P$$=200Pa for the dust plume (''see also Wang et al. 2018, JGRPlanets, doi:10.1002/2017JE005255'').
 +
 +
5. finally, we enter the '''''rocketduststorm''''' routine, where we check whether anywhere in the column, the mmr of stormdust (not concentrated in the sub-mesh fraction, but expanded to the whole mesh) is greater than $$10^{-4}$$ times that of background dust. If so, we activate the scheme in the column, and calculate the heating difference between the sub-mesh fraction (where we have concentrated stormdust, and background dust) and the rest of the mesh (only background dust), the resulting vertical transport in the sub-mesh fraction, and the horizontal detrainment where the stormdust plume vertical velocity decreases. If there is not enough stormdust compared to background dust at any level, the stormdust is detrained into background dust at all levels of the column.
  
  
 
[[Category:Mars-Model]]
 
[[Category:Mars-Model]]

Latest revision as of 23:30, 7 January 2024

This page details at different levels how to use and what is featured in the dust cycle in Mars PCM6. This is still work in progress for now !

Level 1 (user) : Flags for PCM6 dust cycle

To run a simulation with the PCM6 dust cycle, you need to set up several flags and parameters in your callphys.def (see an example here: https://trac.lmd.jussieu.fr/Planeto/browser/trunk/LMDZ.MARS/deftank/callphys.def.GCM6)

We list below all the relevant flags and parameters directly related to PCM6 dust cycle :

  1 ##General options
  2 ##~~~~~~~~~~~~~~~
  3 #Directory where external input files are:
  4 datadir=/path/to/datadir
  5 
  6 #Run with or without tracer transport ?
  7 tracer=.true.
  8 .
  9 .
 10 .
 11 
 12 ## Dust scenario. Used to prescribe the dust
 13 ## ~~~~~~~~~~~~~
 14 #  =1 Dust opt.deph read in startfi; =2 Viking scenario; =3 MGS scenario [default],
 15 #  =4 Mars Year 24 from TES assimilation (old version of MY24; dust_tes.nc file)
 16 #  =6 "cold" (low dust) scenario ; =7 "warm" (high dust) scenario
 17 #  =8 "climatology" (our best guess of a typical Mars year) scenario
 18 #  =24 Mars Year 24 from TES assimilation (ie: MCD reference case)
 19 #  =25 Mars Year 25 from TES assimilation (ie: a year with a global dust storm)
 20 #  =26 Mars Year 26 from TES assimilation
 21 #  ...
 22 #  =35 Mars Year 35 from observers assimilation
 23 iaervar = 8
 24 .
 25 .
 26 .
 27 
 28 # Dust IR opacity ref. wavelength (for dso diagnostics only)
 29 # "tes" (9.3 microns) [default] or "mcs" (21.6 microns)
 30 dustiropacity = tes
 31 # Use an IR to VIS scenario conversion coefficient that is
 32 # dependent on the GCM dust effective radius,
 33 # instead of a fixed 2.6 coefficient ?
 34 #(only if dustiropacity = tes ; default = .false.)
 35 reff_driven_IRtoVIS_scenario = .true.
 36 
 37 ## Physical Parameterizations :
 38 ## ~~~~~~~~~~~~~~~~~~~~~~~~~~
 39 # call radiative transfer ? (default=.true.)
 40 callrad   = .true.
 41 .
 42 .
 43 .
 44 
 45 
 46 ## Radiative transfer options :
 47 ## ~~~~~~~~~~~~~~~~~~~~~~~~~~
 48 .
 49 .
 50 .
 51 
 52 # SCATTERERS: set number of scatterers.
 53 # Must be compliant with other options: +1 if active, +1 if rdstorm, +1 if topflows, +1 if activice ; default=1)
 54 naerkind = 4
 55 
 56 ## Tracer (dust water, ice and/or chemical species) options (used if tracer=T):
 57 ## ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 58 # DUST: Transported dust ? (if >0, use 'dustbin' dust bins ; default=0)
 59 dustbin    = 2
 60 # DUST: Radiatively active dust ? (matters if dustbin>0 ; default=.false.)
 61 active  = .true.
 62 # DUST: use mass and number mixing ratios to predict dust size ? (default=.false.)
 63 doubleq   = .true.
 64 .
 65 .
 66 .
 67 # DUST: lifted by GCM surface winds ? (default=.false.)
 68 lifting = .true.
 69 .
 70 .
 71 .
 72 # DUST: Scavenging by H2O snowfall ? (default=.false.)
 73 scavenging = .true.
 74 
 75 # DUST: freedust ? (default=.false.)
 76 freedust=.true.
 77 # DUST: dustscaling_mode?
 78 #     =0 --> freedust, tauscaling=1
 79 #     =1 --> GCM5.3-like, tauscaling
 80 #     =2 --> tauscaling=1,dust_rad_adjust
 81 dustscaling_mode=2
 82 # DUST: dust injection scheme (if >0, use 'dustinjection' ; default=0)
 83 dustinjection=1
 84 # DUST: dust injection scheme coefficient (default=0.25)
 85 coeff_injection=0.25
 86 # DUST: dust injection scheme initial local time (default=0.)
 87 ti_injection=0.
 88 # DUST: dust injection scheme final local time (default=24.)
 89 tf_injection=24.
 90 # DUST: Rocket Dust Storm scheme (default=.false.)
 91 rdstorm=.true.
 92 # DUST: RDS detrainment coefficient (default=0.02)
 93 coeff_detrainment=0.02
 94 # DUST: Dust entrainment by subgrid-scale slope winds (default=.false.)
 95 topflows=.true.
 96 
 97 # DUST/WATERICE: Scavenging by CO2 condensation? (default=.false.)
 98 scavco2cond = .true.
 99 # DUST/WATERICE: Gravitationnal sedimentation ? (default=.true.)
100 sedimentation = .true.
101 
102 .
103 .
104 .

Note that the PCM6 dust cycle has mainly been tested with the non-dust-related flags and parameters that are featured in callphys.def.GCM6 and callphys.def.MCD6 (cf https://trac.lmd.jussieu.fr/Planeto/browser/trunk/LMDZ.MARS/deftank/), and in general with the *.def files (run.def, traceur.def, z2sig.def) that are suffixed with .GCM6 or .MCD6. If you depart from these files, even for non-dust related processes, we do not ensure the good tuning of the dust cycle, nor to a lesser extent the good compilation/execution of the model. If this happens, please reach out to us !


Level 2 (developper) : Parametrizations and tunable parameters

The technical document that sums up the features of the dust cycle in the PCM6, referred to as TN2022_ESA below, can be found here : https://www-mars.lmd.jussieu.fr/esa/contract2020_2022/deliverables/MS3/D2.1_dust_cycle.pdf

For more insights into the development and tuning of all the parametrizations related to the PCM6 Dust Cycle, please find below the reference technical documents :

The table below sums up all the parameters related to PCM6 Dust Cycle, a short description, their default value in PCM6, a reasonable range that can explored for tuning, where to find/modify them in the code, and references addressing their tuning in the PCM or their explorable range according to our current knowledge of Mars climate.

Process Parameter Description Default value Reasonable range for tuning In the code

(D: declaration ; A: assignment ; U: use)

References
Injection coeff_injection Injection coefficient $$C_{inj}$$ [no unit] 0.25 0 - 1 callkeys.h (D) ; conf_phys.F (A) ; compute_dtau_mod.F90 (U) TN2019_CNES, TN2020_CNES, TN2022_ESA
ti_injection Beginning local time for injection window [h] 0 0 - 18 callkeys.h (D) ; conf_phys.F (A) ; compute_dtau_mod.F90 (U) ; vdifc_mod.F (U) TN2019_ESA, TN2019_CNES, TN2020_CNES, TN2022_ESA
tf_injection Ending local time for injection window [h] 24 6 - 24 callkeys.h (D) ; conf_phys.F (A) ; compute_dtau_mod.F90 (U) ; vdifc_mod.F (U) TN2019_ESA, TN2019_CNES, TN2020_CNES, TN2022_ESA
reff_lift Effective radius of injected dust [m] 3e-6 1e-6 - 5e-6 initracer.F (D,A,U) ; impacts vdifc_mod.F TN2021_CNES
reff_storm Effective radius of injected dust when rdstorm=.true. [m] 3e-6 (should be equal to reff_lift) initracer.F (D,A,U) ; impacts vdifc_mod.F TN2021_CNES
nueff_lift Effective variance of injected dust [no unit] ; is also the variance in the atmosphere nueffdust 0.5 0.2 - 0.6 initracer.F (D,A,U) ; impacts aeroptproperties.F, callsedim_mod.F Wolff et al. (2006), Luginin et al. (2020)
$$Q_{ext}$$ for alpha_lift(igcm_[dust|stormdust]_mass) Extinction coefficient in the visible [no unit] used for the lifted mass coefficient ; should depend on reff_[lift|storm] and nueff_lift 2.4 (hard-coded, no variable) (for $$\nu _{eff}$$=0.5)

$$r_{eff}$$=3µm -> $$Q_{ext}$$=2.46 ; $$r_{eff}$$=2.5µm -> $$Q_{ext}$$=2.5 ; $$r_{eff}$$=2µm -> $$Q_{ext}$$=2.6 ; $$r_{eff}$$=1µm -> $$Q_{ext}$$=2.85 ;

initracer.F (A,U) ; impacts vdifc_mod.F
Rocket dust storm mmr_ref Reference mass mixing ratio [kg/kg] for the rocket dust storm sub-mesh fraction 5e-4 2.5e-4 - 7.5e-4 calcstormfract_mod.F90 (D,A,U) ; impacts rocketduststorm_mod.F90, callradite_mod.F90 TN2019_ESA, Wang et al. (2018), TN2022_ESA
fracmin ; fracmax Bounds for the rocket dust storm sub-mesh fraction [no unit] 0.01 ; 0.6 0 - 1 calcstormfract_mod.F90 (D,A,U) ; impacts rocketduststorm_mod.F90, callradite_mod.F90 TN2022_ESA
coeff_detrainment Detrainment coefficient $$C_{det}$$ [no unit] 0.02 0 - 1* callkeys.h (D) ; conf_phys.F (A) ; rocketduststorm_mod.F90 (U) TN2019_CNES, TN2020_CNES, TN2022_ESA
Mountain top flows $$C_{mons}$$ for alpha_hmons Dampening coefficient $$C_{mons}$$ [no unit] for the mountain top flows sub-mesh fraction 0.5 (hard-coded, no variable) 0 - 1 topmons_mod.F90 (A,U) TN2020_CNES, TN2021_CNES, TN2022_ESA
k0 ; k1 ; k2 Coefficients [m/s ; m$$^{-1}$$ ; no unit] for the slope winds vertical velocity 0.25 ; 5e-4 ; 5e-3 (wmax = 3m/s) 1. ; 5e-4 ; 30e-3 (wmax = 10m/s) topmons_mod.F90 (D,A,U) TN2019_CNES
$$C_{detr}$$ for coefdetrain Dampening coefficient $$C_{detr}$$ [no unit] for the mountain top flows detrainment 1. (hard-coded, no variable) 0 - 1 topmons_mod.F90 (A,U) TN2019_CNES
Sedimentation $$\beta$$ in call of newsedim for dust, stormdust and topdust Particle shape correction factor for the Stokes-Cunningham sedimentation velocity [no unit] 0.5 (hard-coded, no variable) 0.5 - 1

(disk -> irregular -> sphere)

callsedim_mod.F90 (A,U) Murphy et al. (1990)

*Note on the rocket dust storm detrainment : The rocket dust storm detrainment, currently tuned with the coefficient coeff_detrainment, should actually be revisited to match the one that is done for mountain top flows. (ticket [ #...])

What's going on for rocket dust storms and injection : a detailed example through the physics parametrizations

We detail below the successive steps and processes performed concerning the coupling between the rocket dust storms and the dust injection. We place ourselves in one column of the model, which will serve as an example. The Fortran subroutines that are involved at each step are referred as subroutine.

0. as we reach 2pm in this column, we read and interpolate the value of the optical depth scenario for the next day (compute_dtau). Let's say the scenario features an opacity of 5 (big dusty event), while the current day's GCM column has an opacity of 1 (which has been computed before, in aeropacity)

1. (compute_dtau) we calculate the optical depth difference dtau=5-1=4, then what this means in terms of dust mass to be added to the atmosphere, assuming an effective size reff_lift = 3µm by default (defined in initracer). We dampen this quantity of dust by a coefficient Cinj (=0.25 by default) to take into account that the jump in tau_pref_scenario from the current day to the next may not come from local injection but from transport from adjacent meshes. For the values considered in this example, this gives an injection of ~5e-8 kg/m²/s.

2. all this dust is injected uniformly during the injection window, by default between 2 p.m. this day and 2 p.m. the next day (when we are supposed to reach the scenario target), in the form of stormdust into the 1st layer by vdifc, which already mixes it a little on several layers. Then this stormdust undergoes processes like thermals (calltherm_interface), convective adjustment (convadj) and sedimentation (callsedim) that further mix it in the atmosphere. For the latter, stormdust is prevented from falling to the ground, and remains in the 1st layer instead. We need to do so, because the main process responsible for the stormdust rising, represented by the routine rocketduststorm, only happens at the beginning of the next timestep (see point 5).

3. the stormdust is further mixed by the dynamics, and may also be transported to adjacent meshes. The column may also receive stormdust from other meshes.

4. once back to the next physical time step, we calculate a sub-mesh fraction that is representative of the size of the stormdust plume (calcstormfract). To do so, we use the maximum mass mixing ratio of stormdust in the entire column (apart from the 1st layer), and compute the sub-mesh fraction that is needed to reach a reference mixing ratio mmr_ref=5e-4kg/kg. This reference mmr is a value that we consider representative of an opacity of 10 that was measured in a local dust storm by OMEGA, given some assumptions like a vertical extent of $$\Delta P$$=200Pa for the dust plume (see also Wang et al. 2018, JGRPlanets, doi:10.1002/2017JE005255).

5. finally, we enter the rocketduststorm routine, where we check whether anywhere in the column, the mmr of stormdust (not concentrated in the sub-mesh fraction, but expanded to the whole mesh) is greater than $$10^{-4}$$ times that of background dust. If so, we activate the scheme in the column, and calculate the heating difference between the sub-mesh fraction (where we have concentrated stormdust, and background dust) and the rest of the mesh (only background dust), the resulting vertical transport in the sub-mesh fraction, and the horizontal detrainment where the stormdust plume vertical velocity decreases. If there is not enough stormdust compared to background dust at any level, the stormdust is detrained into background dust at all levels of the column.