32#ifndef OPENSWMM_TREATMENT_HPP
33#define OPENSWMM_TREATMENT_HPP
134 int (*pollut_lookup)(
const std::string& name));
149 double hrt,
double q,
double v,
double d,
double area = 0.0);
168 double hrt,
double q,
double v,
double d,
169 const double* cin,
const double* removal,
int n_pollut,
191 double hrt,
double q,
double v,
double d,
double area = 0.0);
double applyTreatment(const TreatExpr &expr, double c_in, double dt, double hrt, double q, double v, double d, double area)
Apply treatment at a node for one pollutant.
Definition Treatment.cpp:445
TokenType
Definition Treatment.hpp:46
@ LPAREN
Left parenthesis (parser internal, never in output)
@ COMMA
Comma separator for min/max (parser internal)
@ FUNC_STEP
Heaviside step.
@ RPAREN
Right parenthesis (parser internal, never in output)
double evaluate(const TreatExpr &expr, double c, double dt, double hrt, double q, double v, double d, double area)
Evaluate a treatment expression with given variable values.
Definition Treatment.cpp:330
TreatVar
Definition Treatment.hpp:68
@ C
Current concentration (this pollutant)
@ R_POLLUT
Removal fraction of another pollutant (uses pollut_ref, co-treatment)
@ C_POLLUT
Concentration of another pollutant (uses pollut_ref)
@ HRT
Hydraulic residence time (hours, per legacy convention)
@ AREA
Node surface area in user units² ((a1+a2)/2*UCF(LENGTH)², matching legacy pvAREA)
@ R
Removal fraction (this pollutant, unused in expressions)
@ Q
Flow rate in user units (Q*UCF(FLOW), matching legacy pvFLOW)
@ D
Depth in user units (y*UCF(LENGTH), matching legacy pvDEPTH)
int parse(const std::string &expr_str, TreatExpr &result)
Parse a treatment expression string into postfix tokens.
Definition Treatment.cpp:275
Definition NodeCoupling.cpp:15
Definition Treatment.hpp:85
double value
For NUMBER tokens.
Definition Treatment.hpp:87
int pollut_ref
Pollutant index for C_POLLUT/R_POLLUT.
Definition Treatment.hpp:89
TokenType type
Definition Treatment.hpp:86
TreatVar var
For VARIABLE tokens.
Definition Treatment.hpp:88
Definition Treatment.hpp:96
bool is_removal
True if expression computes R (removal), false if C.
Definition Treatment.hpp:99
std::vector< Token > tokens
Postfix (RPN) token list.
Definition Treatment.hpp:97
int pollutant_idx
Which pollutant this expression applies to.
Definition Treatment.hpp:98