Antares Simulator
Power System Simulator
Loading...
Searching...
No Matches
linearProblemData.h
1/*
2 * Copyright 2007-2024, 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 <memory>
25#include <string>
26
27#include "antares/optimisation/linear-problem-api/ILinearProblemData.h"
28#include "antares/optimisation/linear-problem-data-impl/dataSeriesRepo.h"
29#include "antares/optimisation/linear-problem-data-impl/scenarioGroupRepo.h"
30
31namespace Antares::Optimisation::LinearProblemDataImpl
32{
33
35{
36public:
37 LinearProblemData() = default;
38
39 explicit LinearProblemData(DataSeriesRepository data_series_repository):
40 dataSeriesRepository_(std::move(data_series_repository))
41 {
42 }
43
44 double getData(const std::string& dataSetId,
45 const std::string& scenarioGroup,
46 const unsigned scenario,
47 const unsigned hour) override;
48
49 void addScenarioGroup(const std::string& groupId, std::pair<unsigned, unsigned> scenarioToRank);
50 void addDataSeries(std::unique_ptr<IDataSeries> dataSeries);
51
52private:
53 DataSeriesRepository dataSeriesRepository_;
54 ScenarioGroupRepository groupRepository_;
55};
56
57} // namespace Antares::Optimisation::LinearProblemDataImpl