Antares Simulator
Power System Simulator
basis_status.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 <memory>
24 
25 namespace Test
26 {
27 class BasisStatus;
28 }
29 
30 namespace operations_research
31 {
32 class MPSolver;
33 }
34 
35 namespace Antares::Optimization
36 {
37 class BasisStatusImpl;
38 
40 {
41 public:
42  // Prevent copy & move
43  BasisStatus();
44  ~BasisStatus();
45  BasisStatus(const BasisStatus&) = delete;
46  BasisStatus(BasisStatus&&) = delete;
47  BasisStatus& operator=(const BasisStatus&) = delete;
48  BasisStatus& operator=(BasisStatus&&) = delete;
49 
50  bool exists() const;
51  void setStartingBasis(operations_research::MPSolver* solver) const;
52  void extractBasis(const operations_research::MPSolver* solver);
53  void clear();
54 
55 private:
56  std::unique_ptr<BasisStatusImpl> impl;
57  friend class Test::BasisStatus; // For tests
58 };
59 } // namespace Antares::Optimization
Definition: basis_status.h:40
Definition: basis_status.cpp:35