From eec45084e9d6bac2a82cb3934c43ce1c9ebac8aa Mon Sep 17 00:00:00 2001 From: Anna Jaruga Date: Thu, 14 Dec 2023 17:13:09 -0800 Subject: [PATCH] Make the 1M scheme more stable --- ...uaplanet_rhoe_equilmoist_allsky_gw_res.yml | 41 ++++++++++++++----- .../microphysics/precipitation.jl | 40 +++++++++--------- 2 files changed, 51 insertions(+), 30 deletions(-) diff --git a/config/model_configs/sphere_aquaplanet_rhoe_equilmoist_allsky_gw_res.yml b/config/model_configs/sphere_aquaplanet_rhoe_equilmoist_allsky_gw_res.yml index 978a21780e..9b7fb9326b 100644 --- a/config/model_configs/sphere_aquaplanet_rhoe_equilmoist_allsky_gw_res.yml +++ b/config/model_configs/sphere_aquaplanet_rhoe_equilmoist_allsky_gw_res.yml @@ -1,18 +1,37 @@ -rad: "allskywithclear" -dt_save_to_disk: "15hours" -rayleigh_sponge: true -orographic_gravity_wave: "gfdl_restart" z_elem: 25 -dt: "400secs" -surface_setup: "DefaultMoninObukhov" -t_end: "15hours" -non_orographic_gravity_wave: true +z_max: 45000.0 dz_bottom: 300.0 +dt: "400secs" +t_end: "24hours" +dt_save_to_disk: "24hours" vert_diff: "true" -idealized_insolation: false -z_max: 45000.0 +moist: "equil" precip_model: "1M" precip_upwinding: "first_order" +rad: "allskywithclear" +idealized_insolation: false +rayleigh_sponge: true +non_orographic_gravity_wave: true +orographic_gravity_wave: "gfdl_restart" +surface_setup: "DefaultMoninObukhov" job_id: "sphere_aquaplanet_rhoe_equilmoist_allsky_gw_res" -moist: "equil" toml: [toml/sphere_aquaplanet_rhoe_equilmoist_allsky_gw_res.toml] +diagnostics: + - short_name: cl + period: 6hours + - short_name: cli + period: 6hours + - short_name: clw + period: 6hours + - short_name: husra + period: 6hours + - short_name: hussn + period: 6hours + - short_name: ta + period: 6hours + - short_name: hus + period: 6hours + - short_name: hur + period: 6hours + - short_name: mixlgm + period: 6hours diff --git a/src/parameterized_tendencies/microphysics/precipitation.jl b/src/parameterized_tendencies/microphysics/precipitation.jl index 751bb64131..f0782d5a2c 100644 --- a/src/parameterized_tendencies/microphysics/precipitation.jl +++ b/src/parameterized_tendencies/microphysics/precipitation.jl @@ -184,6 +184,8 @@ function compute_precipitation_cache!(Y, p, colidx, ::Microphysics1Moment, _) Tₐ(ts) = TD.air_temperature(thp, ts) α(ts) = TD.Parameters.cv_l(thp) / Lf(ts) * (Tₐ(ts) - cmp.ps.T_freeze) + qₚ(ρqₚ, ρ) = max(FT(0), ρqₚ / ρ) + # zero out the source terms @. ᶜSqₜᵖ[colidx] = FT(0) @. ᶜSeₜᵖ[colidx] = FT(0) @@ -228,7 +230,7 @@ function compute_precipitation_cache!(Y, p, colidx, ::Microphysics1Moment, _) cmp.tv.rain, cmp.ce, qₗ(ᶜts[colidx]), - Y.c.ρq_rai[colidx] / Y.c.ρ[colidx], + qₚ(Y.c.ρq_rai[colidx], Y.c.ρ[colidx]), Y.c.ρ[colidx], ), ) @@ -245,7 +247,7 @@ function compute_precipitation_cache!(Y, p, colidx, ::Microphysics1Moment, _) cmp.tv.snow, cmp.ce, qᵢ(ᶜts[colidx]), - Y.c.ρq_sno[colidx] / Y.c.ρ[colidx], + qₚ(Y.c.ρq_sno[colidx], Y.c.ρ[colidx]), Y.c.ρ[colidx], ), ) @@ -263,7 +265,7 @@ function compute_precipitation_cache!(Y, p, colidx, ::Microphysics1Moment, _) cmp.tv.snow, cmp.ce, qₗ(ᶜts[colidx]), - Y.c.ρq_sno[colidx] / Y.c.ρ[colidx], + qₚ(Y.c.ρq_sno[colidx], Y.c.ρ[colidx]), Y.c.ρ[colidx], ), ) @@ -275,7 +277,7 @@ function compute_precipitation_cache!(Y, p, colidx, ::Microphysics1Moment, _) ᶜSᵖ[colidx], FT(-1) * min( ᶜSᵖ[colidx] * α(ᶜts[colidx]), - Y.c.ρq_sno[colidx] / Y.c.ρ[colidx] / dt, + qₚ(Y.c.ρq_sno[colidx], Y.c.ρ[colidx]) / dt, ), ) @. ᶜSqₛᵖ[colidx] += ᶜSᵖ_snow[colidx] @@ -301,7 +303,7 @@ function compute_precipitation_cache!(Y, p, colidx, ::Microphysics1Moment, _) cmp.tv.rain, cmp.ce, qᵢ(ᶜts[colidx]), - Y.c.ρq_rai[colidx], + qₚ(Y.c.ρq_rai[colidx], Y.c.ρ[colidx]), Y.c.ρ[colidx], ), ) @@ -310,14 +312,14 @@ function compute_precipitation_cache!(Y, p, colidx, ::Microphysics1Moment, _) @. ᶜSeₜᵖ[colidx] -= ᶜSᵖ[colidx] * (Iᵢ(ᶜts[colidx]) + ᶜΦ[colidx]) # sink of rain via accretion cloud ice - rain @. ᶜSᵖ[colidx] = min( - Y.c.ρq_rai[colidx] / Y.c.ρ[colidx] / dt, + qₚ(Y.c.ρq_rai[colidx], Y.c.ρ[colidx]) / dt, CM1.accretion_rain_sink( cmp.pr, cmp.ci, cmp.tv.rain, cmp.ce, qᵢ(ᶜts[colidx]), - Y.c.ρq_rai[colidx] / Y.c.ρ[colidx], + qₚ(Y.c.ρq_rai[colidx], Y.c.ρ[colidx]), Y.c.ρ[colidx], ), ) @@ -329,28 +331,28 @@ function compute_precipitation_cache!(Y, p, colidx, ::Microphysics1Moment, _) @. ᶜSᵖ[colidx] = ifelse( Tₐ(ᶜts[colidx]) < cmp.ps.T_freeze, min( - Y.c.ρq_rai[colidx] / Y.c.ρ[colidx] / dt, + qₚ(Y.c.ρq_rai[colidx], Y.c.ρ[colidx]) / dt, CM1.accretion_snow_rain( cmp.ps, cmp.pr, cmp.tv.rain, cmp.tv.snow, cmp.ce, - Y.c.ρq_sno[colidx] / Y.c.ρ[colidx], - Y.c.ρq_rai[colidx] / Y.c.ρ[colidx], + qₚ(Y.c.ρq_sno[colidx], Y.c.ρ[colidx]), + qₚ(Y.c.ρq_rai[colidx], Y.c.ρ[colidx]), Y.c.ρ[colidx], ), ), -min( - Y.c.ρq_sno[colidx] / Y.c.ρ[colidx] / dt, + qₚ(Y.c.ρq_sno[colidx], Y.c.ρ[colidx]) / dt, CM1.accretion_snow_rain( cmp.pr, cmp.ps, cmp.tv.snow, cmp.tv.rain, cmp.ce, - Y.c.ρq_rai[colidx] / Y.c.ρ[colidx], - Y.c.ρq_sno[colidx] / Y.c.ρ[colidx], + qₚ(Y.c.ρq_rai[colidx], Y.c.ρ[colidx]), + qₚ(Y.c.ρq_sno[colidx], Y.c.ρ[colidx]), Y.c.ρ[colidx], ), ), @@ -362,14 +364,14 @@ function compute_precipitation_cache!(Y, p, colidx, ::Microphysics1Moment, _) # evaporation: q_rai -> q_vap @. ᶜSᵖ[colidx] = -min( - Y.c.ρq_rai[colidx] / Y.c.ρ[colidx] / dt, + qₚ(Y.c.ρq_rai[colidx], Y.c.ρ[colidx]) / dt, -CM1.evaporation_sublimation( cmp.pr, cmp.tv.rain, cmp.aps, thp, TD.PhasePartition(thp, ᶜts[colidx]), - Y.c.ρq_rai[colidx] / Y.c.ρ[colidx], + qₚ(Y.c.ρq_rai[colidx], Y.c.ρ[colidx]), Y.c.ρ[colidx], Tₐ(ᶜts[colidx]), ), @@ -380,13 +382,13 @@ function compute_precipitation_cache!(Y, p, colidx, ::Microphysics1Moment, _) # melting: q_sno -> q_rai @. ᶜSᵖ[colidx] = min( - Y.c.ρq_sno[colidx] / Y.c.ρ[colidx] / dt, + qₚ(Y.c.ρq_sno[colidx], Y.c.ρ[colidx]) / dt, CM1.snow_melt( cmp.ps, cmp.tv.snow, cmp.aps, thp, - Y.c.ρq_sno[colidx] / Y.c.ρ[colidx], + qₚ(Y.c.ρq_sno[colidx], Y.c.ρ[colidx]), Y.c.ρ[colidx], Tₐ(ᶜts[colidx]), ), @@ -402,14 +404,14 @@ function compute_precipitation_cache!(Y, p, colidx, ::Microphysics1Moment, _) cmp.aps, thp, TD.PhasePartition(thp, ᶜts[colidx]), - Y.c.ρq_sno[colidx] / Y.c.ρ[colidx], + qₚ(Y.c.ρq_sno[colidx], Y.c.ρ[colidx]), Y.c.ρ[colidx], Tₐ(ᶜts[colidx]), ) @. ᶜSᵖ[colidx] = ifelse( ᶜSᵖ[colidx] > FT(0), min(qᵥ(ᶜts[colidx]) / dt, ᶜSᵖ[colidx]), - -min(Y.c.ρq_sno[colidx] / Y.c.ρ[colidx] / dt, FT(-1) * ᶜSᵖ[colidx]), + -min(qₚ(Y.c.ρq_sno[colidx], Y.c.ρ[colidx]) / dt, FT(-1) * ᶜSᵖ[colidx]), ) @. ᶜSqₜᵖ[colidx] -= ᶜSᵖ[colidx] @. ᶜSqₛᵖ[colidx] += ᶜSᵖ[colidx]