Antares Simulator
Power System Simulator
singleProblemGetter.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 #pragma once
23 
24 #include <filesystem>
25 #include <memory>
26 
27 #include "antares/solver/lps/LpsFromAntares.h"
28 #include "antares/study/study.h"
29 
30 namespace Antares::Solver::Implementation
31 {
32 class SingleProblemGetter;
33 }
34 
35 namespace Antares::Solver
36 {
38 {
39 public:
40  explicit SingleProblemGetter(const std::filesystem::path& studyPath);
42  // NOTE week indices start at 1
43  // year indices start at 0
44  std::vector<WeeklyProblemId> getProblemIds() const;
45  ConstantDataFromAntares getConstantData();
46  // NOTE week indices start at 1
47  // year indices start at 0
48  WeeklyDataFromAntares getWeeklyData(WeeklyProblemId id);
49 
50  // TODO[FOM] This should not be necessary
51  void writeNTCTimeSeries(const std::filesystem::path& outputDir);
52  void writeStudyDescriptionFiles(const std::filesystem::path& outputDir);
53 
54 private:
55  std::unique_ptr<Implementation::SingleProblemGetter> impl_;
56 };
57 } // namespace Antares::Solver
Definition: singleProblemGetter.h:38
The ConstantDataFromAntares class is used to store constant data across all weeks of Antares problems...
Definition: LpsFromAntares.h:54
The WeeklyDataFromAntares class is used to store weekly data for an Antares Problem.
Definition: LpsFromAntares.h:89
The WeeklyProblemId struct is used to identify a weekly problem by year and week.
Definition: LpsFromAntares.h:37