Solver for the augmented system using GenKKTSolverInterfaces. More...
#include <IpGenAugSystemSolver.hpp>
Private Member Functions | |
bool | AugmentedSystemChanged (const SymMatrix *W, Number W_factor, const Vector *D_x, Number delta_x, const Vector *D_s, Number delta_s, const Matrix &J_c, const Vector *D_c, Number delta_c, const Matrix &J_d, const Vector *D_d, Number delta_d) |
Check the internal tags and decide if the passed variables are different from what is in the augmented_system_. | |
void | UpdateTags (const SymMatrix *W, Number W_factor, const Vector *D_x, Number delta_x, const Vector *D_s, Number delta_s, const Matrix &J_c, const Vector *D_c, Number delta_c, const Matrix &J_d, const Vector *D_d, Number delta_d) |
Default Compiler Generated Methods | |
(Hidden to avoid implicit creation/calling). These methods are not implemented and we do not want the compiler to implement them for us, so we declare them private and do not define them. This ensures that they will not be implicitly created/called. | |
GenAugSystemSolver () | |
Default constructor. | |
GenAugSystemSolver (const GenAugSystemSolver &) | |
Copy Constructor. | |
void | operator= (const GenAugSystemSolver &) |
Default Assignment Operator. | |
Private Attributes | |
SmartPtr< GenKKTSolverInterface > | solver_interface_ |
The linear solver object that is to be used to solve the linear systems. | |
Tags and values to track in order to decide whether the | |
matrix has to be updated compared to the most recent call of the Set method. | |
TaggedObject::Tag | w_tag_ |
Tag for W matrix. | |
Number | w_factor_ |
Most recent value of W_factor. | |
TaggedObject::Tag | d_x_tag_ |
Tag for D_x vector, representing the diagonal matrix D_x. | |
Number | delta_x_ |
Most recent value of delta_x from Set method. | |
TaggedObject::Tag | d_s_tag_ |
Tag for D_s vector, representing the diagonal matrix D_s. | |
Number | delta_s_ |
Most recent value of delta_s from Set method. | |
TaggedObject::Tag | j_c_tag_ |
Tag for J_c matrix. | |
TaggedObject::Tag | d_c_tag_ |
Tag for D_c vector, representing the diagonal matrix D_c. | |
Number | delta_c_ |
Most recent value of delta_c from Set method. | |
TaggedObject::Tag | j_d_tag_ |
Tag for J_d matrix. | |
TaggedObject::Tag | d_d_tag_ |
Tag for D_d vector, representing the diagonal matrix D_d. | |
Number | delta_d_ |
Most recent value of delta_d from Set method. | |
Space for storing the diagonal matrices. | |
If the matrix hasn't changed, we can use it from the last call. | |
Number * | dx_vals_copy_ |
Number * | ds_vals_copy_ |
Number * | dc_vals_copy_ |
Number * | dd_vals_copy_ |
Algorithmic parameters | |
bool | warm_start_same_structure_ |
Flag indicating whether the TNLP with identical structure has already been solved before. | |
Additional Inherited Members | |
Protected Member Functions inherited from Ipopt::AlgorithmStrategyObject | |
const Journalist & | Jnlst () const |
IpoptNLP & | IpNLP () const |
IpoptData & | IpData () const |
IpoptCalculatedQuantities & | IpCq () const |
bool | HaveIpData () const |
Solver for the augmented system using GenKKTSolverInterfaces.
This takes any Vector values out and provides Number*'s, but Matrices are provided as given from the NLP.
Definition at line 21 of file IpGenAugSystemSolver.hpp.
Ipopt::GenAugSystemSolver::GenAugSystemSolver | ( | GenKKTSolverInterface & | SolverInterface | ) |
Constructor using only a linear solver object.
|
virtual |
Destructor.
|
private |
Default constructor.
|
private |
Copy Constructor.
|
virtual |
overloaded from AlgorithmStrategyObject
Implements Ipopt::AugSystemSolver.
|
virtual |
Set up the augmented system and solve it for a set of given right hand side - implementation for GenTMatrices and SymTMatrices.
Reimplemented from Ipopt::AugSystemSolver.
Number of negative eigenvalues detected during last solve.
This must not be called if the linear solver does not compute this quantities (see ProvidesInertia).
Implements Ipopt::AugSystemSolver.
Query whether inertia is computed by linear solver.
Implements Ipopt::AugSystemSolver.
Request to increase quality of solution for next solve.
Ask underlying linear solver to increase quality of solution for the next solve (e.g. increase pivot tolerance).
Implements Ipopt::AugSystemSolver.
|
private |
Default Assignment Operator.
|
private |
Check the internal tags and decide if the passed variables are different from what is in the augmented_system_.
|
private |
|
private |
The linear solver object that is to be used to solve the linear systems.
Definition at line 155 of file IpGenAugSystemSolver.hpp.
|
private |
Tag for W matrix.
If W has been given to Set as NULL, then this tag is set to 0
Definition at line 166 of file IpGenAugSystemSolver.hpp.
|
private |
Most recent value of W_factor.
Definition at line 168 of file IpGenAugSystemSolver.hpp.
|
private |
Tag for D_x vector, representing the diagonal matrix D_x.
If D_x has been given to Set as NULL, then this tag is set to 0
Definition at line 173 of file IpGenAugSystemSolver.hpp.
|
private |
Most recent value of delta_x from Set method.
Definition at line 175 of file IpGenAugSystemSolver.hpp.
|
private |
Tag for D_s vector, representing the diagonal matrix D_s.
If D_s has been given to Set as NULL, then this tag is set to 0
Definition at line 180 of file IpGenAugSystemSolver.hpp.
|
private |
Most recent value of delta_s from Set method.
Definition at line 182 of file IpGenAugSystemSolver.hpp.
|
private |
Tag for J_c matrix.
If J_c has been given to Set as NULL, then this tag is set to 0
Definition at line 187 of file IpGenAugSystemSolver.hpp.
|
private |
Tag for D_c vector, representing the diagonal matrix D_c.
If D_c has been given to Set as NULL, then this tag is set to 0
Definition at line 192 of file IpGenAugSystemSolver.hpp.
|
private |
Most recent value of delta_c from Set method.
Definition at line 194 of file IpGenAugSystemSolver.hpp.
|
private |
Tag for J_d matrix.
If J_d has been given to Set as NULL, then this tag is set to 0
Definition at line 199 of file IpGenAugSystemSolver.hpp.
|
private |
Tag for D_d vector, representing the diagonal matrix D_d.
If D_d has been given to Set as NULL, then this tag is set to 0
Definition at line 204 of file IpGenAugSystemSolver.hpp.
|
private |
Most recent value of delta_d from Set method.
Definition at line 206 of file IpGenAugSystemSolver.hpp.
|
private |
Definition at line 214 of file IpGenAugSystemSolver.hpp.
|
private |
Definition at line 215 of file IpGenAugSystemSolver.hpp.
|
private |
Definition at line 216 of file IpGenAugSystemSolver.hpp.
|
private |
Definition at line 217 of file IpGenAugSystemSolver.hpp.
|
private |
Flag indicating whether the TNLP with identical structure has already been solved before.
Definition at line 225 of file IpGenAugSystemSolver.hpp.