1#ifndef HYDROBRICKS_SUBBASIN_H
2#define HYDROBRICKS_SUBBASIN_H
5#include <unordered_map>
11#include "SettingsBasin.h"
12#include "TimeMachine.h"
41 _hydroUnits.reserve(_hydroUnits.size() + count);
50 _bricks.reserve(_bricks.size() + count);
59 _splitters.reserve(_splitters.size() + count);
68 _inConnectors.reserve(_inConnectors.size() + count);
77 _outConnectors.reserve(_outConnectors.size() + count);
86 _outletFluxes.reserve(_outletFluxes.size() + count);
119 [[nodiscard]]
bool IsValid(
bool checkProcesses =
true)
const;
134 void AddBrick(std::unique_ptr<Brick> brick);
141 void AddSplitter(std::unique_ptr<Splitter> splitter);
176 return !_hydroUnits.empty();
229 [[nodiscard]]
bool HasBrick(std::string_view name)
const;
253 [[nodiscard]]
bool HasSplitter(std::string_view name)
const;
318 std::vector<std::unique_ptr<Brick>> _bricks;
319 std::unordered_map<string, Brick*> _brickMap;
320 std::vector<std::unique_ptr<Splitter>> _splitters;
321 std::unordered_map<string, Splitter*> _splitterMap;
322 std::vector<std::unique_ptr<HydroUnit>> _hydroUnits;
323 std::unordered_map<int, HydroUnit*> _hydroUnitMap;
324 std::vector<Connector*> _inConnectors;
325 std::vector<Connector*> _outConnectors;
326 std::vector<Flux*> _outletFluxes;
Definition HydroUnit.h:18
Definition SettingsBasin.h:47
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