From ba6a21206f3f579d62db1f219d1691b458da8346 Mon Sep 17 00:00:00 2001 From: Florian OMNES Date: Wed, 8 Jan 2025 16:52:20 +0100 Subject: [PATCH] Expose method Write instead of relying on protected MpSolver method --- .../api/include/antares/solver/modeler/api/linearProblem.h | 2 ++ src/solver/modeler/main.cpp | 2 +- .../antares/solver/modeler/ortoolsImpl/linearProblem.h | 1 + src/solver/modeler/ortoolsImpl/linearProblem.cpp | 5 +++++ 4 files changed, 9 insertions(+), 1 deletion(-) diff --git a/src/solver/modeler/api/include/antares/solver/modeler/api/linearProblem.h b/src/solver/modeler/api/include/antares/solver/modeler/api/linearProblem.h index 6885d81ac1..17cd8c6f8b 100644 --- a/src/solver/modeler/api/include/antares/solver/modeler/api/linearProblem.h +++ b/src/solver/modeler/api/include/antares/solver/modeler/api/linearProblem.h @@ -72,6 +72,8 @@ class ILinearProblem /// Solve the problem, returns a IMipSolution virtual IMipSolution* solve(bool verboseSolver) = 0; + virtual void Write(const std::string& filename) = 0; + // Definition of infinity virtual double infinity() const = 0; }; diff --git a/src/solver/modeler/main.cpp b/src/solver/modeler/main.cpp index 5e75b34a2d..837eabb08a 100644 --- a/src/solver/modeler/main.cpp +++ b/src/solver/modeler/main.cpp @@ -85,7 +85,7 @@ int main(int argc, const char** argv) { logs.info() << "Writing problem.mps..."; auto mps_path = std::filesystem::current_path() / "problem.mps"; - pb.MpSolver()->Write(mps_path.c_str()); + pb.Write(mps_path.c_str()); } logs.info() << "Launching resolution..."; diff --git a/src/solver/modeler/ortoolsImpl/include/antares/solver/modeler/ortoolsImpl/linearProblem.h b/src/solver/modeler/ortoolsImpl/include/antares/solver/modeler/ortoolsImpl/linearProblem.h index 3d69ee98e9..4cf5b72e90 100644 --- a/src/solver/modeler/ortoolsImpl/include/antares/solver/modeler/ortoolsImpl/linearProblem.h +++ b/src/solver/modeler/ortoolsImpl/include/antares/solver/modeler/ortoolsImpl/linearProblem.h @@ -65,6 +65,7 @@ class OrtoolsLinearProblem: public Api::ILinearProblem bool isMaximization() const override; OrtoolsMipSolution* solve(bool verboseSolver) override; + void Write(const std::string& filename) override; double infinity() const override; diff --git a/src/solver/modeler/ortoolsImpl/linearProblem.cpp b/src/solver/modeler/ortoolsImpl/linearProblem.cpp index feba47dda8..df07989c29 100644 --- a/src/solver/modeler/ortoolsImpl/linearProblem.cpp +++ b/src/solver/modeler/ortoolsImpl/linearProblem.cpp @@ -165,6 +165,11 @@ bool OrtoolsLinearProblem::isMaximization() const return objective_->maximization(); } +void OrtoolsLinearProblem::Write(const std::string& filename) +{ + mpSolver_->Write(filename); +} + MPSolver* OrtoolsLinearProblem::MpSolver() const { return mpSolver_;