Ipopt::SchurDriver Class Reference

#include <AsSchurDriver.hpp>

Inheritance diagram for Ipopt::SchurDriver:

Inheritance graph
[legend]
Collaboration diagram for Ipopt::SchurDriver:

Collaboration graph
[legend]
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 PCalculatorpcalc () const
virtual SmartPtr< PCalculatorpcalc_nonconst ()
virtual bool SchurBuild ()=0
 Creates the SchurMatrix from B and P.
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.

References pcalc_.

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

Definition at line 56 of file AsSchurDriver.hpp.

References Ipopt::ConstPtr(), and data_B_.

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

Definition at line 61 of file AsSchurDriver.hpp.

References pcalc_.

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

Definition at line 66 of file AsSchurDriver.hpp.

References data_B_.

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

Definition at line 71 of file AsSchurDriver.hpp.

References Ipopt::ConstPtr(), and pcalc_.

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

Definition at line 76 of file AsSchurDriver.hpp.

References pcalc_.

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

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

SmartPtr<PCalculator> Ipopt::SchurDriver::pcalc_ [private]

Definition at line 105 of file AsSchurDriver.hpp.

Referenced by data_A(), data_A_nonconst(), pcalc(), and pcalc_nonconst().

SmartPtr<SchurData> Ipopt::SchurDriver::data_B_ [private]

Definition at line 107 of file AsSchurDriver.hpp.

Referenced by data_B(), and data_B_nonconst().


The documentation for this class was generated from the following file:
Generated on Sun Nov 28 03:04:23 2010 by  doxygen 1.4.7