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
160 void ResetForcingUpdates();
161
168 [[nodiscard]] HydroUnit* GetHydroUnit(size_t index) const;
169
175 [[nodiscard]] bool HasHydroUnits() const noexcept {
176 return !_hydroUnits.empty();
177 }
178
185 [[nodiscard]] HydroUnit* GetHydroUnitById(int id) const;
186
192 [[nodiscard]] vecInt GetHydroUnitIds() const;
193
199 [[nodiscard]] vecDouble GetHydroUnitAreas() const;
200
206 [[nodiscard]] int GetBrickCount() const;
207
213 [[nodiscard]] int GetSplitterCount() const;
214
221 [[nodiscard]] Brick* GetBrick(size_t index) const;
222
229 [[nodiscard]] bool HasBrick(std::string_view name) const;
230
237 [[nodiscard]] Brick* GetBrick(std::string_view name) const;
238
245 [[nodiscard]] Splitter* GetSplitter(size_t index) const;
246
253 [[nodiscard]] bool HasSplitter(std::string_view name) const;
254
261 [[nodiscard]] Splitter* GetSplitter(std::string_view name) const;
262
268 [[nodiscard]] bool HasIncomingFlow() const;
269
275 void AddInputConnector(Connector* connector);
276
282 void AddOutputConnector(Connector* connector);
283
289 void AttachOutletFlux(Flux* pFlux);
290
297 double* GetValuePointer(std::string_view name);
298
304 [[nodiscard]] bool ComputeOutletDischarge();
305
311 [[nodiscard]] double GetArea() const {
312 return _area;
313 }
314
315 protected:
316 double _area; // m2
317 double _outletTotal;
318 std::vector<std::unique_ptr<Brick>> _bricks; // owning: SubBasin-level bricks
319 std::unordered_map<string, Brick*> _brickMap; // non-owning views into _bricks
320 std::vector<std::unique_ptr<Splitter>> _splitters; // owning: SubBasin-level splitters
321 std::unordered_map<string, Splitter*> _splitterMap; // non-owning views into _splitters
322 std::vector<std::unique_ptr<HydroUnit>> _hydroUnits; // owning
323 std::unordered_map<int, HydroUnit*> _hydroUnitMap; // non-owning views into _hydroUnits
324 std::vector<Connector*> _inConnectors; // non-owning: lifetime managed externally
325 std::vector<Connector*> _outConnectors; // non-owning: lifetime managed externally
326 std::vector<Flux*> _outletFluxes; // non-owning: lifetime managed by process owners
327};
328
329#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:292
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:207
vecInt GetHydroUnitIds() const
Definition SubBasin.cpp:183
bool IsValid(bool checkProcesses=true) const
Definition SubBasin.cpp:110
double * GetValuePointer(std::string_view name)
Definition SubBasin.cpp:283
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:203
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:311
vecDouble GetHydroUnitAreas() const
Definition SubBasin.cpp:193
int GetHydroUnitCount() const
Definition SubBasin.cpp:163
void AddBrick(std::unique_ptr< Brick > brick)
Definition SubBasin.cpp:135
void ResetForcingUpdates()
Definition SubBasin.cpp:157
void Reset()
Definition SubBasin.cpp:89
HydroUnit * GetHydroUnitById(int id) const
Definition SubBasin.cpp:174
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:218
void ReserveSplitters(size_t count)
Definition SubBasin.h:58
bool HasSplitter(std::string_view name) const
Definition SubBasin.cpp:238
Brick * GetBrick(size_t index) const
Definition SubBasin.cpp:211
HydroUnit * GetHydroUnit(size_t index) const
Definition SubBasin.cpp:167
bool HasIncomingFlow() const
Definition SubBasin.cpp:264
Splitter * GetSplitter(size_t index) const
Definition SubBasin.cpp:231
void AttachOutletFlux(Flux *pFlux)
Definition SubBasin.cpp:278
void AddInputConnector(Connector *connector)
Definition SubBasin.cpp:268
bool HasHydroUnits() const noexcept
Definition SubBasin.h:175
void ReserveLateralConnectionsForUnits(SettingsBasin &basinSettings)
Definition SubBasin.cpp:251
void AddOutputConnector(Connector *connector)
Definition SubBasin.cpp:273
void ReserveOutputConnectors(size_t count)
Definition SubBasin.h:76