22#ifndef OPENSWMM_RUNOFF_HPP
23#define OPENSWMM_RUNOFF_HPP
25#include "../data/SubcatchData.hpp"
31struct SimulationContext;
39constexpr double MEXP = 5.0 / 3.0;
41constexpr double PHI = 1.486;
106 double infil_factor = 1.0,
double recovery_factor = 1.0,
127 void infil_get_state(
int i,
int& model,
double state[6])
const noexcept;
139 void infil_set_state(
int i,
int model,
const double state[6])
noexcept;
145 std::vector<InfilModel> infil_models_;
146 std::vector<HortonState> horton_states_;
147 std::vector<GreenAmptState> grnampt_states_;
148 std::vector<CurveNumState> curvenum_states_;
151 std::vector<double> precip_;
152 std::vector<double> evap_rate_;
153 std::vector<double> infil_rate_;
157 static void updatePondedDepth(
double& depth,
double inflow,
double alpha,
158 double dStore,
double dt);
161 static double getRunoffRate(
double depth,
double dStore,
double alpha);
Infiltration models — Horton, Green-Ampt, SCS Curve Number.
void infil_set_state(int i, int model, const double state[6]) noexcept
Restore infiltration state for subcatchment i from a flat 6-element array.
Definition Runoff.cpp:603
void init(SimulationContext &ctx)
Definition Runoff.cpp:161
const RunoffSoA & soa() const
Definition Runoff.hpp:109
void infil_get_state(int i, int &model, double state[6]) const noexcept
Pack infiltration state for subcatchment i into a flat 6-element array.
Definition Runoff.cpp:562
void execute(SimulationContext &ctx, double dt, double evap_rate=0.0, double infil_factor=1.0, double recovery_factor=1.0, int month=-1)
Definition Runoff.cpp:234
constexpr double PHI
Manning's US customary constant.
Definition Runoff.hpp:41
constexpr double ODETOL
ODE solver tolerance (matching legacy)
Definition Runoff.hpp:40
constexpr double MEXP
Manning's exponent.
Definition Runoff.hpp:39
Definition NodeCoupling.cpp:15
Central, reentrant simulation context.
Definition SimulationContext.hpp:274
std::vector< double > depth_imperv0
Ponded depth, IMPERV0 (ft) — dStore=0.
Definition Runoff.hpp:70
std::vector< double > depth_perv
Ponded depth, PERV (ft)
Definition Runoff.hpp:72
int n_subcatch
Definition Runoff.hpp:48
std::vector< double > alpha_perv
Alpha for pervious subarea.
Definition Runoff.hpp:59
std::vector< double > imperv_runoff_cfs
Impervious subarea runoff (CFS, non-LID area)
Definition Runoff.hpp:87
void resize(int n)
Definition Runoff.cpp:46
std::vector< double > ds_perv
Depression storage for PERV.
Definition Runoff.hpp:63
std::vector< double > ds_imperv
Depression storage for IMPERV1.
Definition Runoff.hpp:62
std::vector< double > old_runoff_imperv1
Previous IMPERV1 runoff (ft/sec)
Definition Runoff.hpp:77
std::vector< double > area
Subcatchment area (ft²)
Definition Runoff.hpp:51
std::vector< double > imperv_pct
Impervious fraction (0-1)
Definition Runoff.hpp:54
std::vector< double > slope
Average slope (ft/ft)
Definition Runoff.hpp:53
std::vector< double > old_runoff_imperv0
Previous IMPERV0 runoff (ft/sec)
Definition Runoff.hpp:76
std::vector< double > runoff
Total runoff rate (cfs)
Definition Runoff.hpp:81
std::vector< double > perv_runoff_cfs
Pervious subarea runoff (CFS, non-LID area)
Definition Runoff.hpp:88
std::vector< double > width
Subcatchment width (ft)
Definition Runoff.hpp:52
std::vector< double > depth_imperv1
Ponded depth, IMPERV1 (ft) — dStore>0.
Definition Runoff.hpp:71
std::vector< double > imperv0_pct
Fraction of imperv with zero dStore (0-1)
Definition Runoff.hpp:55
std::vector< double > infil_loss
Infiltration loss (ft3)
Definition Runoff.hpp:83
void computeAlpha()
Definition Runoff.cpp:78
std::vector< double > evap_loss
Evaporation loss (ft3)
Definition Runoff.hpp:82
std::vector< double > old_runoff_perv
Previous PERV runoff (ft/sec)
Definition Runoff.hpp:78
std::vector< double > n_imperv
Manning's n, impervious.
Definition Runoff.hpp:66
std::vector< double > n_perv
Manning's n, pervious.
Definition Runoff.hpp:67
std::vector< double > alpha_imperv
Alpha for impervious subareas.
Definition Runoff.hpp:58