|
ROL
|
Provides the std::vector implementation of the ROL::Vector interface. More...
#include <ROL_StdVector.hpp>
Inheritance diagram for ROL::StdVector< Real, Element >:Public Member Functions | |
| StdVector (const Teuchos::RCP< std::vector< Element > > &std_vec) | |
| void | set (const Vector< Real > &x) |
| Set \(y \leftarrow x\) where \(y = \mathtt{*this}\). More... | |
| void | plus (const Vector< Real > &x) |
| Compute \(y \leftarrow y + x\), where \(y = \mathtt{*this}\). More... | |
| void | axpy (const Real alpha, const Vector< Real > &x) |
| Compute \(y \leftarrow \alpha x + y\) where \(y = \mathtt{*this}\). More... | |
| void | scale (const Real alpha) |
| Compute \(y \leftarrow \alpha y\) where \(y = \mathtt{*this}\). More... | |
| virtual Real | dot (const Vector< Real > &x) const |
| Compute \( \langle y,x \rangle \) where \(y = \mathtt{*this}\). More... | |
| Real | norm () const |
| Returns \( \| y \| \) where \(y = \mathtt{*this}\). More... | |
| virtual Teuchos::RCP< Vector< Real > > | clone () const |
| Clone to make a new (uninitialized) vector. More... | |
| Teuchos::RCP< const std::vector< Element > > | getVector () const |
| Teuchos::RCP< std::vector< Element > > | getVector () |
| Teuchos::RCP< Vector< Real > > | basis (const int i) const |
| Return i-th basis vector. More... | |
| int | dimension () const |
| Return dimension of the vector space. More... | |
| 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 | print (std::ostream &outStream) const |
Public Member Functions inherited from ROL::Vector< Real > | |
| virtual | ~Vector () |
| virtual void | zero () |
| Set to zero vector. More... | |
| virtual const Vector & | dual () 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. More... | |
| 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. More... | |
Private Types | |
| typedef std::vector< Real >::size_type | uint |
Private Attributes | |
| Teuchos::RCP< std::vector< Element > > | std_vec_ |
Provides the std::vector implementation of the ROL::Vector interface.
Definition at line 60 of file ROL_StdVector.hpp.
|
private |
Definition at line 62 of file ROL_StdVector.hpp.
|
inline |
Definition at line 70 of file ROL_StdVector.hpp.
Referenced by ROL::StdVector< Real >::basis(), and ROL::StdVector< Real >::clone().
|
inlinevirtual |
Set \(y \leftarrow x\) where \(y = \mathtt{*this}\).
| [in] | x | is a vector. |
On return \(\mathtt{*this} = x\). Uses zero and plus methods for the computation. Please overload if a more efficient implementation is needed.
Reimplemented from ROL::Vector< Real >.
Definition at line 72 of file ROL_StdVector.hpp.
Referenced by main().
|
inlinevirtual |
Compute \(y \leftarrow y + x\), where \(y = \mathtt{*this}\).
| [in] | x | is the vector to be added to \(\mathtt{*this}\). |
On return \(\mathtt{*this} = \mathtt{*this} + x\).
Implements ROL::Vector< Real >.
Definition at line 83 of file ROL_StdVector.hpp.
|
inlinevirtual |
Compute \(y \leftarrow \alpha x + y\) where \(y = \mathtt{*this}\).
| [in] | alpha | is the scaling of x. |
| [in] | x | is a vector. |
On return \(\mathtt{*this} = \mathtt{*this} + \alpha x \). Uses clone, set, scale and plus for the computation. Please overload if a more efficient implementation is needed.
Reimplemented from ROL::Vector< Real >.
Definition at line 97 of file ROL_StdVector.hpp.
Referenced by main(), and ROL::ZOO::Objective_PoissonInversion< Real >::solve_adjoint_sensitivity_equation().
|
inlinevirtual |
Compute \(y \leftarrow \alpha y\) where \(y = \mathtt{*this}\).
| [in] | alpha | is the scaling of \(\mathtt{*this}\). |
On return \(\mathtt{*this} = \alpha (\mathtt{*this}) \).
Implements ROL::Vector< Real >.
Definition at line 111 of file ROL_StdVector.hpp.
Referenced by main().
|
inlinevirtual |
Compute \( \langle y,x \rangle \) where \(y = \mathtt{*this}\).
| [in] | x | is the vector that forms the dot product with \(\mathtt{*this}\). |
Implements ROL::Vector< Real >.
Reimplemented in ROL::DualAtomVector< Real >, ROL::DualProbabilityVector< Real >, ROL::DualScaledStdVector< Real, Element >, ROL::PrimalAtomVector< Real >, ROL::PrimalProbabilityVector< Real >, ROL::PrimalScaledStdVector< Real, Element >, and ROL::BatchStdVector< Real >.
Definition at line 118 of file ROL_StdVector.hpp.
Referenced by ROL::ScalarLinearEqualityConstraint< Real >::applyJacobian(), ROL::StdVector< Real >::norm(), ROL::ScalarLinearEqualityConstraint< Real >::solveAugmentedSystem(), and ROL::ScalarLinearEqualityConstraint< Real >::value().
|
inlinevirtual |
Returns \( \| y \| \) where \(y = \mathtt{*this}\).
Implements ROL::Vector< Real >.
Definition at line 134 of file ROL_StdVector.hpp.
Referenced by main().
|
inlinevirtual |
Clone to make a new (uninitialized) vector.
Provides the means of allocating temporary memory in ROL.
Implements ROL::Vector< Real >.
Reimplemented in ROL::DualAtomVector< Real >, ROL::DualProbabilityVector< Real >, ROL::DualScaledStdVector< Real, Element >, ROL::PrimalAtomVector< Real >, ROL::PrimalProbabilityVector< Real >, ROL::PrimalScaledStdVector< Real, Element >, and ROL::BatchStdVector< Real >.
Definition at line 140 of file ROL_StdVector.hpp.
Referenced by main(), and ROL::ZOO::Objective_PoissonInversion< Real >::value().
|
inline |
Definition at line 144 of file ROL_StdVector.hpp.
Referenced by TridiagonalToeplitzOperator< Real >::apply(), ROL::StdEqualityConstraint< Real >::applyAdjointHessian(), ROL::ScalarLinearEqualityConstraint< Real >::applyAdjointJacobian(), ROL::StdEqualityConstraint< Real >::applyAdjointJacobian(), ROL::StdVector< Real >::applyBinary(), TridiagonalToeplitzOperator< Real >::applyInverse(), ROL::StdEqualityConstraint< Real >::applyJacobian(), ROL::ScalarLinearEqualityConstraint< Real >::applyJacobian(), ROL::StdEqualityConstraint< Real >::applyPreconditioner(), ROL::StdVector< Real >::axpy(), ROL::BatchStdVector< Real >::clone(), ROL::PrimalScaledStdVector< Real, Element >::clone(), ROL::PrimalProbabilityVector< Real >::clone(), ROL::DualScaledStdVector< Real, Element >::clone(), ROL::DualProbabilityVector< Real >::clone(), ROL::StdObjective< Real >::dirDeriv(), ROL::BatchStdVector< Real >::dot(), ROL::PrimalScaledStdVector< Real, Element >::dot(), ROL::PrimalProbabilityVector< Real >::dot(), ROL::StdVector< Real >::dot(), ROL::PrimalAtomVector< Real >::dot(), ROL::DualScaledStdVector< Real, Element >::dot(), ROL::DualProbabilityVector< Real >::dot(), ROL::DualAtomVector< Real >::dot(), ROL::PrimalScaledStdVector< Real, Element >::dual(), ROL::PrimalProbabilityVector< Real >::dual(), ROL::PrimalAtomVector< Real >::dual(), ROL::DualScaledStdVector< Real, Element >::dual(), ROL::DualProbabilityVector< Real >::dual(), ROL::DualAtomVector< Real >::dual(), ROL::AtomVector< Real >::getAtom(), ROL::ProbabilityVector< Real >::getNumMyAtoms(), ROL::ProbabilityVector< Real >::getProbability(), ROL::StdObjective< Real >::gradient(), ROL::StdObjective< Real >::hessVec(), ROL::StdObjective< Real >::invHessVec(), ROL::StdVector< Real >::plus(), ROL::StdObjective< Real >::precond(), ROL::BatchStdVector< Real >::reduce(), ROL::StdVector< Real >::set(), ROL::AtomVector< Real >::setAtom(), ROL::ProbabilityVector< Real >::setProbability(), ROL::ScalarLinearEqualityConstraint< Real >::solveAugmentedSystem(), ROL::StdEqualityConstraint< Real >::solveAugmentedSystem(), ROL::StdObjective< Real >::update(), ROL::StdEqualityConstraint< Real >::update(), ROL::StdObjective< Real >::value(), ROL::StdEqualityConstraint< Real >::value(), and ROL::ScalarLinearEqualityConstraint< Real >::value().
|
inline |
Definition at line 148 of file ROL_StdVector.hpp.
|
inlinevirtual |
Return i-th basis vector.
| [in] | i | is the index of the basis function. |
Overloading the basis is only required if the default gradient implementation is used, which computes a finite-difference approximation.
Reimplemented from ROL::Vector< Real >.
Definition at line 152 of file ROL_StdVector.hpp.
Referenced by main().
|
inlinevirtual |
Return dimension of the vector space.
Overload if the basis is overloaded.
Reimplemented from ROL::Vector< Real >.
Definition at line 163 of file ROL_StdVector.hpp.
Referenced by ROL::StdVector< Real >::applyBinary(), ROL::StdVector< Real >::axpy(), ROL::StdVector< Real >::basis(), ROL::StdVector< Real >::dot(), main(), ROL::StdVector< Real >::plus(), and ROL::StdVector< Real >::set().
|
inlinevirtual |
Reimplemented from ROL::Vector< Real >.
Definition at line 167 of file ROL_StdVector.hpp.
|
inlinevirtual |
Reimplemented from ROL::Vector< Real >.
Definition at line 174 of file ROL_StdVector.hpp.
|
inlinevirtual |
Reimplemented from ROL::Vector< Real >.
Definition at line 189 of file ROL_StdVector.hpp.
|
inlinevirtual |
Reimplemented from ROL::Vector< Real >.
Definition at line 198 of file ROL_StdVector.hpp.
|
private |
Definition at line 66 of file ROL_StdVector.hpp.
Referenced by ROL::StdVector< Real >::getVector().
1.8.13