Explicit specialization for the stop case of NTimesDerivable class. More...
#include <roboptim/core/n-times-derivable-function.hh>
Public Types | |
typedef TwiceDifferentiableFunction | parent_t |
Parent type. | |
typedef parent_t::traits_t | traits_t |
Traits type. | |
Public Member Functions | |
ROBOPTIM_GENERATE_TRAITS_REFS_T (derivative, traits_t) | |
Derivative type. | |
virtual size_type | derivabilityOrderMax () const |
Returns the maximum derivability order (relevant for N>2 only) | |
virtual | ~NTimesDerivableFunction () |
size_type | derivativeSize () const |
Return the size of the derivative vector. | |
bool | isValidDerivative (const_derivative_ref derivative) const |
Check if a derivative is valid (check sizes). | |
result_t | operator() (value_type argument) const |
Evaluate the function at a specified point. | |
void | operator() (result_ref result, value_type argument) const |
Evaluate the function at a specified point. | |
derivative_t | derivative (value_type argument, size_type order=1) const |
Compute the derivative of the function. | |
void | derivative (derivative_ref derivative, value_type argument, size_type order=1) const |
Compute the derivative of the function. | |
virtual std::ostream & | print (std::ostream &o) const |
Display the function on the specified output stream. | |
Static Public Attributes | |
static const size_type | derivabilityOrder = 2 |
Function derivability order. | |
Protected Member Functions | |
NTimesDerivableFunction (size_type outputSize=1, std::string name=std::string()) | |
Concrete class constructor should call this constructor. | |
void | impl_compute (result_ref result, const_argument_ref argument) const |
Function evaluation. | |
virtual void | impl_compute (result_ref result, value_type t) const =0 |
Function evaluation. | |
void | impl_gradient (gradient_ref gradient, const_argument_ref argument, size_type functionId=0) const |
Gradient evaluation. | |
virtual void | impl_derivative (derivative_ref derivative, value_type argument, size_type order=1) const =0 |
Derivative evaluation. | |
void | impl_hessian (hessian_ref hessian, const_argument_ref argument, size_type functionId=0) const |
Hessian evaluation. |
Explicit specialization for the stop case of NTimesDerivable class.
This specialization defines the interface of a ``n times derivable function'' and implements generic methods required by upper classes using this class specific interface.
Parent type.
typedef parent_t::traits_t roboptim::NTimesDerivableFunction< 2 >::traits_t |
Traits type.
Reimplemented from roboptim::GenericFunction< T >.
virtual roboptim::NTimesDerivableFunction< 2 >::~NTimesDerivableFunction | ( | ) | [inline, virtual] |
roboptim::NTimesDerivableFunction< 2 >::NTimesDerivableFunction | ( | size_type | outputSize = 1 , |
std::string | name = std::string () |
||
) | [inline, protected] |
Concrete class constructor should call this constructor.
outputSize | output size (result size) |
name | function's name |
virtual size_type roboptim::NTimesDerivableFunction< 2 >::derivabilityOrderMax | ( | ) | const [inline, virtual] |
Returns the maximum derivability order (relevant for N>2 only)
derivative_t roboptim::NTimesDerivableFunction< 2 >::derivative | ( | value_type | argument, |
size_type | order = 1 |
||
) | const [inline] |
Compute the derivative of the function.
Derivative is computed for a certain order, at a given point.
argument | point at which the derivative will be computed |
order | derivative order (if 0 then function is evaluated) |
References roboptim::derivative().
void roboptim::NTimesDerivableFunction< 2 >::derivative | ( | derivative_ref | derivative, |
value_type | argument, | ||
size_type | order = 1 |
||
) | const [inline] |
Compute the derivative of the function.
Derivative is computed for a certain order, at a given point.
derivative | derivative will be stored in this vector |
argument | point at which the derivative will be computed |
order | derivative order (if 0 then function is evaluated) |
References roboptim::NTimesDerivableFunction< DerivabilityOrder >::derivabilityOrderMax().
size_type roboptim::NTimesDerivableFunction< 2 >::derivativeSize | ( | ) | const [inline] |
Return the size of the derivative vector.
void roboptim::NTimesDerivableFunction< 2 >::impl_compute | ( | result_ref | result, |
const_argument_ref | argument | ||
) | const [inline, protected, virtual] |
Function evaluation.
Implement generic function evaluation, as required by Function, using this class evaluation method (using a double instead of a vector).
result | result will be stored in this vector |
argument | point at which the function will be evaluated |
Implements roboptim::GenericFunction< T >.
virtual void roboptim::NTimesDerivableFunction< 2 >::impl_compute | ( | result_ref | result, |
value_type | t | ||
) | const [protected, pure virtual] |
Function evaluation.
Evaluate the function, has to be implemented in concrete classes.
result | result will be stored in this vector |
t | point at which the function will be evaluated |
virtual void roboptim::NTimesDerivableFunction< 2 >::impl_derivative | ( | derivative_ref | derivative, |
value_type | argument, | ||
size_type | order = 1 |
||
) | const [protected, pure virtual] |
Derivative evaluation.
Compute the derivative, has to be implemented in concrete classes.
derivative | derivative will be store in this argument |
argument | point where the gradient will be computed |
order | derivative order (if 0 evaluates the function) |
void roboptim::NTimesDerivableFunction< 2 >::impl_gradient | ( | gradient_ref | gradient, |
const_argument_ref | argument, | ||
size_type | functionId = 0 |
||
) | const [inline, protected, virtual] |
Gradient evaluation.
Implement the gradient computation, as required by DerivableFunction. The gradient is computed for a specific sub-function which id is passed through the functionId argument.
gradient | gradient will be store in this argument |
argument | point where the gradient will be computed |
functionId | evaluated function id in the split representation |
ROBOPTIM_DO_NOT_CHECK_ALLOCATION
ROBOPTIM_DO_NOT_CHECK_ALLOCATION
Implements roboptim::GenericDifferentiableFunction< T >.
References roboptim::derivative(), roboptim::is_malloc_allowed(), and roboptim::set_is_malloc_allowed().
void roboptim::NTimesDerivableFunction< 2 >::impl_hessian | ( | hessian_ref | hessian, |
const_argument_ref | argument, | ||
size_type | functionId = 0 |
||
) | const [inline, protected, virtual] |
Hessian evaluation.
Implement the hessian computation, as required by the TwiceDerivableFunction class using the derivative method. The hessian is computed for a specific sub-function which id is passed through the functionId argument.
hessian | hessian will be stored here |
argument | point where the hessian will be computed |
functionId | evaluated function id in the split representation |
ROBOPTIM_DO_NOT_CHECK_ALLOCATION
ROBOPTIM_DO_NOT_CHECK_ALLOCATION
Implements roboptim::GenericTwiceDifferentiableFunction< T >.
References roboptim::derivative(), roboptim::is_malloc_allowed(), and roboptim::set_is_malloc_allowed().
bool roboptim::NTimesDerivableFunction< 2 >::isValidDerivative | ( | const_derivative_ref | derivative | ) | const [inline] |
Check if a derivative is valid (check sizes).
derivative | derivative vector to be checked |
result_t roboptim::NTimesDerivableFunction< 2 >::operator() | ( | value_type | argument | ) | const [inline] |
Evaluate the function at a specified point.
The program will abort if the argument does not have the expected size.
argument | point at which the function will be evaluated |
void roboptim::NTimesDerivableFunction< 2 >::operator() | ( | result_ref | result, |
value_type | argument | ||
) | const [inline] |
Evaluate the function at a specified point.
The program will abort if the argument does not have the expected size.
result | result will be stored in this vector |
argument | point at which the function will be evaluated |
virtual std::ostream& roboptim::NTimesDerivableFunction< 2 >::print | ( | std::ostream & | o | ) | const [inline, virtual] |
Display the function on the specified output stream.
o | output stream used for display |
Reimplemented from roboptim::GenericTwiceDifferentiableFunction< T >.
References roboptim::NTimesDerivableFunction< DerivabilityOrder >::derivabilityOrderMax().
Derivative type.
Derivatives are column vectors.
const size_type roboptim::NTimesDerivableFunction< 2 >::derivabilityOrder = 2 [static] |
Function derivability order.
One static const variable per class in inheritance structure.