|
ROL
|
Defines the linear algebra or vector space interface for simulation-based optimization. More...
#include <ROL_Vector_SimOpt.hpp>
Public Member Functions | |
| Vector_SimOpt (const ROL::Ptr< Vector< Real > > &vec1, const ROL::Ptr< Vector< Real > > &vec2) | |
| void | plus (const Vector< Real > &x) |
| void | scale (const Real alpha) |
| Compute \(y \leftarrow \alpha y\) where \(y = \mathtt{*this}\). | |
| void | axpy (const Real alpha, const Vector< Real > &x) |
| Real | dot (const Vector< Real > &x) const |
| Real | norm () const |
| Returns \( \| y \| \) where \(y = \mathtt{*this}\). | |
| ROL::Ptr< Vector< Real > > | clone () const |
| Clone to make a new (uninitialized) vector. | |
| const Vector< Real > & | dual (void) const |
| Return dual representation of \(\mathtt{*this}\), for example, the result of applying a Riesz map, or change of basis, or change of memory layout. | |
| Real | apply (const Vector< Real > &x) const |
| ROL::Ptr< Vector< Real > > | basis (const int i) const |
| Return i-th basis vector. | |
| void | applyUnary (const Elementwise::UnaryFunction< Real > &f) |
| void | applyBinary (const Elementwise::BinaryFunction< Real > &f, const Vector< Real > &x) |
| Real | reduce (const Elementwise::ReductionOp< Real > &r) const |
| void | setScalar (const Real C) |
| Set \(y \leftarrow C\) where \(C\in\mathbb{R}\). | |
| void | randomize (const Real l=0.0, const Real u=1.0) |
| Set vector to be uniform random between [l,u]. | |
| int | dimension () const |
| Return dimension of the vector space. | |
| ROL::Ptr< const Vector< Real > > | get_1 () const |
| ROL::Ptr< const Vector< Real > > | get_2 () const |
| ROL::Ptr< Vector< Real > > | get_1 () |
| ROL::Ptr< Vector< Real > > | get_2 () |
| void | set_1 (const Vector< Real > &vec) |
| void | set_2 (const Vector< Real > &vec) |
| void | print (std::ostream &outStream) const |
| Public Member Functions inherited from ROL::ROL::Vector< Real > | |
| virtual | ~Vector () |
| virtual void | plus (const Vector &x)=0 |
| Compute \(y \leftarrow y + x\), where \(y = \mathtt{*this}\). | |
| virtual Real | dot (const Vector &x) const =0 |
| Compute \( \langle y,x \rangle \) where \(y = \mathtt{*this}\). | |
| virtual void | axpy (const Real alpha, const Vector &x) |
| Compute \(y \leftarrow \alpha x + y\) where \(y = \mathtt{*this}\). | |
| virtual void | zero () |
| Set to zero vector. | |
| virtual void | set (const Vector &x) |
| Set \(y \leftarrow x\) where \(y = \mathtt{*this}\). | |
| virtual Real | apply (const Vector< Real > &x) const |
| Apply \(\mathtt{*this}\) to a dual vector. This is equivalent to the call \(\mathtt{this->dot(x.dual())}\). | |
| virtual void | applyBinary (const Elementwise::BinaryFunction< Real > &f, const Vector &x) |
| virtual std::vector< Real > | checkVector (const Vector< Real > &x, const Vector< Real > &y, const bool printToStream=true, std::ostream &outStream=std::cout) const |
| Verify vector-space methods. | |
Private Attributes | |
| ROL::Ptr< Vector< Real > > | vec1_ |
| ROL::Ptr< Vector< Real > > | vec2_ |
| ROL::Ptr< Vector< Real > > | dual_vec1_ |
| ROL::Ptr< Vector< Real > > | dual_vec2_ |
| ROL::Ptr< Vector_SimOpt< Real > > | dual_vec_ |
Defines the linear algebra or vector space interface for simulation-based optimization.
Definition at line 23 of file ROL_Vector_SimOpt.hpp.
|
inline |
Definition at line 32 of file ROL_Vector_SimOpt.hpp.
References clone(), dual_vec1_, dual_vec2_, vec1_, and vec2_.
Referenced by apply(), applyBinary(), axpy(), dot(), and plus().
|
inline |
Definition at line 38 of file ROL_Vector_SimOpt.hpp.
References get_1(), get_2(), vec1_, vec2_, and Vector_SimOpt().
Referenced by ROL::Constraint_SimOpt< Real >::applyAdjointHessian().
|
inlinevirtual |
Compute \(y \leftarrow \alpha y\) where \(y = \mathtt{*this}\).
@param[in] alpha is the scaling of \f$\mathtt{*this}\f$.
On return \f$\mathtt{*this} = \alpha (\mathtt{*this}) \f$.
---
Implements ROL::ROL::Vector< Real >.
Definition at line 45 of file ROL_Vector_SimOpt.hpp.
Referenced by ROL::SimulatedConstraint< Real >::applyAdjointHessian(), ROL::SimulatedConstraint< Real >::applyAdjointJacobian(), ROL::SimulatedObjective< Real >::gradient(), ROL::SimulatedObjectiveCVaR< Real >::gradient(), and ROL::SimulatedObjective< Real >::hessVec().
|
inline |
Definition at line 50 of file ROL_Vector_SimOpt.hpp.
References get_1(), get_2(), vec1_, vec2_, and Vector_SimOpt().
|
inline |
Definition at line 57 of file ROL_Vector_SimOpt.hpp.
References get_1(), get_2(), vec1_, vec2_, and Vector_SimOpt().
|
inlinevirtual |
Returns \( \| y \| \) where \(y = \mathtt{*this}\).
@return A nonnegative number equal to the norm of \f$\mathtt{*this}\f$.
---
Implements ROL::ROL::Vector< Real >.
Definition at line 63 of file ROL_Vector_SimOpt.hpp.
Referenced by main().
|
inlinevirtual |
Clone to make a new (uninitialized) vector.
@return A reference-counted pointer to the cloned vector. Provides the means of allocating temporary memory in ROL. ---
Implements ROL::ROL::Vector< Real >.
Definition at line 69 of file ROL_Vector_SimOpt.hpp.
Referenced by ROL::Constraint_SimOpt< Real >::applyAdjointHessian(), ROL::Constraint_SimOpt< Real >::applyAdjointJacobian(), ROL::Constraint_SimOpt< Real >::applyPreconditioner(), basis(), main(), and Vector_SimOpt().
|
inlinevirtual |
Return dual representation of \(\mathtt{*this}\), for example, the result of applying a Riesz map, or change of basis, or change of memory layout.
By default, returns the current object. Please overload if you need a dual representation.
Reimplemented from ROL::ROL::Vector< Real >.
Definition at line 73 of file ROL_Vector_SimOpt.hpp.
References dual_vec1_, dual_vec2_, dual_vec_, vec1_, and vec2_.
Referenced by ROL::Constraint_SimOpt< Real >::applyPreconditioner().
|
inline |
Definition at line 80 of file ROL_Vector_SimOpt.hpp.
References get_1(), get_2(), vec1_, vec2_, and Vector_SimOpt().
|
inlinevirtual |
Return i-th basis vector.
@param[in] i is the index of the basis function. @return A reference-counted pointer to the basis vector with index @b i. Overloading the basis is only required if the default gradient implementation is used, which computes a finite-difference approximation. ---
Reimplemented from ROL::ROL::Vector< Real >.
Definition at line 86 of file ROL_Vector_SimOpt.hpp.
References basis(), clone(), dimension(), vec1_, and vec2_.
Referenced by basis().
|
inlinevirtual |
Reimplemented from ROL::ROL::Vector< Real >.
Definition at line 102 of file ROL_Vector_SimOpt.hpp.
Referenced by main().
|
inline |
Definition at line 109 of file ROL_Vector_SimOpt.hpp.
References get_1(), get_2(), vec1_, vec2_, and Vector_SimOpt().
|
inlinevirtual |
Reimplemented from ROL::ROL::Vector< Real >.
Definition at line 117 of file ROL_Vector_SimOpt.hpp.
|
inlinevirtual |
Set \(y \leftarrow C\) where \(C\in\mathbb{R}\).
@param[in] C is a scalar.
On return \f$\mathtt{*this} = C\f$.
Uses #applyUnary methods for the computation.
Please overload if a more efficient implementation is needed.
---
Reimplemented from ROL::ROL::Vector< Real >.
Definition at line 125 of file ROL_Vector_SimOpt.hpp.
|
inlinevirtual |
Set vector to be uniform random between [l,u].
@param[in] l is a the lower bound.
@param[in] u is a the upper bound.
On return the components of \f$\mathtt{*this}\f$ are uniform
random numbers on the interval \f$[l,u]\f$.
The default implementation uses #applyUnary methods for the
computation. Please overload if a more efficient implementation is
needed.
---
Reimplemented from ROL::ROL::Vector< Real >.
Definition at line 130 of file ROL_Vector_SimOpt.hpp.
|
inlinevirtual |
Return dimension of the vector space.
@return The dimension of the vector space, i.e., the total number of basis vectors. Overload if the basis is overloaded. ---
Reimplemented from ROL::ROL::Vector< Real >.
Definition at line 136 of file ROL_Vector_SimOpt.hpp.
References dimension(), vec1_, and vec2_.
Referenced by basis(), and dimension().
|
inline |
Definition at line 140 of file ROL_Vector_SimOpt.hpp.
References vec1_.
Referenced by apply(), ROL::Constraint_SimOpt< Real >::applyAdjointHessian(), ROL::SimulatedConstraint< Real >::applyAdjointHessian(), ROL::Constraint_SimOpt< Real >::applyAdjointJacobian(), ROL::SimulatedConstraint< Real >::applyAdjointJacobian(), applyBinary(), ROL::BoundConstraint_SimOpt< Real >::applyInverseScalingFunction(), ROL::Constraint_SimOpt< Real >::applyJacobian(), ROL::SimulatedConstraint< Real >::applyJacobian(), ROL::Constraint_SimOpt< Real >::applyPreconditioner(), ROL::SimulatedConstraint< Real >::applyPreconditioner(), ROL::BoundConstraint_SimOpt< Real >::applyScalingFunctionJacobian(), axpy(), dot(), ROL::SimulatedObjective< Real >::gradient(), ROL::SimulatedObjectiveCVaR< Real >::gradient(), ROL::SimulatedObjective< Real >::hessVec(), ROL::BoundConstraint_SimOpt< Real >::isFeasible(), plus(), ROL::BoundConstraint_SimOpt< Real >::project(), ROL::BoundConstraint_SimOpt< Real >::projectInterior(), ROL::BoundConstraint_SimOpt< Real >::pruneActive(), ROL::BoundConstraint_SimOpt< Real >::pruneActive(), ROL::BoundConstraint_SimOpt< Real >::pruneLowerActive(), ROL::BoundConstraint_SimOpt< Real >::pruneLowerActive(), ROL::BoundConstraint_SimOpt< Real >::pruneUpperActive(), ROL::BoundConstraint_SimOpt< Real >::pruneUpperActive(), ROL::Constraint_SimOpt< Real >::update(), ROL::Constraint_SimOpt< Real >::update(), ROL::Constraint_SimOpt< Real >::value(), ROL::SimulatedObjective< Real >::value(), and ROL::SimulatedObjectiveCVaR< Real >::value().
|
inline |
Definition at line 144 of file ROL_Vector_SimOpt.hpp.
References vec2_.
Referenced by apply(), ROL::Constraint_SimOpt< Real >::applyAdjointHessian(), ROL::SimulatedConstraint< Real >::applyAdjointHessian(), ROL::Constraint_SimOpt< Real >::applyAdjointJacobian(), ROL::SimulatedConstraint< Real >::applyAdjointJacobian(), applyBinary(), ROL::BoundConstraint_SimOpt< Real >::applyInverseScalingFunction(), ROL::Constraint_SimOpt< Real >::applyJacobian(), ROL::SimulatedConstraint< Real >::applyJacobian(), ROL::Constraint_SimOpt< Real >::applyPreconditioner(), ROL::SimulatedConstraint< Real >::applyPreconditioner(), ROL::BoundConstraint_SimOpt< Real >::applyScalingFunctionJacobian(), axpy(), dot(), ROL::SimulatedObjective< Real >::gradient(), ROL::SimulatedObjectiveCVaR< Real >::gradient(), ROL::SimulatedObjective< Real >::hessVec(), ROL::BoundConstraint_SimOpt< Real >::isFeasible(), plus(), ROL::BoundConstraint_SimOpt< Real >::project(), ROL::BoundConstraint_SimOpt< Real >::projectInterior(), ROL::BoundConstraint_SimOpt< Real >::pruneActive(), ROL::BoundConstraint_SimOpt< Real >::pruneActive(), ROL::BoundConstraint_SimOpt< Real >::pruneLowerActive(), ROL::BoundConstraint_SimOpt< Real >::pruneLowerActive(), ROL::BoundConstraint_SimOpt< Real >::pruneUpperActive(), ROL::BoundConstraint_SimOpt< Real >::pruneUpperActive(), ROL::Constraint_SimOpt< Real >::update(), ROL::Constraint_SimOpt< Real >::update(), ROL::Constraint_SimOpt< Real >::value(), ROL::SimulatedObjective< Real >::value(), and ROL::SimulatedObjectiveCVaR< Real >::value().
|
inline |
Definition at line 148 of file ROL_Vector_SimOpt.hpp.
References vec1_.
|
inline |
Definition at line 152 of file ROL_Vector_SimOpt.hpp.
References vec2_.
|
inline |
Definition at line 156 of file ROL_Vector_SimOpt.hpp.
References vec1_.
Referenced by ROL::Constraint_SimOpt< Real >::applyAdjointHessian(), and ROL::Constraint_SimOpt< Real >::applyAdjointJacobian().
|
inline |
Definition at line 160 of file ROL_Vector_SimOpt.hpp.
References vec2_.
Referenced by ROL::Constraint_SimOpt< Real >::applyAdjointHessian(), and ROL::Constraint_SimOpt< Real >::applyAdjointJacobian().
|
inlinevirtual |
Reimplemented from ROL::ROL::Vector< Real >.
Definition at line 164 of file ROL_Vector_SimOpt.hpp.
|
private |
Definition at line 25 of file ROL_Vector_SimOpt.hpp.
Referenced by apply(), applyBinary(), applyUnary(), axpy(), basis(), clone(), dimension(), dot(), dual(), get_1(), get_1(), norm(), plus(), print(), randomize(), reduce(), scale(), set_1(), setScalar(), and Vector_SimOpt().
|
private |
Definition at line 26 of file ROL_Vector_SimOpt.hpp.
Referenced by apply(), applyBinary(), applyUnary(), axpy(), basis(), clone(), dimension(), dot(), dual(), get_2(), get_2(), norm(), plus(), print(), randomize(), reduce(), scale(), set_2(), setScalar(), and Vector_SimOpt().
|
mutableprivate |
Definition at line 27 of file ROL_Vector_SimOpt.hpp.
Referenced by dual(), and Vector_SimOpt().
|
mutableprivate |
Definition at line 28 of file ROL_Vector_SimOpt.hpp.
Referenced by dual(), and Vector_SimOpt().
|
mutableprivate |
Definition at line 29 of file ROL_Vector_SimOpt.hpp.
Referenced by dual().