SCALE-RM
|
module atmosphere / physics / microphysics / Tomita08 More...
Functions/Subroutines | |
subroutine, public | atmos_phy_mp_tomita08_setup (KA, KS, KE, IA, IS, IE, JA, JS, JE, flg_lt) |
ATMOS_PHY_MP_tomita08_setup Setup. More... | |
subroutine, public | atmos_phy_mp_tomita08_finalize |
finalize More... | |
subroutine, public | atmos_phy_mp_tomita08_putvar (in_drag_g, in_re_qc, in_re_qi, in_Cr, in_Cs) |
overwrite private variables More... | |
subroutine, public | atmos_phy_mp_tomita08_getvar (out_drag_g, out_re_qc, out_re_qi, out_Cr, out_Cs) |
read private variables More... | |
subroutine, public | atmos_phy_mp_tomita08_adjustment (KA, KS, KE, IA, IS, IE, JA, JS, JE, DENS, PRES, CCN, dt, TEMP, QTRC, CPtot, CVtot, RHOE_t, EVAPORATE, flg_lt, d0_crg, v0_crg, dqcrg, beta_crg, QSPLT_in, Sarea, QTRC_crg) |
ATMOS_PHY_MP_tomita08_adjustment calculate state after saturation process. More... | |
subroutine, public | atmos_phy_mp_tomita08_terminal_velocity (KA, KS, KE, DENS, TEMP, RHOQ, vterm) |
Lin-type cold rain microphysics (terminal velocity) More... | |
subroutine, public | atmos_phy_mp_tomita08_cloud_fraction (KA, KS, KE, IA, IS, IE, JA, JS, JE, QTRC, mask_criterion, cldfrac) |
Calculate Cloud Fraction. More... | |
subroutine, public | atmos_phy_mp_tomita08_effective_radius (KA, KS, KE, IA, IS, IE, JA, JS, JE, DENS0, TEMP0, QTRC0, Re) |
Calculate Effective Radius. More... | |
subroutine, public | atmos_phy_mp_tomita08_qtrc2qhyd (KA, KS, KE, IA, IS, IE, JA, JS, JE, QTRC, Qe) |
Calculate mass ratio of each category. More... | |
subroutine, public | atmos_phy_mp_tomita08_qhyd2qtrc (KA, KS, KE, IA, IS, IE, JA, JS, JE, Qe, QTRC) |
get mass ratio of each category More... | |
Variables | |
integer, parameter, public | atmos_phy_mp_tomita08_ntracers = QA_MP |
integer, parameter, public | atmos_phy_mp_tomita08_nwaters = 2 |
integer, parameter, public | atmos_phy_mp_tomita08_nices = 3 |
character(len=h_short), dimension(qa_mp), parameter, public | atmos_phy_mp_tomita08_tracer_names = (/ 'QV', 'QC', 'QR', 'QI', 'QS', 'QG' /) |
character(len=h_mid), dimension(qa_mp), parameter, public | atmos_phy_mp_tomita08_tracer_descriptions = (/ 'Ratio of Water Vapor mass to total mass (Specific humidity)', 'Ratio of Cloud Water mass to total mass ', 'Ratio of Rain Water mass to total mass ', 'Ratio of Cloud Ice mass ratio to total mass ', 'Ratio of Snow miass ratio to total mass ', 'Ratio of Graupel mass ratio to total mass '/) |
character(len=h_short), dimension(qa_mp), parameter, public | atmos_phy_mp_tomita08_tracer_units = (/ 'kg/kg', 'kg/kg', 'kg/kg', 'kg/kg', 'kg/kg', 'kg/kg' /) |
module atmosphere / physics / microphysics / Tomita08
name | type | default value | comment |
---|---|---|---|
DO_COUPLE_AEROSOL | logical | .false. | apply CCN effect? |
DO_EXPLICIT_ICEGEN | logical | .false. | apply explicit ice generation? |
AUTOCONV_NC | real(RP) | Nc_ocn | number concentration of cloud water [1/cc] |
ENABLE_KK2000 | logical | .false. | use scheme by Khairoutdinov and Kogan (2000) |
ENABLE_RS2014 | logical | .false. | use scheme by Roh and Satoh (2014) |
ENABLE_WDXZ2014 | logical | .false. | use scheme by Wainwright et al. (2014) |
ENABLE_HZDFHI2007 | logical | .false. | use scheme by Heymsfield et al. (2007) |
CLOUD_TYPE | character(len=12) | "synoptic" ! "synoptic" or "crystal_face" | |
ENABLE_TRAWLBG2017 | logical | .false. | use scheme by Thornberry et al. (2017) |
N0R_DEF | real(RP) | 8.E+6_RP | intercept parameter for rain [1/m4] |
N0S_DEF | real(RP) | 3.E+6_RP | intercept parameter for snow [1/m4] |
N0G_DEF | real(RP) | 4.E+6_RP | intercept parameter for graupel [1/m4] |
DENS_S | real(RP) | 100.0_RP | density of snow [kg/m3] |
DENS_G | real(RP) | 400.0_RP | density of graupel [kg/m3] |
RE_QC | real(RP) | 8.E-6_RP | effective radius for cloud water |
RE_QI | real(RP) | 40.E-6_RP | effective radius for cloud ice |
DRAG_G | real(RP) | 0.6_RP | drag coefficient for graupel |
CR | real(RP) | 130.0_RP | |
CS | real(RP) | 4.84_RP | |
EIW | real(RP) | 1.0_RP | collection efficiency of cloud ice for cloud water |
ERW | real(RP) | 1.0_RP | collection efficiency of rain for cloud water |
ESW | real(RP) | 1.0_RP | collection efficiency of snow for cloud water |
EGW | real(RP) | 1.0_RP | collection efficiency of graupel for cloud water |
ERI | real(RP) | 1.0_RP | collection efficiency of rain for cloud ice |
ESI | real(RP) | 1.0_RP | collection efficiency of snow for cloud ice |
EGI | real(RP) | 0.1_RP | collection efficiency of graupel for cloud ice |
ESR | real(RP) | 1.0_RP | collection efficiency of snow for rain |
EGR | real(RP) | 1.0_RP | collection efficiency of graupel for rain |
EGS | real(RP) | 1.0_RP | collection efficiency of graupel for snow |
GAMMA_SACR | real(RP) | 25.E-3_RP | effect of low temperature for Esi |
GAMMA_GACS | real(RP) | 90.E-3_RP | effect of low temperature for Egs |
MI | real(RP) | 4.19E-13_RP | mass of one cloud ice crystal [kg] |
BETA_SAUT | real(RP) | 6.E-3_RP | auto-conversion factor beta for ice |
GAMMA_SAUT | real(RP) | 60.E-3_RP | auto-conversion factor gamma for ice |
QICRT_SAUT | real(RP) | 0.0_RP | mass ratio threshold for Psaut [kg/kg] |
BETA_GAUT | real(RP) | 0.0_RP | auto-conversion factor beta for snow |
GAMMA_GAUT | real(RP) | 90.E-3_RP | auto-conversion factor gamma for snow |
QSCRT_GAUT | real(RP) | 6.E-4_RP | mass ratio threshold for Pgaut [kg/kg] |
FIXED_RE | logical | .false. | use ice's effective radius for snow and graupel, and set rain transparent? |
CONST_REC | logical | .true. | use constant effective radius for cloud water? |
NOFALL_QR | logical | .false. | surpress sedimentation of rain? |
NOFALL_QI | logical | .false. | surpress sedimentation of ice? |
NOFALL_QS | logical | .false. | surpress sedimentation of snow? |
NOFALL_QG | logical | .false. | surpress sedimentation of graupel? |
ECOAL_GI | real(RP) | ||
ECOAL_GS | real(RP) |
name | description | unit | variable |
---|---|---|---|
Pcsat | QC production term by satulation adjustment | kg/kg/s | Pcsat |
Pisat | QI production term by satulation adjustment | kg/kg/s | Pisat |
Pgmlt | individual tendency term in tomita08 | kg/kg/s | Pgmlt |
subroutine, public scale_atmos_phy_mp_tomita08::atmos_phy_mp_tomita08_setup | ( | integer, intent(in) | KA, |
integer, intent(in) | KS, | ||
integer, intent(in) | KE, | ||
integer, intent(in) | IA, | ||
integer, intent(in) | IS, | ||
integer, intent(in) | IE, | ||
integer, intent(in) | JA, | ||
integer, intent(in) | JS, | ||
integer, intent(in) | JE, | ||
logical, intent(in), optional | flg_lt | ||
) |
ATMOS_PHY_MP_tomita08_setup Setup.
Definition at line 399 of file scale_atmos_phy_mp_tomita08.F90.
References scale_const::const_dice, scale_const::const_dwatr, scale_const::const_grav, scale_const::const_pi, scale_file_history::file_history_reg(), scale_io::io_fid_conf, scale_prc::prc_abort(), and scale_specfunc::sf_gamma().
Referenced by mod_atmos_phy_mp_driver::atmos_phy_mp_driver_setup().
subroutine, public scale_atmos_phy_mp_tomita08::atmos_phy_mp_tomita08_finalize |
finalize
Definition at line 656 of file scale_atmos_phy_mp_tomita08.F90.
Referenced by mod_atmos_phy_mp_driver::atmos_phy_mp_driver_finalize().
subroutine, public scale_atmos_phy_mp_tomita08::atmos_phy_mp_tomita08_putvar | ( | real(rp), intent(in), optional | in_drag_g, |
real(rp), intent(in), optional | in_re_qc, | ||
real(rp), intent(in), optional | in_re_qi, | ||
real(rp), intent(in), optional | in_Cr, | ||
real(rp), intent(in), optional | in_Cs | ||
) |
overwrite private variables
Definition at line 671 of file scale_atmos_phy_mp_tomita08.F90.
References scale_const::const_grav.
Referenced by mod_da_param_estimation::da_param_estimation_update().
subroutine, public scale_atmos_phy_mp_tomita08::atmos_phy_mp_tomita08_getvar | ( | real(rp), intent(out), optional | out_drag_g, |
real(rp), intent(out), optional | out_re_qc, | ||
real(rp), intent(out), optional | out_re_qi, | ||
real(rp), intent(out), optional | out_Cr, | ||
real(rp), intent(out), optional | out_Cs | ||
) |
read private variables
Definition at line 703 of file scale_atmos_phy_mp_tomita08.F90.
Referenced by mod_da_param_estimation::da_param_estimation_update().
subroutine, public scale_atmos_phy_mp_tomita08::atmos_phy_mp_tomita08_adjustment | ( | integer, intent(in) | KA, |
integer, intent(in) | KS, | ||
integer, intent(in) | KE, | ||
integer, intent(in) | IA, | ||
integer, intent(in) | IS, | ||
integer, intent(in) | IE, | ||
integer, intent(in) | JA, | ||
integer, intent(in) | JS, | ||
integer, intent(in) | JE, | ||
real(rp), dimension (ka,ia,ja), intent(in) | DENS, | ||
real(rp), dimension (ka,ia,ja), intent(in) | PRES, | ||
real(rp), dimension (ka,ia,ja), intent(in) | CCN, | ||
real(dp), intent(in) | dt, | ||
real(rp), dimension(ka,ia,ja), intent(inout) | TEMP, | ||
real(rp), dimension(ka,ia,ja,qa_mp), intent(inout) | QTRC, | ||
real(rp), dimension(ka,ia,ja), intent(inout) | CPtot, | ||
real(rp), dimension(ka,ia,ja), intent(inout) | CVtot, | ||
real(rp), dimension (ka,ia,ja), intent(out) | RHOE_t, | ||
real(rp), dimension(ka,ia,ja), intent(out) | EVAPORATE, | ||
logical, intent(in), optional | flg_lt, | ||
real(rp), intent(in), optional | d0_crg, | ||
real(rp), intent(in), optional | v0_crg, | ||
real(rp), dimension(ka,ia,ja), intent(in), optional | dqcrg, | ||
real(rp), dimension(ka,ia,ja), intent(in), optional | beta_crg, | ||
real(rp), dimension(ka,ia,ja,3), intent(out), optional | QSPLT_in, | ||
real(rp), dimension(ka,ia,ja,qa_mp-1), intent(out), optional | Sarea, | ||
real(rp), dimension(ka,ia,ja,qa_mp-1), intent(inout), optional | QTRC_crg | ||
) |
ATMOS_PHY_MP_tomita08_adjustment calculate state after saturation process.
Definition at line 735 of file scale_atmos_phy_mp_tomita08.F90.
References atmos_phy_mp_tomita08_effective_radius(), scale_const::const_cl, scale_const::const_dice, scale_const::const_dwatr, scale_const::const_eps, scale_const::const_lhf0, scale_const::const_lhs0, scale_const::const_lhv0, scale_const::const_pi, scale_const::const_pre00, scale_const::const_rvap, scale_const::const_tem00, scale_const::const_undef, scale_atmos_hydrometeor::cp_ice, scale_atmos_hydrometeor::cp_vapor, scale_atmos_hydrometeor::cp_water, scale_atmos_hydrometeor::cv_ice, scale_atmos_hydrometeor::cv_vapor, scale_atmos_hydrometeor::cv_water, scale_atmos_hydrometeor::i_hs, scale_atmos_hydrometeor::lhf, scale_atmos_hydrometeor::lhv, scale_atmos_hydrometeor::n_hyd, scale_prof::prof_rapend(), and scale_prof::prof_rapstart().
Referenced by mod_atmos_phy_mp_driver::atmos_phy_mp_driver_calc_tendency().
subroutine, public scale_atmos_phy_mp_tomita08::atmos_phy_mp_tomita08_terminal_velocity | ( | integer, intent(in), value | KA, |
integer, intent(in), value | KS, | ||
integer, intent(in), value | KE, | ||
real(rp), dimension(ka), intent(in) | DENS, | ||
real(rp), dimension(ka), intent(in) | TEMP, | ||
real(rp), dimension(ka,qa_mp-1), intent(in) | RHOQ, | ||
real(rp), dimension(ka,qa_mp-1), intent(out) | vterm | ||
) |
Lin-type cold rain microphysics (terminal velocity)
Definition at line 2257 of file scale_atmos_phy_mp_tomita08.F90.
References scale_const::const_tem00.
Referenced by mod_atmos_phy_mp_driver::atmos_phy_mp_driver_calc_tendency().
subroutine, public scale_atmos_phy_mp_tomita08::atmos_phy_mp_tomita08_cloud_fraction | ( | integer, intent(in) | KA, |
integer, intent(in) | KS, | ||
integer, intent(in) | KE, | ||
integer, intent(in) | IA, | ||
integer, intent(in) | IS, | ||
integer, intent(in) | IE, | ||
integer, intent(in) | JA, | ||
integer, intent(in) | JS, | ||
integer, intent(in) | JE, | ||
real(rp), dimension(ka,ia,ja,qa_mp-1), intent(in) | QTRC, | ||
real(rp), intent(in) | mask_criterion, | ||
real(rp), dimension(ka,ia,ja), intent(out) | cldfrac | ||
) |
Calculate Cloud Fraction.
Definition at line 2528 of file scale_atmos_phy_mp_tomita08.F90.
Referenced by mod_atmos_phy_mp_vars::atmos_phy_mp_vars_get_diagnostic().
subroutine, public scale_atmos_phy_mp_tomita08::atmos_phy_mp_tomita08_effective_radius | ( | integer, intent(in) | KA, |
integer, intent(in) | KS, | ||
integer, intent(in) | KE, | ||
integer, intent(in) | IA, | ||
integer, intent(in) | IS, | ||
integer, intent(in) | IE, | ||
integer, intent(in) | JA, | ||
integer, intent(in) | JS, | ||
integer, intent(in) | JE, | ||
real(rp), dimension(ka,ia,ja), intent(in) | DENS0, | ||
real(rp), dimension(ka,ia,ja), intent(in) | TEMP0, | ||
real(rp), dimension(ka,ia,ja,qa_mp-1), intent(in) | QTRC0, | ||
real(rp), dimension (ka,ia,ja,n_hyd), intent(out) | Re | ||
) |
Calculate Effective Radius.
Definition at line 2565 of file scale_atmos_phy_mp_tomita08.F90.
References scale_const::const_dice, scale_const::const_dwatr, scale_const::const_pi, scale_const::const_tem00, scale_atmos_hydrometeor::i_hc, scale_atmos_hydrometeor::i_hg, scale_atmos_hydrometeor::i_hi, scale_atmos_hydrometeor::i_hr, scale_atmos_hydrometeor::i_hs, and scale_atmos_hydrometeor::n_hyd.
Referenced by atmos_phy_mp_tomita08_adjustment(), and mod_atmos_phy_mp_vars::atmos_phy_mp_vars_get_diagnostic().
subroutine, public scale_atmos_phy_mp_tomita08::atmos_phy_mp_tomita08_qtrc2qhyd | ( | integer, intent(in) | KA, |
integer, intent(in) | KS, | ||
integer, intent(in) | KE, | ||
integer, intent(in) | IA, | ||
integer, intent(in) | IS, | ||
integer, intent(in) | IE, | ||
integer, intent(in) | JA, | ||
integer, intent(in) | JS, | ||
integer, intent(in) | JE, | ||
real(rp), dimension(ka,ia,ja,qa_mp-1), intent(in) | QTRC, | ||
real(rp), dimension(ka,ia,ja,n_hyd), intent(out) | Qe | ||
) |
Calculate mass ratio of each category.
Definition at line 2836 of file scale_atmos_phy_mp_tomita08.F90.
References scale_atmos_hydrometeor::i_hc, scale_atmos_hydrometeor::i_hg, scale_atmos_hydrometeor::i_hi, scale_atmos_hydrometeor::i_hr, scale_atmos_hydrometeor::i_hs, and scale_atmos_hydrometeor::n_hyd.
Referenced by mod_atmos_phy_mp_vars::atmos_phy_mp_vars_get_diagnostic().
subroutine, public scale_atmos_phy_mp_tomita08::atmos_phy_mp_tomita08_qhyd2qtrc | ( | integer, intent(in) | KA, |
integer, intent(in) | KS, | ||
integer, intent(in) | KE, | ||
integer, intent(in) | IA, | ||
integer, intent(in) | IS, | ||
integer, intent(in) | IE, | ||
integer, intent(in) | JA, | ||
integer, intent(in) | JS, | ||
integer, intent(in) | JE, | ||
real(rp), dimension (ka,ia,ja,n_hyd), intent(in) | Qe, | ||
real(rp), dimension(ka,ia,ja,qa_mp-1), intent(out) | QTRC | ||
) |
get mass ratio of each category
Definition at line 2944 of file scale_atmos_phy_mp_tomita08.F90.
References scale_atmos_hydrometeor::i_hc, scale_atmos_hydrometeor::i_hg, scale_atmos_hydrometeor::i_hh, scale_atmos_hydrometeor::i_hi, scale_atmos_hydrometeor::i_hr, scale_atmos_hydrometeor::i_hs, and scale_atmos_hydrometeor::n_hyd.
Referenced by mod_atmos_phy_mp_driver::atmos_phy_mp_driver_qhyd2qtrc().
integer, parameter, public scale_atmos_phy_mp_tomita08::atmos_phy_mp_tomita08_ntracers = QA_MP |
Definition at line 46 of file scale_atmos_phy_mp_tomita08.F90.
Referenced by mod_atmos_phy_mp_driver::atmos_phy_mp_driver_tracer_setup().
integer, parameter, public scale_atmos_phy_mp_tomita08::atmos_phy_mp_tomita08_nwaters = 2 |
Definition at line 47 of file scale_atmos_phy_mp_tomita08.F90.
Referenced by mod_atmos_phy_mp_driver::atmos_phy_mp_driver_tracer_setup().
integer, parameter, public scale_atmos_phy_mp_tomita08::atmos_phy_mp_tomita08_nices = 3 |
Definition at line 48 of file scale_atmos_phy_mp_tomita08.F90.
Referenced by mod_atmos_phy_mp_driver::atmos_phy_mp_driver_tracer_setup().
character(len=h_short), dimension(qa_mp), parameter, public scale_atmos_phy_mp_tomita08::atmos_phy_mp_tomita08_tracer_names = (/ 'QV', 'QC', 'QR', 'QI', 'QS', 'QG' /) |
Definition at line 49 of file scale_atmos_phy_mp_tomita08.F90.
Referenced by mod_atmos_phy_mp_driver::atmos_phy_mp_driver_tracer_setup().
character(len=h_mid), dimension(qa_mp), parameter, public scale_atmos_phy_mp_tomita08::atmos_phy_mp_tomita08_tracer_descriptions = (/ 'Ratio of Water Vapor mass to total mass (Specific humidity)', 'Ratio of Cloud Water mass to total mass ', 'Ratio of Rain Water mass to total mass ', 'Ratio of Cloud Ice mass ratio to total mass ', 'Ratio of Snow miass ratio to total mass ', 'Ratio of Graupel mass ratio to total mass '/) |
Definition at line 56 of file scale_atmos_phy_mp_tomita08.F90.
Referenced by mod_atmos_phy_mp_driver::atmos_phy_mp_driver_tracer_setup().
character(len=h_short), dimension(qa_mp), parameter, public scale_atmos_phy_mp_tomita08::atmos_phy_mp_tomita08_tracer_units = (/ 'kg/kg', 'kg/kg', 'kg/kg', 'kg/kg', 'kg/kg', 'kg/kg' /) |
Definition at line 63 of file scale_atmos_phy_mp_tomita08.F90.
Referenced by mod_atmos_phy_mp_driver::atmos_phy_mp_driver_tracer_setup().