Reaktoro
A unified framework for modeling chemically reactive systems
OptimumSolverIpFeasible.hpp
1 // Reaktoro is a unified framework for modeling chemically reactive systems.
2 //
3 // Copyright (C) 2014-2018 Allan Leal
4 //
5 // This library is free software; you can redistribute it and/or
6 // modify it under the terms of the GNU Lesser General Public
7 // License as published by the Free Software Foundation; either
8 // version 2.1 of the License, or (at your option) any later version.
9 //
10 // This library is distributed in the hope that it will be useful,
11 // but WITHOUT ANY WARRANTY; without even the implied warranty of
12 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 // Lesser General Public License for more details.
14 //
15 // You should have received a copy of the GNU Lesser General Public License
16 // along with this library. If not, see <http://www.gnu.org/licenses/>.
17 
18 #pragma once
19 
20 // C++ includes
21 #include <memory>
22 
23 namespace Reaktoro {
24 
25 // Forward declarations
26 struct OptimumOptions;
27 struct OptimumProblem;
28 struct OptimumState;
29 struct OptimumResult;
30 
34 {
35 public:
38 
41 
43  virtual ~OptimumSolverIpFeasible();
44 
47 
52  auto approximate(const OptimumProblem& problem, OptimumState& state) -> OptimumResult;
53 
58  auto approximate(const OptimumProblem& problem, OptimumState& state, const OptimumOptions& options) -> OptimumResult;
59 
60 private:
61  struct Impl;
62 
63  std::unique_ptr<Impl> pimpl;
64 };
65 
66 } // namespace Reaktoro
auto approximate(const OptimumProblem &problem, OptimumState &state) -> OptimumResult
Find an initial guess for an optimisation problem.
Definition: OptimumSolverIpFeasible.cpp:126
A type that describes the non-linear constrained optimisation problem.
Definition: OptimumProblem.hpp:49
auto operator=(OptimumSolverIpFeasible other) -> OptimumSolverIpFeasible &
Assign a copy of an OptimumSolverIpFeasible instance.
Definition: OptimumSolverIpFeasible.cpp:120
The namespace containing all components of the Reaktoro library.
Definition: ChemicalScalar.hpp:24
A type that describes the options of a optimisation calculation.
Definition: OptimumOptions.hpp:187
A type that describes the state of an optimum solution.
Definition: OptimumState.hpp:29
A type that describes the result of an optimisation calculation.
Definition: OptimumResult.hpp:24
virtual ~OptimumSolverIpFeasible()
Destroy this OptimumSolverIpFeasible instance.
Definition: OptimumSolverIpFeasible.cpp:117
The class that implements the IpFeasible algorithm using an interior-point method.
Definition: OptimumSolverIpFeasible.hpp:34
OptimumSolverIpFeasible()
Construct a default OptimumSolverIpFeasible instance.
Definition: OptimumSolverIpFeasible.cpp:109