16#ifndef OPENSWMM_NODE_HPP
17#define OPENSWMM_NODE_HPP
19#include "../core/Constants.hpp"
20#include "../data/NodeData.hpp"
21#include "../data/TableData.hpp"
25struct SimulationContext;
44double getVolume(
const NodeData& nodes,
int idx,
double depth,
45 TableData* tables =
nullptr,
int unit_sys = 0);
58double getSurfArea(
const NodeData& nodes,
int idx,
double depth,
59 TableData* tables =
nullptr,
int unit_sys = 0);
72double getPondedArea(
const NodeData& nodes,
int idx,
double depth);
85double getMaxOutflow(
const NodeData& nodes,
int idx,
double q,
double dt);
99double getOverflow(
double new_volume,
double full_volume,
double dt);
109double getDepth(
const NodeData& nodes,
int idx,
double volume,
110 TableData* tables =
nullptr,
int unit_sys = 0);
115inline double getHead(
double invert_elev,
double depth) {
116 return invert_elev + depth;
131void computeHeads(
const double* invert,
const double* depth,
double* head,
int n);
152 double* overflow,
double dt,
int n);
double getHead(double invert_elev, double depth)
Compute head from depth: head = invert + depth.
Definition Node.hpp:115
double getSurfArea(const NodeData &nodes, int idx, double depth, TableData *tables, int unit_sys)
Compute surface area at a given depth for a single node.
Definition Node.cpp:131
void computeVolumes(const NodeData &nodes, const double *depth, double *volume)
Compute volumes for all nodes from their current depths.
Definition Node.cpp:227
void computeOverflows(const double *new_volume, const double *full_volume, double *overflow, double dt, int n)
Compute overflow for all nodes.
Definition Node.cpp:238
void computeHeads(const double *invert, const double *depth, double *head, int n)
Compute head = invert + depth for all nodes.
Definition Node.cpp:217
double getDepth(const NodeData &nodes, int idx, double volume, TableData *tables, int unit_sys)
Compute depth from volume for a single node (inverse of getVolume).
Definition Node.cpp:68
double getOverflow(double new_volume, double full_volume, double dt)
Compute overflow rate at a node.
Definition Node.cpp:206
double getMaxOutflow(const NodeData &nodes, int idx, double q, double dt)
Compute max outflow limited by available volume.
Definition Node.cpp:191
double getVolume(const NodeData &nodes, int idx, double depth, TableData *tables, int unit_sys)
Compute volume at a given depth for a single node.
Definition Node.cpp:25
double getPondedArea(const NodeData &nodes, int idx, double depth)
Get the ponded area (for overflow above rim).
Definition Node.cpp:174
Definition NodeCoupling.cpp:15
Structure-of-Arrays storage for all nodes.
Definition NodeData.hpp:90