Antares Simulator
Power System Simulator
BindingConstraintGroupRepository.h
1 /*
2 ** Copyright 2007-2025, RTE (https://www.rte-france.com)
3 ** See AUTHORS.txt
4 ** SPDX-License-Identifier: MPL-2.0
5 ** This file is part of Antares-Simulator,
6 ** Adequacy and Performance assessment for interconnected energy networks.
7 **
8 ** Antares_Simulator is free software: you can redistribute it and/or modify
9 ** it under the terms of the Mozilla Public Licence 2.0 as published by
10 ** the Mozilla Foundation, either version 2 of the License, or
11 ** (at your option) any later version.
12 **
13 ** Antares_Simulator is distributed in the hope that it will be useful,
14 ** but WITHOUT ANY WARRANTY; without even the implied warranty of
15 ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 ** Mozilla Public Licence 2.0 for more details.
17 **
18 ** You should have received a copy of the Mozilla Public Licence 2.0
19 ** along with Antares_Simulator. If not, see <https://opensource.org/license/mpl-2-0/>.
20 */
21 //
22 // Created by marechaljas on 28/06/23.
23 //
24 
25 #pragma once
26 
27 #include <functional>
28 #include <memory>
29 #include <set>
30 
31 #include "antares/study/binding_constraint/BindingConstraintGroup.h"
32 #include "antares/study/fwd.h"
33 
34 #include "BindingConstraint.h"
35 #include "BindingConstraintSaver.h"
36 
37 namespace Antares::Data
38 {
39 
41 {
42 public:
43  [[nodiscard]] unsigned size() const;
44 
45  [[nodiscard]] bool buildFrom(const BindingConstraintsRepository& repository);
46 
47  void resizeAllTimeseriesNumbers(unsigned nb_years);
48 
49  BindingConstraintGroup* operator[](const std::string& name) const;
50 
51  using iterator = std::vector<std::unique_ptr<BindingConstraintGroup>>::iterator;
52  using const_iterator = std::vector<std::unique_ptr<BindingConstraintGroup>>::const_iterator;
53 
54  [[nodiscard]] iterator begin();
55  [[nodiscard]] const_iterator begin() const;
56 
57  [[nodiscard]] iterator end();
58  [[nodiscard]] const_iterator end() const;
59 
60  BindingConstraintGroup* add(const std::string& name);
61  void clear();
62 
63 private:
64  [[nodiscard]] bool timeSeriesWidthConsistentInGroups() const;
65 
66  std::vector<std::unique_ptr<BindingConstraintGroup>> groups_;
67 };
68 
69 } // namespace Antares::Data
Definition: BindingConstraintGroupRepository.h:41
Definition: BindingConstraintGroup.h:36
Definition: BindingConstraintsRepository.h:36