Antares Simulator
Power System Simulator
ortools_utils.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 #pragma once
22 
23 #include <map>
24 #include <string>
25 
26 #include <antares/writer/i_writer.h>
27 
28 // ignore unused parameters warnings from ortools
29 #pragma GCC diagnostic push
30 #pragma GCC diagnostic ignored "-Wunused-parameter"
31 #include "ortools/linear_solver/linear_solver.h"
32 #pragma GCC diagnostic pop
33 
34 #include "ortools_wrapper.h"
35 
36 namespace operations_research::math_opt
37 {
38 enum class SolverType;
39 }
40 
41 using namespace operations_research;
42 
43 // TODO use Objective().Value() instead
44 // This is a temporary workaround for Windows
45 double getObjectiveValue(const MPSolver* solver);
46 
47 void ORTOOLS_EcrireJeuDeDonneesLineaireAuFormatMPS(MPSolver* solver,
49  const std::string& filename);
50 
56 std::string toString(const std::list<std::string>& solverList);
57 
63 std::list<std::string> availableLinearSolversList();
64 
70 std::list<std::string> availableQuadraticSolversList();
71 
75 bool isLinearSolverAvailable(const std::string& solverName);
76 
82 MPSolver* MPSolverFactory(const bool isMip, const std::string& solverName);
83 
84 std::string generateTempPath(const std::string& filename);
85 void removeTemporaryFile(const std::string& tmpPath);
86 
87 class OrtoolsUtils final
88 {
89 public:
90  struct SolverNames
91  {
92  std::optional<std::string> LPSolverName, MIPSolverName;
93  };
94 
95  static const std::map<std::string, SolverNames> mpSolverMap;
96  static const std::map<std::string, math_opt::SolverType> mathoptSolverMap;
97 };
Definition: i_writer.h:32
Definition: ortools_utils.h:88
Definition: ortools_utils.h:91