44#ifndef ROL_LINEARCOMBINATIONOBJECTIVE_DEF_H
45#define ROL_LINEARCOMBINATIONOBJECTIVE_DEF_H
49template<
typename Real>
57template<
typename Real>
63template<
typename Real>
65 for (
size_t i=0; i<
size_; ++i) {
66 obj_[i]->update(x,type,iter);
70template<
typename Real>
72 for (
size_t i=0; i<
size_; ++i) {
73 obj_[i]->update(x,flag,iter);
77template<
typename Real>
80 for (
size_t i = 0; i <
size_; i++) {
86template<
typename Real>
93 for (
size_t i = 0; i <
size_; i++) {
99template<
typename Real>
106 for (
size_t i = 0; i <
size_; i++) {
112template<
typename Real>
115 for (
size_t i = 0; i <
size_; ++i) {
116 obj_[i]->setParameter(param);
void setParameter(const std::vector< Real > ¶m) override
Ptr< Vector< Real > > xdual_
const std::vector< Ptr< Objective< Real > > > obj_
Real value(const Vector< Real > &x, Real &tol) override
LinearCombinationObjective(const std::vector< Ptr< Objective< Real > > > &obj)
void gradient(Vector< Real > &g, const Vector< Real > &x, Real &tol) override
void hessVec(Vector< Real > &hv, const Vector< Real > &v, const Vector< Real > &x, Real &tol) override
std::vector< Real > weights_
void update(const Vector< Real > &x, UpdateType type, int iter=-1) override
virtual void setParameter(const std::vector< Real > ¶m)
Defines the linear algebra or vector space interface.
virtual void zero()
Set to zero vector.
virtual ROL::Ptr< Vector > clone() const =0
Clone to make a new (uninitialized) vector.
virtual void axpy(const Real alpha, const Vector &x)
Compute where .