Antares Simulator
Power System Simulator
Loading...
Searching...
No Matches
mipConstraint.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 <antares/optimisation/linear-problem-api/mipConstraint.h>
25
26namespace operations_research
27{
28class MPConstraint; // forward declaration
29}
30
31namespace Antares::Optimisation::LinearProblemMpsolverImpl
32{
33
35{
36public:
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 double getLb() const override;
44 double getUb() const override;
45
46 double getCoefficient(LinearProblemApi::IMipVariable* var) override;
47
48 const std::string& getName() const override;
49
50 ~OrtoolsMipConstraint() override = default;
51
52 explicit OrtoolsMipConstraint(operations_research::MPConstraint* mpConstraint);
53
54private:
55 operations_research::MPConstraint* mpConstraint_;
56};
57
58} // namespace Antares::Optimisation::LinearProblemMpsolverImpl