Skip to content

Commit

Permalink
Merge pull request #542 from SpeedyWeather/mk/flux_prev
Browse files Browse the repository at this point in the history
Surface fluxes calculated from previous time step
  • Loading branch information
milankl authored May 17, 2024
2 parents efbe175 + 2b80cc7 commit c30ea26
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 11 deletions.
2 changes: 1 addition & 1 deletion src/physics/large_scale_condensation.jl
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ Base.@kwdef struct ImplicitCondensation{NF<:AbstractFloat} <: AbstractCondensati
relative_humidity_threshold::NF = 1

"Flux limiter for latent heat release [W/m²] per timestep"
max_heating::NF = 1
max_heating::NF = 10 # currently not needed? maybe too high?

"Time scale in multiples of time step Δt, the larger the less immediate"
time_scale::NF = 3
Expand Down
22 changes: 12 additions & 10 deletions src/physics/surface_fluxes.jl
Original file line number Diff line number Diff line change
Expand Up @@ -27,9 +27,10 @@ function surface_thermodynamics!( column::ColumnVariables,
::SurfaceThermodynamicsConstant,
model::PrimitiveWet)

# surface value is same as lowest model level
column.surface_temp = column.temp[end] # todo use constant POTENTIAL temperature
column.surface_humid = column.humid[end] # humidity at surface is the same as
# surface value is same as lowest model level, use previous time step
# for numerical stability
column.surface_temp = column.temp_prev[end] # todo use constant POTENTIAL temperature
column.surface_humid = column.humid_prev[end] # humidity at surface is the same as

# surface air density via virtual temperature
(; R_dry) = model.atmosphere
Expand All @@ -41,8 +42,9 @@ function surface_thermodynamics!( column::ColumnVariables,
::SurfaceThermodynamicsConstant,
model::PrimitiveDry)
(; R_dry) = model.atmosphere
# surface value is same as lowest model level
column.surface_temp = column.temp[end] # todo use constant POTENTIAL temperature
# surface value is same as lowest model level, but use previous
# time step for numerical stability
column.surface_temp = column.temp_prev[end] # todo use constant POTENTIAL temperature
column.surface_air_density = column.pres[end]/(R_dry*column.surface_temp)
end

Expand Down Expand Up @@ -71,7 +73,7 @@ Base.@kwdef struct SurfaceWind{NF<:AbstractFloat} <: AbstractSurfaceWind
drag_sea::NF = 1.8e-3

"Flux limiter to cap the max of surface momentum fluxes [kg/m/s²]"
max_flux::NF = 0.1
max_flux::NF = 10 # currently not needed? maybe too high?
end

SurfaceWind(SG::SpectralGrid; kwargs...) = SurfaceWind{SG.NF}(; kwargs...)
Expand All @@ -85,9 +87,9 @@ function surface_wind_stress!( column::ColumnVariables,
(; f_wind, V_gust, drag_land, drag_sea) = surface_wind
(; max_flux) = surface_wind

# SPEEDY documentation eq. 49
column.surface_u = f_wind*column.u[end]
column.surface_v = f_wind*column.v[end]
# SPEEDY documentation eq. 49, but use previous time step for numerical stability
column.surface_u = f_wind*column.u_prev[end]
column.surface_v = f_wind*column.v_prev[end]
(; surface_u, surface_v) = column

# SPEEDY documentation eq. 50
Expand Down Expand Up @@ -136,7 +138,7 @@ Base.@kwdef struct SurfaceHeatFlux{NF<:AbstractFloat} <: AbstractSurfaceHeatFlux
heat_exchange_sea::NF = 0.9e-3

"Flux limiter for surface heat fluxes [W/m²]"
max_flux::NF = 100
max_flux::NF = 100 # currently not needed? maybe too high?
end

SurfaceHeatFlux(SG::SpectralGrid; kwargs...) = SurfaceHeatFlux{SG.NF}(; kwargs...)
Expand Down

0 comments on commit c30ea26

Please sign in to comment.