ROL
Public Member Functions | Private Attributes | List of all members
ROL::ProjectedNewtonStep< Real > Class Template Reference

Provides the interface to compute optimization steps with projected Newton's method using line search. More...

#include <ROL_ProjectedNewtonStep.hpp>

+ Inheritance diagram for ROL::ProjectedNewtonStep< Real >:

Public Member Functions

 ProjectedNewtonStep (ROL::ParameterList &parlist, const bool computeObj=true)
 Constructor. More...
 
void initialize (Vector< Real > &x, const Vector< Real > &s, const Vector< Real > &g, Objective< Real > &obj, BoundConstraint< Real > &bnd, AlgorithmState< Real > &algo_state)
 Initialize step with bound constraint. More...
 
void compute (Vector< Real > &s, const Vector< Real > &x, Objective< Real > &obj, BoundConstraint< Real > &bnd, AlgorithmState< Real > &algo_state)
 Compute step. More...
 
void update (Vector< Real > &x, const Vector< Real > &s, Objective< Real > &obj, BoundConstraint< Real > &bnd, AlgorithmState< Real > &algo_state)
 Update step, if successful. More...
 
std::string printHeader (void) const
 Print iterate header. More...
 
std::string printName (void) const
 Print step name. More...
 
std::string print (AlgorithmState< Real > &algo_state, bool print_header=false) const
 Print iterate status. More...
 
- Public Member Functions inherited from ROL::Step< Real >
virtual ~Step ()
 
 Step (void)
 
virtual void initialize (Vector< Real > &x, const Vector< Real > &g, Objective< Real > &obj, BoundConstraint< Real > &con, AlgorithmState< Real > &algo_state)
 Initialize step with bound constraint. More...
 
virtual void initialize (Vector< Real > &x, const Vector< Real > &g, Vector< Real > &l, const Vector< Real > &c, Objective< Real > &obj, Constraint< Real > &con, AlgorithmState< Real > &algo_state)
 Initialize step with equality constraint. More...
 
virtual void initialize (Vector< Real > &x, const Vector< Real > &g, Vector< Real > &l, const Vector< Real > &c, Objective< Real > &obj, Constraint< Real > &con, BoundConstraint< Real > &bnd, AlgorithmState< Real > &algo_state)
 Initialize step with equality constraint. More...
 
virtual void compute (Vector< Real > &s, const Vector< Real > &x, const Vector< Real > &l, Objective< Real > &obj, Constraint< Real > &con, AlgorithmState< Real > &algo_state)
 Compute step (equality constraints). More...
 
virtual void update (Vector< Real > &x, Vector< Real > &l, const Vector< Real > &s, Objective< Real > &obj, Constraint< Real > &con, AlgorithmState< Real > &algo_state)
 Update step, if successful (equality constraints). More...
 
virtual void compute (Vector< Real > &s, const Vector< Real > &x, const Vector< Real > &l, Objective< Real > &obj, Constraint< Real > &con, BoundConstraint< Real > &bnd, AlgorithmState< Real > &algo_state)
 Compute step (equality constraints). More...
 
virtual void update (Vector< Real > &x, Vector< Real > &l, const Vector< Real > &s, Objective< Real > &obj, Constraint< Real > &con, BoundConstraint< Real > &bnd, AlgorithmState< Real > &algo_state)
 Update step, if successful (equality constraints). More...
 
void initialize (OptimizationProblem< Real > &opt, AlgorithmState< Real > &algo_state)
 
void compute (Vector< Real > &s, OptimizationProblem< Real > &opt, AlgorithmState< Real > &algo_state)
 
void update (OptimizationProblem< Real > &opt, const Vector< Real > &s, AlgorithmState< Real > &algo_state)
 
const ROL::Ptr< const
StepState< Real > > 
getStepState (void) const
 Get state for step object. More...
 
void reset (const Real searchSize=1.0)
 Get state for step object. More...
 

Private Attributes

ROL::Ptr< Vector< Real > > gp_
 Additional vector storage. More...
 
ROL::Ptr< Vector< Real > > d_
 Additional vector storage. More...
 
int verbosity_
 Verbosity level. More...
 
const bool computeObj_
 
bool useProjectedGrad_
 Whether or not to use to the projected gradient criticality measure. More...
 

Additional Inherited Members

- Protected Member Functions inherited from ROL::Step< Real >
ROL::Ptr< StepState< Real > > getState (void)
 

Detailed Description

template<class Real>
class ROL::ProjectedNewtonStep< Real >

Provides the interface to compute optimization steps with projected Newton's method using line search.

Definition at line 59 of file ROL_ProjectedNewtonStep.hpp.

Constructor & Destructor Documentation

template<class Real >
ROL::ProjectedNewtonStep< Real >::ProjectedNewtonStep ( ROL::ParameterList &  parlist,
const bool  computeObj = true 
)
inline

Constructor.

Standard constructor to build a ProjectedNewtonStep object. Algorithmic specifications are passed in through a ROL::ParameterList.

Parameters
[in]parlistis a parameter list containing algorithmic specifications

Definition at line 81 of file ROL_ProjectedNewtonStep.hpp.

References ROL::ProjectedNewtonStep< Real >::useProjectedGrad_, and ROL::ProjectedNewtonStep< Real >::verbosity_.

Member Function Documentation

template<class Real >
void ROL::ProjectedNewtonStep< Real >::initialize ( Vector< Real > &  x,
const Vector< Real > &  s,
const Vector< Real > &  g,
Objective< Real > &  obj,
BoundConstraint< Real > &  con,
AlgorithmState< Real > &  algo_state 
)
inlinevirtual
template<class Real >
void ROL::ProjectedNewtonStep< Real >::compute ( Vector< Real > &  s,
const Vector< Real > &  x,
Objective< Real > &  obj,
BoundConstraint< Real > &  bnd,
AlgorithmState< Real > &  algo_state 
)
inlinevirtual
template<class Real >
void ROL::ProjectedNewtonStep< Real >::update ( Vector< Real > &  x,
const Vector< Real > &  s,
Objective< Real > &  obj,
BoundConstraint< Real > &  bnd,
AlgorithmState< Real > &  algo_state 
)
inlinevirtual
template<class Real >
std::string ROL::ProjectedNewtonStep< Real >::printHeader ( void  ) const
inlinevirtual
template<class Real >
std::string ROL::ProjectedNewtonStep< Real >::printName ( void  ) const
inlinevirtual

Print step name.

Reimplemented from ROL::Step< Real >.

Definition at line 183 of file ROL_ProjectedNewtonStep.hpp.

References ROL::DESCENT_NEWTON, and ROL::EDescentToString().

Referenced by ROL::ProjectedNewtonStep< Real >::print().

template<class Real >
std::string ROL::ProjectedNewtonStep< Real >::print ( AlgorithmState< Real > &  algo_state,
bool  printHeader = false 
) const
inlinevirtual

Member Data Documentation

template<class Real >
ROL::Ptr<Vector<Real> > ROL::ProjectedNewtonStep< Real >::gp_
private
template<class Real >
ROL::Ptr<Vector<Real> > ROL::ProjectedNewtonStep< Real >::d_
private

Additional vector storage.

Definition at line 63 of file ROL_ProjectedNewtonStep.hpp.

Referenced by ROL::ProjectedNewtonStep< Real >::initialize(), and ROL::ProjectedNewtonStep< Real >::update().

template<class Real >
int ROL::ProjectedNewtonStep< Real >::verbosity_
private
template<class Real >
const bool ROL::ProjectedNewtonStep< Real >::computeObj_
private
template<class Real >
bool ROL::ProjectedNewtonStep< Real >::useProjectedGrad_
private

Whether or not to use to the projected gradient criticality measure.

Definition at line 66 of file ROL_ProjectedNewtonStep.hpp.

Referenced by ROL::ProjectedNewtonStep< Real >::ProjectedNewtonStep(), and ROL::ProjectedNewtonStep< Real >::update().


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