Antares Simulator
Power System Simulator
Loading...
Searching...
No Matches
mipSolution.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 <map>
25#include <ortools/linear_solver/linear_solver.h>
26#include <string>
27#include <vector>
28
29#include <antares/optimisation/linear-problem-api/mipSolution.h>
30
31namespace Antares::Optimisation::LinearProblemMpsolverImpl
32{
33
35{
36public:
37 OrtoolsMipSolution(operations_research::MPSolver::ResultStatus& responseStatus,
38 operations_research::MPSolver* solver);
39
40 ~OrtoolsMipSolution() override = default;
41
42 LinearProblemApi::MipStatus getStatus() const override;
43 double getObjectiveValue() const override;
44 double getOptimalValue(const LinearProblemApi::IMipVariable* var) const override;
45 std::vector<double> getOptimalValues(
46 const std::vector<LinearProblemApi::IMipVariable*>& vars) const override;
47 const std::map<std::string, double>& getOptimalValues() const override;
48
49private:
50 operations_research::MPSolver::ResultStatus status_;
51 operations_research::MPSolver* mpSolver_;
52 std::map<std::string, double> solution_;
53};
54
55} // namespace Antares::Optimisation::LinearProblemMpsolverImpl