Antares Simulator
Power System Simulator
mipConstraint.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 <antares/optimisation/linear-problem-api/mipConstraint.h>
25 
26 namespace operations_research
27 {
28 class MPConstraint; // forward declaration
29 }
30 
31 namespace Antares::Optimisation::LinearProblemMpsolverImpl
32 {
33 
35 {
36 public:
37  void setLb(double lb) override;
38  void setUb(double ub) override;
39 
40  void setBounds(double lb, double ub) override;
41  void setCoefficient(LinearProblemApi::IMipVariable* var, double coefficient) override;
42 
43  [[nodiscard]] double getLb() const override;
44  [[nodiscard]] double getUb() const override;
45 
46  [[nodiscard]] double getCoefficient(const LinearProblemApi::IMipVariable* var) const override;
47 
48  [[nodiscard]] double dual() const override;
49 
50  [[nodiscard]] const std::string& getName() const override;
51  LinearProblemApi::MipBasisStatus getMipBasisStatus() const override;
52  ~OrtoolsMipConstraint() override = default;
53 
54  explicit OrtoolsMipConstraint(operations_research::MPConstraint* mpConstraint);
55 
56 private:
57  operations_research::MPConstraint* mpConstraint_;
58 };
59 
60 } // namespace Antares::Optimisation::LinearProblemMpsolverImpl