Skip to content

Commit

Permalink
Preallocate thermal state
Browse files Browse the repository at this point in the history
  • Loading branch information
Sbozzolo committed Apr 24, 2024
1 parent 7b0c273 commit 024dca1
Show file tree
Hide file tree
Showing 6 changed files with 39 additions and 6 deletions.
1 change: 1 addition & 0 deletions docs/src/APIs/shared_utilities.md
Original file line number Diff line number Diff line change
Expand Up @@ -77,6 +77,7 @@ ClimaLand.turbulent_fluxes
ClimaLand.turbulent_fluxes_at_a_point
ClimaLand.radiative_fluxes_at_a_point
ClimaLand.construct_atmos_ts
ClimaLand.set_atmos_ts!
ClimaLand.surface_air_density
ClimaLand.liquid_precipitation
ClimaLand.snow_precipitation
Expand Down
24 changes: 20 additions & 4 deletions src/shared_utilities/drivers.jl
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ export AbstractAtmosphericDrivers,
CoupledRadiativeFluxes,
compute_ρ_sfc,
construct_atmos_ts,
set_atmos_ts!,
turbulent_fluxes,
net_radiation,
turbulent_fluxes_at_a_point,
Expand Down Expand Up @@ -175,6 +176,21 @@ function construct_atmos_ts(
return ts_in
end

"""
Fill the pre-allocated ts_in `Field` with a thermodynamic state.
"""
function set_atmos_ts!(
ts_in,
atmos::PrescribedAtmosphere{FT},
p,
thermo_params,
) where {FT}
P = p.drivers.P
T = p.drivers.T
q = p.drivers.q
ts_in .= Thermodynamics.PhaseEquil_pTq.(thermo_params, P, T, q)
return nothing
end

"""
turbulent_fluxes(atmos::PrescribedAtmosphere,
Expand Down Expand Up @@ -208,7 +224,7 @@ function turbulent_fluxes(
d_sfc = displacement_height(model, Y, p)
thermo_params =
LP.thermodynamic_parameters(model.parameters.earth_param_set)
ts_air = construct_atmos_ts(atmos, p, thermo_params)
set_atmos_ts!(p.scratch.thermal_state, atmos, p, thermo_params)
u_air = p.drivers.u
h_air = atmos.h

Expand All @@ -220,7 +236,7 @@ function turbulent_fluxes(
h_sfc,
r_sfc,
d_sfc,
ts_air,
p.scratch.thermal_state,
u_air,
h_air,
atmos.gustiness,
Expand Down Expand Up @@ -518,8 +534,8 @@ function surface_air_density(
)
thermo_params =
LP.thermodynamic_parameters(model.parameters.earth_param_set)
ts_in = construct_atmos_ts(atmos, p, thermo_params)
return compute_ρ_sfc.(thermo_params, ts_in, T_sfc)
set_atmos_ts!(p.scratch.thermal_state, atmos, p, thermo_params)
return compute_ρ_sfc.(thermo_params, p.scratch.thermal_state, T_sfc)
end


Expand Down
15 changes: 15 additions & 0 deletions src/shared_utilities/models.jl
Original file line number Diff line number Diff line change
Expand Up @@ -355,6 +355,7 @@ function initialize_auxiliary(model::AbstractModel{FT}, state) where {FT}
)
if :domain propertynames(model)
p = add_dss_buffer_to_aux(p, model.domain)
p = add_scratch_to_aux(p, model.domain)
else
error(
"Your model does not contain a domain. If this is intended, you will need a new method of initialize_auxiliary.",
Expand All @@ -363,6 +364,20 @@ function initialize_auxiliary(model::AbstractModel{FT}, state) where {FT}
return p
end

function add_scratch_to_aux(p, domain)
hasproperty(domain.space, :surface) || error("Surface domain required")
FT = Spaces.undertype(domain.space.surface)
scratch = (;
# Thermal state on the surface
thermal_state = Fields.Field(
Thermodynamics.PhaseEquil{FT},
domain.space.surface,
)
)
return merge(p, (; scratch))
end


function initialize_vars(keys, types, domain_names, state, model_name)
FT = eltype(state)
if length(keys) == 0
Expand Down
1 change: 1 addition & 0 deletions src/standalone/Bucket/Bucket.jl
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ using ClimaLand:
turbulent_fluxes,
net_radiation,
construct_atmos_ts,
set_atmos_ts!,
compute_ρ_sfc,
AbstractExpModel,
heaviside,
Expand Down
2 changes: 1 addition & 1 deletion test/standalone/Bucket/soil_bucket_tests.jl
Original file line number Diff line number Diff line change
Expand Up @@ -120,7 +120,7 @@ for FT in (Float32, Float64)
),
)
else
@test propertynames(p) == (:bucket, :drivers)
@test propertynames(p) == (:bucket, :scratch, :drivers)
end


Expand Down
2 changes: 1 addition & 1 deletion test/standalone/Soil/soil_test_3d.jl
Original file line number Diff line number Diff line change
Expand Up @@ -71,7 +71,7 @@ for FT in (Float32, Float64)

Y, p, coords = initialize(soil)
# test that the dss buffer was added
@test propertynames(p) == (:soil, :dss_buffer_3d, :dss_buffer_2d)
@test propertynames(p) == (:soil, :dss_buffer_3d, :dss_buffer_2d, :scratch)
@test typeof(p.dss_buffer_3d) == typeof(
ClimaCore.Spaces.create_dss_buffer(
ClimaCore.Fields.zeros(soil_domain.space.subsurface),
Expand Down

0 comments on commit 024dca1

Please sign in to comment.