Public Member Functions | Private Member Functions | Private Attributes

Ipopt::SchurDriver Class Reference

#include <AsSchurDriver.hpp>

Inheritance diagram for Ipopt::SchurDriver:
Ipopt::AlgorithmStrategyObject Ipopt::ReferencedObject Ipopt::DenseGenSchurDriver Ipopt::IFTSchurDriver

List of all members.

Public Member Functions

 SchurDriver (SmartPtr< PCalculator > pcalc, SmartPtr< SchurData > data_B)
 This class is the interface for any class that deals with the Schur matrix from the point when it is constructed by the PCalculator to the solution against one vector.
virtual ~SchurDriver ()
virtual bool InitializeImpl (const OptionsList &options, const std::string &prefix)
 Overloaded from AlgorithmStrategyObject.
virtual SmartPtr< const SchurDatadata_A () const
 Const accessor methods to the SchurData for for the derived classes.
virtual SmartPtr< const SchurDatadata_B () const
virtual SmartPtr< SchurDatadata_A_nonconst ()
virtual SmartPtr< SchurDatadata_B_nonconst ()
virtual SmartPtr< const
PCalculator
pcalc () const
virtual SmartPtr< PCalculatorpcalc_nonconst ()
virtual bool SchurBuild ()=0
 Sets the Data for which this SchurMatrix will be built.
virtual bool SchurFactorize ()=0
 Calls the factorization routine for the SchurMatrix.
virtual bool SchurSolve (SmartPtr< IteratesVector > lhs, SmartPtr< const IteratesVector > rhs, SmartPtr< IteratesVector > sol, SmartPtr< Vector > delta_u)=0
 Performs a backsolve on S and K.
virtual bool SchurSolve (SmartPtr< IteratesVector > lhs, SmartPtr< const IteratesVector > rhs, SmartPtr< Vector > delta_u)=0
 Performs a backsolve on S and K; calls the latter with sol=K^(-1)*r_s=0.

Private Member Functions

 SchurDriver ()

Private Attributes

SmartPtr< PCalculatorpcalc_
SmartPtr< SchurDatadata_B_

Detailed Description

Definition at line 18 of file AsSchurDriver.hpp.


Constructor & Destructor Documentation

Ipopt::SchurDriver::SchurDriver ( SmartPtr< PCalculator pcalc,
SmartPtr< SchurData data_B 
) [inline]

This class is the interface for any class that deals with the Schur matrix from the point when it is constructed by the PCalculator to the solution against one vector.

Specific implementations may also incorporate the treatment of adding rows/cols (like QPSchur).

The computations done by this class are 1. Solve $S = r_s 2. Solve $K s = ... - nu (really?)

Definition at line 31 of file AsSchurDriver.hpp.

virtual Ipopt::SchurDriver::~SchurDriver (  )  [inline, virtual]

Definition at line 39 of file AsSchurDriver.hpp.

Ipopt::SchurDriver::SchurDriver (  )  [inline, private]

Definition at line 101 of file AsSchurDriver.hpp.


Member Function Documentation

virtual bool Ipopt::SchurDriver::InitializeImpl ( const OptionsList options,
const std::string &  prefix 
) [inline, virtual]

Overloaded from AlgorithmStrategyObject.

Implements Ipopt::AlgorithmStrategyObject.

Definition at line 44 of file AsSchurDriver.hpp.

virtual SmartPtr<const SchurData> Ipopt::SchurDriver::data_A (  )  const [inline, virtual]

Const accessor methods to the SchurData for for the derived classes.

Definition at line 51 of file AsSchurDriver.hpp.

virtual SmartPtr<const SchurData> Ipopt::SchurDriver::data_B (  )  const [inline, virtual]

Definition at line 56 of file AsSchurDriver.hpp.

virtual SmartPtr<SchurData> Ipopt::SchurDriver::data_A_nonconst (  )  [inline, virtual]

Definition at line 61 of file AsSchurDriver.hpp.

virtual SmartPtr<SchurData> Ipopt::SchurDriver::data_B_nonconst (  )  [inline, virtual]

Definition at line 66 of file AsSchurDriver.hpp.

virtual SmartPtr<const PCalculator> Ipopt::SchurDriver::pcalc (  )  const [inline, virtual]

Definition at line 71 of file AsSchurDriver.hpp.

virtual SmartPtr<PCalculator> Ipopt::SchurDriver::pcalc_nonconst (  )  [inline, virtual]

Definition at line 76 of file AsSchurDriver.hpp.

virtual bool Ipopt::SchurDriver::SchurBuild (  )  [pure virtual]

Sets the Data for which this SchurMatrix will be built.

Creates the SchurMatrix from B and P

Implemented in Ipopt::DenseGenSchurDriver, and Ipopt::IFTSchurDriver.

virtual bool Ipopt::SchurDriver::SchurFactorize (  )  [pure virtual]

Calls the factorization routine for the SchurMatrix.

Implemented in Ipopt::DenseGenSchurDriver, and Ipopt::IFTSchurDriver.

virtual bool Ipopt::SchurDriver::SchurSolve ( SmartPtr< IteratesVector lhs,
SmartPtr< const IteratesVector rhs,
SmartPtr< IteratesVector sol,
SmartPtr< Vector delta_u 
) [pure virtual]

Performs a backsolve on S and K.

Implemented in Ipopt::DenseGenSchurDriver, and Ipopt::IFTSchurDriver.

virtual bool Ipopt::SchurDriver::SchurSolve ( SmartPtr< IteratesVector lhs,
SmartPtr< const IteratesVector rhs,
SmartPtr< Vector delta_u 
) [pure virtual]

Performs a backsolve on S and K; calls the latter with sol=K^(-1)*r_s=0.

Implemented in Ipopt::DenseGenSchurDriver, and Ipopt::IFTSchurDriver.


Member Data Documentation

Definition at line 105 of file AsSchurDriver.hpp.

Definition at line 107 of file AsSchurDriver.hpp.


The documentation for this class was generated from the following file: