24#ifndef OPENSWMM_SNOW_HPP
25#define OPENSWMM_SNOW_HPP
31struct SimulationContext;
53 std::vector<double>
fw;
55 std::vector<double>
ati;
56 std::vector<double>
awe;
61 std::vector<double>
dhm;
70 std::vector<double>
si;
71 std::vector<double>
sba;
73 std::vector<double>
asc;
80 std::vector<double>
snn;
104 void init(
int n_subcatch);
127 double temp,
double wind,
double rainfall,
128 double snowfall = 0.0,
129 double gamma = 0.0,
double ea = 0.0);
153 static void batchATIUpdate(
double* ati,
double temp,
double tipm,
154 double dt,
int count);
157 static void batchDegreeDayMelt(
const double* dhm,
const double* tbase,
158 double temp,
double* melt,
int count);
161 static void batchRainOnSnowMelt(
double temp,
double wind,
double gamma,
162 double ea,
double rainfall,
163 double* melt,
int count);
166 static void batchAccumulate(
double* wsnow,
double snowfall,
double dt,
int count);
SnowSoA & state()
Definition Snow.hpp:147
void init(int n_subcatch)
Definition Snow.cpp:47
void setMeltCoeffs(int day_of_year)
Update seasonal melt coefficients based on day of year.
Definition Snow.cpp:351
void execute(SimulationContext &ctx, double dt, double temp, double wind, double rainfall, double snowfall=0.0, double gamma=0.0, double ea=0.0)
Compute snowmelt for all subcatchments (batch).
Definition Snow.cpp:205
void plowSnow(SimulationContext &ctx, double dt, double snowfall)
Snow plowing — redistribute excess snow between subareas.
Definition Snow.cpp:373
constexpr int SNOW_IMPERV
Definition Snow.hpp:41
constexpr int SNOW_PERV
Definition Snow.hpp:42
constexpr int N_SUBAREAS
Plowable, Impervious, Pervious.
Definition Snow.hpp:39
constexpr int SNOW_PLOWABLE
Definition Snow.hpp:40
Definition NodeCoupling.cpp:15
Central, reentrant simulation context.
Definition SimulationContext.hpp:274
std::vector< double > sfrac
Definition Snow.hpp:84
std::vector< int > to_subcatch
Target subcatchment for plowed snow.
Definition Snow.hpp:87
std::vector< double > fwfrac
Free water capacity fraction.
Definition Snow.hpp:64
double removed
Cumulative snow plowed out of system (ft3)
Definition Snow.hpp:93
double adc_perv[10]
Definition Snow.hpp:77
std::vector< double > dhmin
Min melt coeff (winter solstice) (ft/deg-F/sec)
Definition Snow.hpp:62
std::vector< double > asc
Computed areal snow coverage (0–1), per subarea.
Definition Snow.hpp:73
std::vector< double > sbws
Snow water equiv at end of new-snow ADC.
Definition Snow.hpp:72
std::vector< double > coldc
Cold content (ft water equiv)
Definition Snow.hpp:54
std::vector< double > wsnow
Snow water equivalent (ft)
Definition Snow.hpp:52
double adc_imperv[10]
Definition Snow.hpp:76
std::vector< double > awe
Areal depletion index.
Definition Snow.hpp:56
double tipm
ATI weighting factor.
Definition Snow.hpp:90
int n_subcatch
Definition Snow.hpp:49
double rnm
Negative melt ratio.
Definition Snow.hpp:91
std::vector< double > tbase
Base melt temperature (deg F)
Definition Snow.hpp:60
std::vector< double > imelt
Melt rate output (ft/sec)
Definition Snow.hpp:57
std::vector< double > fArea
Fraction of total area for each subarea.
Definition Snow.hpp:67
std::vector< double > snn
Plowable fraction of impervious area.
Definition Snow.hpp:80
std::vector< double > si
Snow depth for 100% cover (ft)
Definition Snow.hpp:70
void resize(int n)
Definition Snow.cpp:20
double season
Current snowmelt season factor (-1 to +1)
Definition Snow.hpp:92
std::vector< double > fw
Free water in pack (ft)
Definition Snow.hpp:53
std::vector< double > sba
Snow coverage area at start of new-snow ADC.
Definition Snow.hpp:71
std::vector< double > dhmax
Max melt coeff (summer solstice) (ft/deg-F/sec)
Definition Snow.hpp:63
std::vector< double > ati
Antecedent temperature index (deg F)
Definition Snow.hpp:55
std::vector< double > dhm
Degree-day melt factor (ft/deg-F/sec)
Definition Snow.hpp:61
std::vector< double > weplow
Depth at which plowing begins (ft)
Definition Snow.hpp:83