Skip to content

Commit

Permalink
Cache: viscous_sponge_cache
Browse files Browse the repository at this point in the history
  • Loading branch information
Sbozzolo committed Oct 24, 2023
1 parent 28ccff2 commit 1d80852
Show file tree
Hide file tree
Showing 2 changed files with 35 additions and 12 deletions.
6 changes: 4 additions & 2 deletions src/cache/cache.jl
Original file line number Diff line number Diff line change
Expand Up @@ -131,8 +131,10 @@ function additional_cache(
end

return merge(
(; rayleigh_sponge = rayleigh_sponge_cache(Y, atmos)),
viscous_sponge_cache(atmos.viscous_sponge, Y),
(;
rayleigh_sponge = rayleigh_sponge_cache(Y, atmos),
viscous_sponge = viscous_sponge_cache(Y, atmos),
),
precipitation_cache(Y, precip_model),
subsidence_cache(Y, atmos.subsidence),
large_scale_advection_cache(Y, atmos.ls_adv),
Expand Down
41 changes: 31 additions & 10 deletions src/parameterized_tendencies/sponge/viscous_sponge.jl
Original file line number Diff line number Diff line change
Expand Up @@ -6,10 +6,13 @@ import ClimaCore.Fields as Fields
import ClimaCore.Geometry as Geometry
import ClimaCore.Spaces as Spaces

viscous_sponge_cache(::Nothing, Y) = NamedTuple()
viscous_sponge_cache(Y, atmos::AtmosModel) =
viscous_sponge_cache(Y, atmos.viscous_sponge)

viscous_sponge_cache(Y, ::Nothing) = (;)
viscous_sponge_tendency!(Yₜ, Y, p, t, ::Nothing) = nothing

function viscous_sponge_cache(viscous_sponge::ViscousSponge, Y)
function viscous_sponge_cache(Y, viscous_sponge::ViscousSponge)
(; κ₂, zd) = viscous_sponge
FT = Spaces.undertype(axes(Y.c))
ᶜz = Fields.coordinate_field(Y.c).z
Expand All @@ -22,16 +25,34 @@ function viscous_sponge_cache(viscous_sponge::ViscousSponge, Y)
return (; ᶜβ_viscous, ᶠβ_viscous)
end

function viscous_sponge_tendency!(Yₜ, Y, p, t, ::ViscousSponge)
(; ᶜβ_viscous, ᶠβ_viscous) = p
add_viscous_sponge_energy_tendency!(Yₜ, Y, p, t) =
add_viscous_sponge_energy_tendency!(Yₜ, Y, p, t, p.energy_form)

function add_viscous_sponge_energy_tendency!(Yₜ, Y, p, t, ::TotalEnergy)
(; ᶜβ_viscous) = p.viscous_sponge
(; ᶜh_tot) = p
ᶜρ = Y.c.ρ
@. Yₜ.c.ρe_tot += ᶜβ_viscous * wdivₕ(ᶜρ * gradₕ(ᶜh_tot))
end

function add_viscous_sponge_energy_tendency!(
Yₜ,
Y,
p,
t,
::PotentialTemperature,
)
(; ᶜβ_viscous) = p.viscous_sponge
ᶜρ = Y.c.ρ
@. Yₜ.c.ρθ += ᶜβ_viscous * wdivₕ(ᶜρ * gradₕ(Y.c.ρθ / ᶜρ))
end

function viscous_sponge_tendency!(Yₜ, Y, p, t, ::ViscousSponge)
(; ᶜβ_viscous, ᶠβ_viscous) = p.viscous_sponge
ᶜuₕ = Y.c.uₕ
if :ρθ in propertynames(Y.c)
@. Yₜ.c.ρθ += ᶜβ_viscous * wdivₕ(ᶜρ * gradₕ(Y.c.ρθ / ᶜρ))
elseif :ρe_tot in propertynames(Y.c)
(; ᶜh_tot) = p
@. Yₜ.c.ρe_tot += ᶜβ_viscous * wdivₕ(ᶜρ * gradₕ(ᶜh_tot))
end

add_viscous_sponge_energy_tendency!(Yₜ, Y, p, t)

@. Yₜ.c.uₕ +=
ᶜβ_viscous * (
wgradₕ(divₕ(ᶜuₕ)) - Geometry.project(
Expand Down

0 comments on commit 1d80852

Please sign in to comment.