MFEM
v4.3.0
Finite element discretization library
|
#include <solvers.hpp>
Public Member Functions | |
OptimizationProblem (int insize, const Operator *C_, const Operator *D_) | |
In parallel, insize is the number of the local true dofs. More... | |
virtual double | CalcObjective (const Vector &x) const =0 |
Objective F(x). In parallel, the result should be reduced over tasks. More... | |
virtual void | CalcObjectiveGrad (const Vector &x, Vector &grad) const |
The result grad is expected to enter with the correct size. More... | |
void | SetEqualityConstraint (const Vector &c) |
void | SetInequalityConstraint (const Vector &dl, const Vector &dh) |
void | SetSolutionBounds (const Vector &xl, const Vector &xh) |
const Operator * | GetC () const |
const Operator * | GetD () const |
const Vector * | GetEqualityVec () const |
const Vector * | GetInequalityVec_Lo () const |
const Vector * | GetInequalityVec_Hi () const |
const Vector * | GetBoundsVec_Lo () const |
const Vector * | GetBoundsVec_Hi () const |
int | GetNumConstraints () const |
Public Attributes | |
const int | input_size |
Protected Attributes | |
const Operator * | C |
Not owned, some can remain unused (NULL). More... | |
const Operator * | D |
const Vector * | c_e |
const Vector * | d_lo |
const Vector * | d_hi |
const Vector * | x_lo |
const Vector * | x_hi |
Defines operators and constraints for the following optimization problem:
Find x that minimizes the objective function F(x), subject to C(x) = c_e, d_lo <= D(x) <= d_hi, x_lo <= x <= x_hi.
The operators F, C, D must take input of the same size (same width). Gradients of F, C, D might be needed, depending on the OptimizationSolver. When used with Hiop, gradients of C and D must be DenseMatrices. F always returns a scalar value, see CalcObjective(), CalcObjectiveGrad(). C and D can have arbitrary heights. C and D can be NULL, meaning that their constraints are not used.
When used in parallel, all Vectors are assumed to be true dof vectors, and the operators are expected to be defined for tdof vectors.
Definition at line 599 of file solvers.hpp.
mfem::OptimizationProblem::OptimizationProblem | ( | int | insize, |
const Operator * | C_, | ||
const Operator * | D_ | ||
) |
In parallel, insize is the number of the local true dofs.
Definition at line 2111 of file solvers.cpp.
|
pure virtual |
Objective F(x). In parallel, the result should be reduced over tasks.
|
inlinevirtual |
The result grad is expected to enter with the correct size.
Definition at line 615 of file solvers.hpp.
|
inline |
Definition at line 628 of file solvers.hpp.
|
inline |
Definition at line 627 of file solvers.hpp.
|
inline |
Definition at line 622 of file solvers.hpp.
|
inline |
Definition at line 623 of file solvers.hpp.
|
inline |
Definition at line 624 of file solvers.hpp.
|
inline |
Definition at line 626 of file solvers.hpp.
|
inline |
Definition at line 625 of file solvers.hpp.
int mfem::OptimizationProblem::GetNumConstraints | ( | ) | const |
Definition at line 2147 of file solvers.cpp.
void mfem::OptimizationProblem::SetEqualityConstraint | ( | const Vector & | c | ) |
Definition at line 2121 of file solvers.cpp.
Definition at line 2129 of file solvers.cpp.
Definition at line 2139 of file solvers.cpp.
|
protected |
Not owned, some can remain unused (NULL).
Definition at line 603 of file solvers.hpp.
|
protected |
Definition at line 604 of file solvers.hpp.
|
protected |
Definition at line 603 of file solvers.hpp.
|
protected |
Definition at line 604 of file solvers.hpp.
|
protected |
Definition at line 604 of file solvers.hpp.
const int mfem::OptimizationProblem::input_size |
Definition at line 607 of file solvers.hpp.
|
protected |
Definition at line 604 of file solvers.hpp.
|
protected |
Definition at line 604 of file solvers.hpp.