Skip to content

Commit

Permalink
Add max_flow_rate to LinearResistance
Browse files Browse the repository at this point in the history
  • Loading branch information
visr committed Feb 8, 2024
1 parent 6093e14 commit 9163696
Show file tree
Hide file tree
Showing 9 changed files with 35 additions and 14 deletions.
5 changes: 4 additions & 1 deletion core/src/create.jl
Original file line number Diff line number Diff line change
Expand Up @@ -226,7 +226,9 @@ end

function LinearResistance(db::DB, config::Config)::LinearResistance
static = load_structvector(db, config, LinearResistanceStaticV1)
parsed_parameters, valid = parse_static_and_time(db, config, "LinearResistance"; static)
defaults = (; max_flow_rate = Inf, active = true)
parsed_parameters, valid =
parse_static_and_time(db, config, "LinearResistance"; static, defaults)

if !valid
error(
Expand All @@ -238,6 +240,7 @@ function LinearResistance(db::DB, config::Config)::LinearResistance
NodeID.(parsed_parameters.node_id),
BitVector(parsed_parameters.active),
parsed_parameters.resistance,
parsed_parameters.max_flow_rate,
parsed_parameters.control_mapping,
)
end
Expand Down
15 changes: 8 additions & 7 deletions core/src/solve.jl
Original file line number Diff line number Diff line change
Expand Up @@ -182,13 +182,15 @@ Requirements:
node_id: node ID of the LinearResistance node
active: whether this node is active and thus contributes flows
resistance: the resistance to flow; Q = Δh/resistance
resistance: the resistance to flow; Q = min(Δh/resistance, max_flow_rate)
max_flow_rate: the maximum flow rate allowed through the node
control_mapping: dictionary from (node_id, control_state) to resistance and/or active state
"""
struct LinearResistance <: AbstractParameterNode
node_id::Vector{NodeID}
active::BitVector
resistance::Vector{Float64}
max_flow_rate::Vector{Float64}
control_mapping::Dict{Tuple{NodeID, String}, NamedTuple}
end

Expand Down Expand Up @@ -862,17 +864,16 @@ function formulate_flow!(
t::Number,
)::Nothing
(; graph) = p
(; node_id, active, resistance) = linear_resistance
(; node_id, active, resistance, max_flow_rate) = linear_resistance
for (i, id) in enumerate(node_id)
basin_a_id = inflow_id(graph, id)
basin_b_id = outflow_id(graph, id)

if active[i]
q =
(
get_level(p, basin_a_id, t; storage) -
get_level(p, basin_b_id, t; storage)
) / resistance[i]
h_a = get_level(p, basin_a_id, t; storage)
h_b = get_level(p, basin_b_id, t; storage)
q_unlimited = (h_a - h_b) / resistance[i]
q = clamp(q_unlimited, -max_flow_rate[i], max_flow_rate[i])

# add reduction_factor on highest level
if q > 0
Expand Down
1 change: 1 addition & 0 deletions core/src/validation.jl
Original file line number Diff line number Diff line change
Expand Up @@ -244,6 +244,7 @@ end
node_id::Int
active::Union{Missing, Bool}
resistance::Float64
max_flow_rate::Union{Missing, Float64}
control_state::Union{Missing, String}
end

Expand Down
1 change: 1 addition & 0 deletions core/test/equations_test.jl
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@
# The storage of the basin when it has the same level as the level boundary
limit_storage = 450.0
decay_rate = -1 / (basin_area * p.linear_resistance.resistance[1])
# TODO adapt for max_flow_rate of 6e-5
storage_analytic =
@. limit_storage + (storage[1] - limit_storage) * exp.(decay_rate * t)

Expand Down
10 changes: 5 additions & 5 deletions docs/core/equations.qmd
Original file line number Diff line number Diff line change
Expand Up @@ -269,15 +269,15 @@ of outlets, or even reversal of flows for high precipitation events.
### LinearResistance
A `LinearResistance` connects two basins together. The flow between the two basins
is determined by a linear relationship:
is determined by a linear relationship, up to an optional maximum flow rate:
$$
Q = \frac{h_a - h_b}{R}
Q = \mathrm{clamp}(\frac{h_a - h_b}{R}, -Q_{\max}, Q_{\max})
$$ {#eq-basinflow}
Here $h_a$ is the water level in the first basin, $h_b$ is the water level in
the second basin, and $R$ is the resistance of the link. A `LinearResistance` makes
no assumptions about the direction of the flow: water flows from high to low.
Here $h_a$ is the water level in the first basin, $h_b$ is the water level in the second basin.
$R$ is the resistance of the link, and $Q_{\max}$ is the maximum flow rate.
A `LinearResistance` makes no assumptions about the direction of the flow: water flows from high to low.
### Terminal
Expand Down
1 change: 1 addition & 0 deletions docs/core/usage.qmd
Original file line number Diff line number Diff line change
Expand Up @@ -580,6 +580,7 @@ node_id | Int | - | sorted
control_state | String | - | (optional) sorted per node_id
active | Bool | - | (optional, default true)
resistance | Float64 | $sm^{-2}$ | -
max_flow_rate | Float64 | $m^3 s^{-1}$ | non-negative

# ManningResistance {#sec-manning-resistance}

Expand Down
11 changes: 11 additions & 0 deletions docs/schema/LinearResistanceStatic.schema.json
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,17 @@
"format": "double",
"type": "number"
},
"max_flow_rate": {
"format": "default",
"anyOf": [
{
"type": "null"
},
{
"type": "number"
}
]
},
"control_state": {
"format": "default",
"anyOf": [
Expand Down
1 change: 1 addition & 0 deletions python/ribasim/ribasim/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -117,6 +117,7 @@ class LinearResistanceStatic(BaseModel):
node_id: int
active: bool | None = None
resistance: float
max_flow_rate: float | None = None
control_state: str | None = None
remarks: str = Field("", description="a hack for pandera")

Expand Down
4 changes: 3 additions & 1 deletion python/ribasim_testmodels/ribasim_testmodels/equations.py
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,9 @@ def linear_resistance_model():

# setup linear resistance:
linear_resistance = ribasim.LinearResistance(
static=pd.DataFrame(data={"node_id": [2], "resistance": [5e4]})
static=pd.DataFrame(
data={"node_id": [2], "resistance": [5e4], "max_flow_rate": [6e-5]}
)
)

# Setup level boundary:
Expand Down

0 comments on commit 9163696

Please sign in to comment.