Interior-point-optimisation  1.0-1
Interior-pointoptimisationlibrary
GradientEstimate.hpp
Go to the documentation of this file.
1 /*
2  * $Id: GradientEstimate.hpp 37 2013-04-11 10:51:50Z jdl3 $
3  * Copyright (C) 2011, 2013 John D Lamb
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License as published by
7  * the Free Software Foundation; either version 2 of the License, or (at
8  * your option) any later version.
9  *
10  * This program is distributed in the hope that it will be useful, but
11  * WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13  * General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public License
16  * along with this program; if not, write to the Free Software
17  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
18  */
19 
20 #ifndef IPO_FUNCTION_GRADIENTESTIMATE_HPP
21 #define IPO_FUNCTION_GRADIENTESTIMATE_HPP
22 
23 #include<cmath>
24 #include<limits>
25 #include"Function.hpp"
26 #include"../ipo/detail/GSL.hpp"
27 
28 namespace ipo_function {
35  class GradientEstimate : public virtual detail::FunctionBase {
36  public:
42  GradientEstimate( size_t const size = 0 );
47  virtual void setVector( gsl::vector const& vector ) = 0;
51  virtual double value() const;
55  virtual gsl::vector gradient() const;
56  protected:
60  double functionValue;
64  gsl::vector functionGradient;
65  };
66 }
67 
68 #endif
Base class for gradient estimators.
double functionValue
The function value.
gsl::vector functionGradient
The gradient value.
virtual gsl::vector gradient() const
virtual double value() const
GradientEstimate(size_t const size=0)
Constructor.
Namespace for functions that can be used by ipo::Objective and ipo::Constraint.
Base class for Function and DerivativesEstimates.
size_t const size
Size of vector arguments to supply to subclass functions.
virtual void setVector(gsl::vector const &vector)=0
Set the vector to a new value.