Antares Simulator
Power System Simulator
loadFiles.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 <vector>
26 #include <yaml-cpp/yaml.h>
27 
28 #include <antares/solver/modeler/data.h>
29 #include <antares/solver/modeler/parameters/modelerParameters.h>
30 #include <antares/study/system-model/library.h>
31 #include <antares/study/system-model/system.h>
32 
33 namespace Antares::Solver::LoadFiles
34 {
35 
37 Antares::Modeler::Data loadAll(const std::filesystem::path& studyPath);
38 
39 ModelerParameters loadParameters(const std::filesystem::path& studyPath);
40 
41 std::vector<ModelerStudy::SystemModel::Library> loadLibraries(
42  const std::filesystem::path& studyPath);
43 
44 ModelerStudy::SystemModel::System loadSystem(
45  const std::filesystem::path& studyPath,
46  const std::vector<ModelerStudy::SystemModel::Library>& libraries);
47 
48 std::unique_ptr<Optimisation::LinearProblemApi::ILinearProblemData> loadDataSeries(
49  const std::filesystem::path& studyPath);
50 
51 Optimisation::ScenarioGroupRepository loadScenarioGroupRepository(
52  const std::filesystem::path& studyPath);
53 
54 void handleYamlError(const YAML::Exception& e, const std::string& filename);
55 
57 class ErrorLoadingYaml final: public std::runtime_error
58 {
59 public:
60  explicit ErrorLoadingYaml(const std::string& s):
61  runtime_error(s)
62  {
63  }
64 };
65 
66 } // namespace Antares::Solver::LoadFiles
Generic error class for all loading errors to catch in the main.
Definition: loadFiles.h:58
Definition: data.h:38