hydrobricks
Loading...
Searching...
No Matches
SubBasin.h
1#ifndef HYDROBRICKS_SUBBASIN_H
2#define HYDROBRICKS_SUBBASIN_H
3
4#include <memory>
5#include <unordered_map>
6#include <vector>
7
8#include "Connector.h"
9#include "HydroUnit.h"
10#include "Includes.h"
11#include "SettingsBasin.h"
12#include "TimeMachine.h"
13
14class SubBasin {
15 public:
16 SubBasin();
17
18 virtual ~SubBasin();
19
26 [[nodiscard]] ModelResult Initialize(SettingsBasin& basinSettings);
27
33 void BuildBasin(SettingsBasin& basinSettings);
34
40 void ReserveHydroUnits(size_t count) {
41 _hydroUnits.reserve(_hydroUnits.size() + count);
42 }
43
49 void ReserveBricks(size_t count) {
50 _bricks.reserve(_bricks.size() + count);
51 }
52
58 void ReserveSplitters(size_t count) {
59 _splitters.reserve(_splitters.size() + count);
60 }
61
67 void ReserveInputConnectors(size_t count) {
68 _inConnectors.reserve(_inConnectors.size() + count);
69 }
70
76 void ReserveOutputConnectors(size_t count) {
77 _outConnectors.reserve(_outConnectors.size() + count);
78 }
79
85 void ReserveOutletFluxes(size_t count) {
86 _outletFluxes.reserve(_outletFluxes.size() + count);
87 }
88
95
102 [[nodiscard]] ModelResult AssignFractions(SettingsBasin& basinSettings);
103
107 void Reset();
108
112 void SaveAsInitialState();
113
119 [[nodiscard]] bool IsValid(bool checkProcesses = true) const;
120
127 void Validate() const;
128
134 void AddBrick(std::unique_ptr<Brick> brick);
135
141 void AddSplitter(std::unique_ptr<Splitter> splitter);
142
148 void AddHydroUnit(std::unique_ptr<HydroUnit> unit);
149
155 [[nodiscard]] int GetHydroUnitCount() const;
156
163 [[nodiscard]] HydroUnit* GetHydroUnit(size_t index) const;
164
170 [[nodiscard]] bool HasHydroUnits() const noexcept {
171 return !_hydroUnits.empty();
172 }
173
180 [[nodiscard]] HydroUnit* GetHydroUnitById(int id) const;
181
187 [[nodiscard]] vecInt GetHydroUnitIds() const;
188
194 [[nodiscard]] vecDouble GetHydroUnitAreas() const;
195
201 [[nodiscard]] int GetBrickCount() const;
202
208 [[nodiscard]] int GetSplitterCount() const;
209
216 [[nodiscard]] Brick* GetBrick(size_t index) const;
217
224 [[nodiscard]] bool HasBrick(std::string_view name) const;
225
232 [[nodiscard]] Brick* GetBrick(std::string_view name) const;
233
240 [[nodiscard]] Splitter* GetSplitter(size_t index) const;
241
248 [[nodiscard]] bool HasSplitter(std::string_view name) const;
249
256 [[nodiscard]] Splitter* GetSplitter(std::string_view name) const;
257
263 [[nodiscard]] bool HasIncomingFlow() const;
264
270 void AddInputConnector(Connector* connector);
271
277 void AddOutputConnector(Connector* connector);
278
284 void AttachOutletFlux(Flux* pFlux);
285
292 double* GetValuePointer(std::string_view name);
293
299 [[nodiscard]] bool ComputeOutletDischarge();
300
306 [[nodiscard]] double GetArea() const {
307 return _area;
308 }
309
310 protected:
311 double _area; // m2
312 double _outletTotal;
313 std::vector<std::unique_ptr<Brick>> _bricks; // owning: SubBasin-level bricks
314 std::unordered_map<string, Brick*> _brickMap; // non-owning views into _bricks
315 std::vector<std::unique_ptr<Splitter>> _splitters; // owning: SubBasin-level splitters
316 std::unordered_map<string, Splitter*> _splitterMap; // non-owning views into _splitters
317 std::vector<std::unique_ptr<HydroUnit>> _hydroUnits; // owning
318 std::unordered_map<int, HydroUnit*> _hydroUnitMap; // non-owning views into _hydroUnits
319 std::vector<Connector*> _inConnectors; // non-owning: lifetime managed externally
320 std::vector<Connector*> _outConnectors; // non-owning: lifetime managed externally
321 std::vector<Flux*> _outletFluxes; // non-owning: lifetime managed by process owners
322};
323
324#endif
Definition Brick.h:24
Definition Connector.h:8
Definition Flux.h:9
Definition HydroUnit.h:18
Definition SettingsBasin.h:47
Definition Splitter.h:13
Definition SubBasin.h:14
bool ComputeOutletDischarge()
Definition SubBasin.cpp:286
void ReserveInputConnectors(size_t count)
Definition SubBasin.h:67
void AddSplitter(std::unique_ptr< Splitter > splitter)
Definition SubBasin.cpp:142
int GetSplitterCount() const
Definition SubBasin.cpp:201
vecInt GetHydroUnitIds() const
Definition SubBasin.cpp:177
bool IsValid(bool checkProcesses=true) const
Definition SubBasin.cpp:110
double * GetValuePointer(std::string_view name)
Definition SubBasin.cpp:277
void SaveAsInitialState()
Definition SubBasin.cpp:101
void AddHydroUnit(std::unique_ptr< HydroUnit > unit)
Definition SubBasin.cpp:149
void ReserveOutletFluxes(size_t count)
Definition SubBasin.h:85
int GetBrickCount() const
Definition SubBasin.cpp:197
ModelResult AssignFractions(SettingsBasin &basinSettings)
Definition SubBasin.cpp:57
void BuildBasin(SettingsBasin &basinSettings)
Definition SubBasin.cpp:28
void Validate() const
Definition SubBasin.cpp:128
double GetArea() const
Definition SubBasin.h:306
vecDouble GetHydroUnitAreas() const
Definition SubBasin.cpp:187
int GetHydroUnitCount() const
Definition SubBasin.cpp:157
void AddBrick(std::unique_ptr< Brick > brick)
Definition SubBasin.cpp:135
void Reset()
Definition SubBasin.cpp:89
HydroUnit * GetHydroUnitById(int id) const
Definition SubBasin.cpp:168
void ReserveBricks(size_t count)
Definition SubBasin.h:49
ModelResult Initialize(SettingsBasin &basinSettings)
Definition SubBasin.cpp:18
void ReserveHydroUnits(size_t count)
Definition SubBasin.h:40
bool HasBrick(std::string_view name) const
Definition SubBasin.cpp:212
void ReserveSplitters(size_t count)
Definition SubBasin.h:58
bool HasSplitter(std::string_view name) const
Definition SubBasin.cpp:232
Brick * GetBrick(size_t index) const
Definition SubBasin.cpp:205
HydroUnit * GetHydroUnit(size_t index) const
Definition SubBasin.cpp:161
bool HasIncomingFlow() const
Definition SubBasin.cpp:258
Splitter * GetSplitter(size_t index) const
Definition SubBasin.cpp:225
void AttachOutletFlux(Flux *pFlux)
Definition SubBasin.cpp:272
void AddInputConnector(Connector *connector)
Definition SubBasin.cpp:262
bool HasHydroUnits() const noexcept
Definition SubBasin.h:170
void ReserveLateralConnectionsForUnits(SettingsBasin &basinSettings)
Definition SubBasin.cpp:245
void AddOutputConnector(Connector *connector)
Definition SubBasin.cpp:267
void ReserveOutputConnectors(size_t count)
Definition SubBasin.h:76