74 Teuchos::RCP<const vector>
getVector(
const V& x ) {
75 using Teuchos::dyn_cast;
80 using Teuchos::dyn_cast;
98 Real f1 = 1.5-(*ex)[0]*(1.0-(*ex)[1]);
99 Real f2 = 2.25-(*ex)[0]*(1.0-pow((*ex)[1],2));
100 Real f3 = 2.625-(*ex)[0]*(1.0-pow((*ex)[1],3));
102 return pow(f1,2)+pow(f2,2)+pow(f3,2);
112 Real f1 = 1.5-(*ex)[0]*(1.0-(*ex)[1]);
113 Real f2 = 2.25-(*ex)[0]*(1.0-pow((*ex)[1],2));
114 Real f3 = 2.625-(*ex)[0]*(1.0-pow((*ex)[1],3));
115 Real df1dx = -(1.0-(*ex)[1]);
116 Real df1dy = (*ex)[0];
117 Real df2dx = -(1.0-pow((*ex)[1],2));
118 Real df2dy = 2.0*(*ex)[0]*(*ex)[1];
119 Real df3dx = -(1.0-pow((*ex)[1],3));
120 Real df3dy = 3.0*(*ex)[0]*pow((*ex)[1],2);
122 (*eg)[0] = 2.0*df1dx*f1+2.0*df2dx*f2+2.0*df3dx*f3;
123 (*eg)[1] = 2.0*df1dy*f1+2.0*df2dy*f2+2.0*df3dy*f3;
133 Real f1 = 1.5-(*ex)[0]*(1.0-(*ex)[1]);
134 Real f2 = 2.25-(*ex)[0]*(1.0-pow((*ex)[1],2));
135 Real f3 = 2.625-(*ex)[0]*(1.0-pow((*ex)[1],3));
136 Real df1dx = -(1.0-(*ex)[1]);
137 Real df1dy = (*ex)[0];
138 Real df2dx = -(1.0-pow((*ex)[1],2));
139 Real df2dy = 2.0*(*ex)[0]*(*ex)[1];
140 Real df3dx = -(1.0-pow((*ex)[1],3));
141 Real df3dy = 3.0*(*ex)[0]*pow((*ex)[1],2);
146 Real d2f2dy2 = 2.0*(*ex)[0];
147 Real d2f2dxdy = 2.0*(*ex)[1];
149 Real d2f3dy2 = 6.0*(*ex)[0]*(*ex)[1];
150 Real d2f3dxdy = 3.0*pow((*ex)[1],2);
152 Real H11 = 2.0*(d2f1dx2*f1+df1dx*df1dx)+2.0*(d2f2dx2*f2+df2dx*df2dx)
153 +2.0*(d2f3dx2*f3+df3dx*df3dx);
154 Real H22 = 2.0*(d2f1dy2*f1+df1dy*df1dy)+2.0*(d2f2dy2*f2+df2dy*df2dy)
155 +2.0*(d2f3dy2*f3+df3dy*df3dy);
156 Real H12 = 2.0*(d2f1dxdy*f1 + df1dx*df1dy)+2.0*(d2f2dxdy*f2 + df2dx*df2dy)
157 +2.0*(d2f3dxdy*f3 + df3dx*df3dy);
159 (*ehv)[0] = H11*(*ev)[0]+H12*(*ev)[1];
160 (*ehv)[1] = H12*(*ev)[0]+H22*(*ev)[1];
171 Real f1 = 1.5-(*ex)[0]*(1.0-(*ex)[1]);
172 Real f2 = 2.25-(*ex)[0]*(1.0-pow((*ex)[1],2));
173 Real f3 = 2.625-(*ex)[0]*(1.0-pow((*ex)[1],3));
174 Real df1dx = -(1.0-(*ex)[1]);
175 Real df1dy = (*ex)[0];
176 Real df2dx = -(1.0-pow((*ex)[1],2));
177 Real df2dy = 2.0*(*ex)[0]*(*ex)[1];
178 Real df3dx = -(1.0-pow((*ex)[1],3));
179 Real df3dy = 3.0*(*ex)[0]*pow((*ex)[1],2);
184 Real d2f2dy2 = 2.0*(*ex)[0];
185 Real d2f2dxdy = 2.0*(*ex)[1];
187 Real d2f3dy2 = 6.0*(*ex)[0]*(*ex)[1];
188 Real d2f3dxdy = 3.0*pow((*ex)[1],2);
190 Real H11 = 2.0*(d2f1dx2*f1+df1dx*df1dx)+2.0*(d2f2dx2*f2+df2dx*df2dx)
191 +2.0*(d2f3dx2*f3+df3dx*df3dx);
192 Real H22 = 2.0*(d2f1dy2*f1+df1dy*df1dy)+2.0*(d2f2dy2*f2+df2dy*df2dy)
193 +2.0*(d2f3dy2*f3+df3dy*df3dy);
194 Real H12 = 2.0*(d2f1dxdy*f1 + df1dx*df1dy)+2.0*(d2f2dxdy*f2 + df2dx*df2dy)
195 +2.0*(d2f3dxdy*f3 + df3dx*df3dy);
197 (*ehv)[0] = (1.0/(H11*H22-H12*H12))*( H22*(*ev)[0] - H12*(*ev)[1]);
198 (*ehv)[1] = (1.0/(H11*H22-H12*H12))*(-H12*(*ev)[0] + H11*(*ev)[1]);
205 typedef std::vector<Real>
vector;
208 typedef typename vector::size_type uint;
211 using Teuchos::dyn_cast;
214 RCP<vector> x0p = dyn_cast<SV>(x0).
getVector();
215 RCP<vector> xp = dyn_cast<SV>(x).
getVector();
Provides the interface to evaluate objective functions.
void gradient(Vector< Real > &g, const Vector< Real > &x, Real &tol)
Compute gradient.
virtual void hessVec(Vector< Real > &hv, const Vector< Real > &v, const Vector< Real > &x, Real &tol)
Apply Hessian approximation to vector.
Defines the linear algebra or vector space interface.
Provides the std::vector implementation of the ROL::Vector interface.
Teuchos::RCP< vector > getVector(V &x)
Teuchos::RCP< const vector > getVector(const V &x)
Real value(const Vector< Real > &x, Real &tol)
Compute value.
void getBeale(Teuchos::RCP< Objective< Real > > &obj, Vector< Real > &x0, Vector< Real > &x)
std::vector< Real > vector
void invHessVec(Vector< Real > &hv, const Vector< Real > &v, const Vector< Real > &x, Real &tol)
Apply inverse Hessian approximation to vector.