ROL
ROL::ConicApproximationModel< Real > Class Template Reference

#include <ROL_ConicApproximationModel.hpp>

Inheritance diagram for ROL::ConicApproximationModel< Real >:

Public Member Functions

virtual ~ConicApproximationModel ()
 ConicApproximationModel (const Ptr< Obj > &obj, const Ptr< const V > &x, const Ptr< V > &s, const Ptr< const V > &a)
virtual void update (const V &s, bool flag=true, int iter=-1) override
virtual Real value (const V &s, Real &tol) override
virtual void gradient (V &g, const V &s, Real &tol) override
virtual void hessVec (V &hv, const V &v, const V &s, Real &tol) override
virtual void invHessVec (V &hv, const V &v, const V &s, Real &tol) override
virtual void precond (V &Pv, const V &v, const V &s, Real &tol) override
virtual ~ConicApproximationModel ()
 ConicApproximationModel (const Ptr< Obj > &obj, const Ptr< const V > &x, const Ptr< V > &s, const Ptr< const V > &a)
virtual void update (const V &s, bool flag=true, int iter=-1) override
virtual Real value (const V &s, Real &tol) override
virtual void gradient (V &g, const V &s, Real &tol) override
virtual void hessVec (V &hv, const V &v, const V &s, Real &tol) override
virtual void invHessVec (V &hv, const V &v, const V &s, Real &tol) override
virtual void precond (V &Pv, const V &v, const V &s, Real &tol) override
Public Member Functions inherited from ROL::ROL::Objective< Real >
virtual ~Objective ()
 Objective ()
virtual void update (const Vector< Real > &x, UpdateType type, int iter=-1)
 Update objective function.
virtual void update (const Vector< Real > &x, bool flag=true, int iter=-1)
 Update objective function.
virtual Real value (const Vector< Real > &x, Real &tol)=0
 Compute value.
virtual void gradient (Vector< Real > &g, const Vector< Real > &x, Real &tol)
 Compute gradient.
virtual Real dirDeriv (const Vector< Real > &x, const Vector< Real > &d, Real &tol)
 Compute directional derivative.
virtual void hessVec (Vector< Real > &hv, const Vector< Real > &v, const Vector< Real > &x, Real &tol)
 Apply Hessian approximation to vector.
virtual void invHessVec (Vector< Real > &hv, const Vector< Real > &v, const Vector< Real > &x, Real &tol)
 Apply inverse Hessian approximation to vector.
virtual void precond (Vector< Real > &Pv, const Vector< Real > &v, const Vector< Real > &x, Real &tol)
 Apply preconditioner to vector.
virtual void prox (Vector< Real > &Pv, const Vector< Real > &v, Real t, Real &tol)
 Compute the proximity operator.
virtual void proxJacVec (Vector< Real > &Jv, const Vector< Real > &v, const Vector< Real > &x, Real t, Real &tol)
 Apply the Jacobian of the proximity operator.
virtual std::vector< std::vector< Real > > checkGradient (const Vector< Real > &x, const Vector< Real > &d, const bool printToStream=true, std::ostream &outStream=std::cout, const int numSteps=ROL_NUM_CHECKDERIV_STEPS, const int order=1)
 Finite-difference gradient check.
virtual std::vector< std::vector< Real > > checkGradient (const Vector< Real > &x, const Vector< Real > &g, const Vector< Real > &d, const bool printToStream=true, std::ostream &outStream=std::cout, const int numSteps=ROL_NUM_CHECKDERIV_STEPS, const int order=1)
 Finite-difference gradient check.
virtual std::vector< std::vector< Real > > checkGradient (const Vector< Real > &x, const Vector< Real > &d, const std::vector< Real > &steps, const bool printToStream=true, std::ostream &outStream=std::cout, const int order=1)
 Finite-difference gradient check with specified step sizes.
virtual std::vector< std::vector< Real > > checkGradient (const Vector< Real > &x, const Vector< Real > &g, const Vector< Real > &d, const std::vector< Real > &steps, const bool printToStream=true, std::ostream &outStream=std::cout, const int order=1)
 Finite-difference gradient check with specified step sizes.
virtual std::vector< std::vector< Real > > checkHessVec (const Vector< Real > &x, const Vector< Real > &v, const bool printToStream=true, std::ostream &outStream=std::cout, const int numSteps=ROL_NUM_CHECKDERIV_STEPS, const int order=1)
 Finite-difference Hessian-applied-to-vector check.
virtual std::vector< std::vector< Real > > checkHessVec (const Vector< Real > &x, const Vector< Real > &hv, const Vector< Real > &v, const bool printToStream=true, std::ostream &outStream=std::cout, const int numSteps=ROL_NUM_CHECKDERIV_STEPS, const int order=1)
 Finite-difference Hessian-applied-to-vector check.
virtual std::vector< std::vector< Real > > checkHessVec (const Vector< Real > &x, const Vector< Real > &v, const std::vector< Real > &steps, const bool printToStream=true, std::ostream &outStream=std::cout, const int order=1)
 Finite-difference Hessian-applied-to-vector check with specified step sizes.
virtual std::vector< std::vector< Real > > checkHessVec (const Vector< Real > &x, const Vector< Real > &hv, const Vector< Real > &v, const std::vector< Real > &steps, const bool printToStream=true, std::ostream &outStream=std::cout, const int order=1)
 Finite-difference Hessian-applied-to-vector check with specified step sizes.
virtual std::vector< Real > checkHessSym (const Vector< Real > &x, const Vector< Real > &v, const Vector< Real > &w, const bool printToStream=true, std::ostream &outStream=std::cout)
 Hessian symmetry check.
virtual std::vector< Real > checkHessSym (const Vector< Real > &x, const Vector< Real > &hv, const Vector< Real > &v, const Vector< Real > &w, const bool printToStream=true, std::ostream &outStream=std::cout)
 Hessian symmetry check.
virtual std::vector< std::vector< Real > > checkProxJacVec (const Vector< Real > &x, const Vector< Real > &v, Real t=Real(1), bool printToStream=true, std::ostream &outStream=std::cout, int numSteps=ROL_NUM_CHECKDERIV_STEPS)
 Finite-difference proximity operator Jacobian-applied-to-vector check.
virtual void setParameter (const std::vector< Real > &param)

Private Types

using V = Vector<Real>
using Obj = Objective<Real>
using V = Vector<Real>
using Obj = Objective<Real>

Private Attributes

Ptr< Objobj_
const Ptr< const Vx_
const Ptr< const Va_
Ptr< Vg_
Ptr< Vs_
Ptr< VHs_
Real f_
Real gamma_
Real sHs_
VectorWorkspace< Real > workspace_

Additional Inherited Members

Protected Member Functions inherited from ROL::ROL::Objective< Real >
const std::vector< Real > getParameter (void) const

Detailed Description

template<class Real>
class ROL::ConicApproximationModel< Real >

Definition at line 32 of file algorithm/TypeU/trustregion/other/ROL_ConicApproximationModel.hpp.

Member Typedef Documentation

◆ V [1/2]

template<class Real>
using ROL::ConicApproximationModel< Real >::V = Vector<Real>
private

◆ Obj [1/2]

template<class Real>
using ROL::ConicApproximationModel< Real >::Obj = Objective<Real>
private

◆ V [2/2]

template<class Real>
using ROL::ConicApproximationModel< Real >::V = Vector<Real>
private

◆ Obj [2/2]

template<class Real>
using ROL::ConicApproximationModel< Real >::Obj = Objective<Real>
private

Constructor & Destructor Documentation

◆ ~ConicApproximationModel() [1/2]

template<class Real>
virtual ROL::ConicApproximationModel< Real >::~ConicApproximationModel ( )
inlinevirtual

◆ ConicApproximationModel() [1/2]

template<class Real>
ROL::ConicApproximationModel< Real >::ConicApproximationModel ( const Ptr< Obj > & obj,
const Ptr< const V > & x,
const Ptr< V > & s,
const Ptr< const V > & a )
inline

◆ ~ConicApproximationModel() [2/2]

template<class Real>
virtual ROL::ConicApproximationModel< Real >::~ConicApproximationModel ( )
inlinevirtual

◆ ConicApproximationModel() [2/2]

template<class Real>
ROL::ConicApproximationModel< Real >::ConicApproximationModel ( const Ptr< Obj > & obj,
const Ptr< const V > & x,
const Ptr< V > & s,
const Ptr< const V > & a )
inline

Definition at line 49 of file step/trustregion/ROL_ConicApproximationModel.hpp.

References a_, f_, g_, gamma_, Hs_, obj_, ROL::ROL_EPSILON(), s_, and x_.

Member Function Documentation

◆ update() [1/2]

template<class Real>
virtual void ROL::ConicApproximationModel< Real >::update ( const V & s,
bool flag = true,
int iter = -1 )
inlineoverridevirtual

◆ value() [1/2]

template<class Real>
virtual Real ROL::ConicApproximationModel< Real >::value ( const V & s,
Real & tol )
inlineoverridevirtual

Definition at line 67 of file algorithm/TypeU/trustregion/other/ROL_ConicApproximationModel.hpp.

References f_, g_, gamma_, s_, and sHs_.

◆ gradient() [1/2]

template<class Real>
virtual void ROL::ConicApproximationModel< Real >::gradient ( V & g,
const V & s,
Real & tol )
inlineoverridevirtual

◆ hessVec() [1/2]

template<class Real>
virtual void ROL::ConicApproximationModel< Real >::hessVec ( V & hv,
const V & v,
const V & s,
Real & tol )
inlineoverridevirtual

◆ invHessVec() [1/2]

template<class Real>
virtual void ROL::ConicApproximationModel< Real >::invHessVec ( V & hv,
const V & v,
const V & s,
Real & tol )
inlineoverridevirtual

◆ precond() [1/2]

template<class Real>
virtual void ROL::ConicApproximationModel< Real >::precond ( V & Pv,
const V & v,
const V & s,
Real & tol )
inlineoverridevirtual

◆ update() [2/2]

template<class Real>
virtual void ROL::ConicApproximationModel< Real >::update ( const V & s,
bool flag = true,
int iter = -1 )
inlineoverridevirtual

Definition at line 60 of file step/trustregion/ROL_ConicApproximationModel.hpp.

References a_, gamma_, Hs_, obj_, ROL::ROL_EPSILON(), s_, and x_.

◆ value() [2/2]

template<class Real>
virtual Real ROL::ConicApproximationModel< Real >::value ( const V & s,
Real & tol )
inlineoverridevirtual

Definition at line 67 of file step/trustregion/ROL_ConicApproximationModel.hpp.

References f_, g_, gamma_, s_, and sHs_.

◆ gradient() [2/2]

template<class Real>
virtual void ROL::ConicApproximationModel< Real >::gradient ( V & g,
const V & s,
Real & tol )
inlineoverridevirtual

◆ hessVec() [2/2]

template<class Real>
virtual void ROL::ConicApproximationModel< Real >::hessVec ( V & hv,
const V & v,
const V & s,
Real & tol )
inlineoverridevirtual

◆ invHessVec() [2/2]

template<class Real>
virtual void ROL::ConicApproximationModel< Real >::invHessVec ( V & hv,
const V & v,
const V & s,
Real & tol )
inlineoverridevirtual

◆ precond() [2/2]

template<class Real>
virtual void ROL::ConicApproximationModel< Real >::precond ( V & Pv,
const V & v,
const V & s,
Real & tol )
inlineoverridevirtual

Member Data Documentation

◆ obj_

template<class Real>
Ptr< Obj > ConicApproximationModel::obj_
private

◆ x_

template<class Real>
const Ptr< const V > ConicApproximationModel::x_
private

◆ a_

template<class Real>
const Ptr< const V > ConicApproximationModel::a_
private

◆ g_

template<class Real>
Ptr< V > ConicApproximationModel::g_
private

◆ s_

template<class Real>
Ptr< V > ConicApproximationModel::s_
private

◆ Hs_

template<class Real>
Ptr< V > ConicApproximationModel::Hs_
private

◆ f_

template<class Real>
Real ConicApproximationModel::f_
private

◆ gamma_

template<class Real>
Real ConicApproximationModel::gamma_
private

◆ sHs_

template<class Real>
Real ConicApproximationModel::sHs_
private

◆ workspace_

template<class Real>
VectorWorkspace< Real > ConicApproximationModel::workspace_
private

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