Define an abstract function which is twice-derivable (
).
More...
#include <roboptim/core/twice-differentiable-function.hh>
Public Types | |
| typedef std::pair< size_type, size_type > | hessianSize_t |
| Hessian size type represented as a pair of values. | |
Public Member Functions | |
| ROBOPTIM_DIFFERENTIABLE_FUNCTION_FWD_TYPEDEFS_ (GenericDifferentiableFunction< T >) | |
| ROBOPTIM_GENERATE_TRAITS_REFS_ (hessian) | |
| Hessian type. | |
| hessianSize_t | hessianSize () const |
| Return the size of a hessian. | |
| bool | isValidHessian (const_hessian_ref hessian) const |
| Check if the hessian is valid (check sizes). | |
| hessian_t | hessian (const_argument_ref argument, size_type functionId=0) const |
| Compute the hessian at a given point. | |
| void | hessian (hessian_ref hessian, const_argument_ref argument, size_type functionId=0) const |
| Compute the hessian at a given point. | |
| virtual std::ostream & | print (std::ostream &) const |
| Display the function on the specified output stream. | |
Protected Member Functions | |
| GenericTwiceDifferentiableFunction (size_type inputSize, size_type outputSize=1, std::string name=std::string()) | |
| Concrete class constructor should call this constructor. | |
| virtual void | impl_hessian (hessian_ref hessian, const_argument_ref argument, size_type functionId=0) const =0 |
| Hessian evaluation. | |
| void | setZero (hessian_ref symmetric) const |
| Set a symmetric matrix to zero. | |
Define an abstract function which is twice-derivable (
).
A twice-derivable function is a derivable function which provides a way to compute its hessian.
,
where
is the input size and
is the output size.
Hessian computation is done through the impl_hessian method that has to implemented by the concrete class inheriting this class.
The hessian of a
function where
and
is a tensor. To avoid this costly representation, the function is split into
functions. See DifferentiableFunction documentation for more information.
| typedef std::pair<size_type, size_type> roboptim::GenericTwiceDifferentiableFunction< T >::hessianSize_t |
Hessian size type represented as a pair of values.
| roboptim::GenericTwiceDifferentiableFunction< T >::GenericTwiceDifferentiableFunction | ( | size_type | inputSize, |
| size_type | outputSize = 1, |
||
| std::string | name = std::string () |
||
| ) | [protected] |
Concrete class constructor should call this constructor.
| inputSize | input size (argument size) |
| outputSize | output size (result size) |
| name | function's name |
| std::runtime_error |
| hessian_t roboptim::GenericTwiceDifferentiableFunction< T >::hessian | ( | const_argument_ref | argument, |
| size_type | functionId = 0 |
||
| ) | const [inline] |
Compute the hessian at a given point.
Program will abort if the argument size is wrong.
| argument | point where the hessian will be computed |
| functionId | evaluated function id in the split representation |
References roboptim::GenericTwiceDifferentiableFunction< T >::hessianSize(), and roboptim::GenericTwiceDifferentiableFunction< T >::setZero().
| void roboptim::GenericTwiceDifferentiableFunction< T >::hessian | ( | hessian_ref | hessian, |
| const_argument_ref | argument, | ||
| size_type | functionId = 0 |
||
| ) | const [inline] |
Compute the hessian at a given point.
Program will abort if the argument size is wrong.
| 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
References roboptim::GenericTwiceDifferentiableFunction< T >::impl_hessian(), roboptim::is_malloc_allowed(), roboptim::GenericTwiceDifferentiableFunction< T >::isValidHessian(), roboptim::GenericFunction< T >::logger, and roboptim::set_is_malloc_allowed().
| hessianSize_t roboptim::GenericTwiceDifferentiableFunction< T >::hessianSize | ( | ) | const [inline] |
Return the size of a hessian.
Hessian size is equal to (input size, input size).
References roboptim::GenericFunction< T >::inputSize().
Referenced by roboptim::GenericTwiceDifferentiableFunction< T >::hessian(), and roboptim::GenericTwiceDifferentiableFunction< T >::isValidHessian().
| virtual void roboptim::GenericTwiceDifferentiableFunction< T >::impl_hessian | ( | hessian_ref | hessian, |
| const_argument_ref | argument, | ||
| size_type | functionId = 0 |
||
| ) | const [protected, pure virtual] |
Hessian evaluation.
Compute the hessian, has to be implemented in concrete classes. 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 |
Implemented in roboptim::NTimesDerivableFunction< 2 >, roboptim::Cos< T >, roboptim::Sin< T >, roboptim::GenericNumericQuadraticFunction< T >, roboptim::Cos< T >, roboptim::Polynomial< T >, roboptim::Sin< T >, and roboptim::GenericLinearFunction< T >.
Referenced by roboptim::GenericTwiceDifferentiableFunction< T >::hessian().
| bool roboptim::GenericTwiceDifferentiableFunction< T >::isValidHessian | ( | const_hessian_ref | hessian | ) | const [inline] |
Check if the hessian is valid (check sizes).
| hessian | hessian that will be checked |
References roboptim::GenericTwiceDifferentiableFunction< T >::hessianSize().
Referenced by roboptim::GenericTwiceDifferentiableFunction< T >::hessian().
| std::ostream & roboptim::GenericTwiceDifferentiableFunction< T >::print | ( | std::ostream & | o | ) | const [virtual] |
Display the function on the specified output stream.
| o | output stream used for display |
Reimplemented from roboptim::GenericDifferentiableFunction< T >.
Reimplemented in roboptim::NTimesDerivableFunction< 2 >, roboptim::GenericNumericQuadraticFunction< T >, roboptim::GenericConstantFunction< T >, roboptim::GenericNumericLinearFunction< T >, roboptim::GenericIdentityFunction< T >, roboptim::Polynomial< T >, roboptim::GenericLinearFunction< T >, roboptim::GenericQuadraticFunction< T >, roboptim::Cos< T >, and roboptim::Sin< T >.
References roboptim::indent().
| roboptim::GenericTwiceDifferentiableFunction< T >::ROBOPTIM_DIFFERENTIABLE_FUNCTION_FWD_TYPEDEFS_ | ( | GenericDifferentiableFunction< T > | ) |
| roboptim::GenericTwiceDifferentiableFunction< T >::ROBOPTIM_GENERATE_TRAITS_REFS_ | ( | hessian | ) |
Hessian type.
Hessians are symmetric matrices.
| void roboptim::GenericTwiceDifferentiableFunction< T >::setZero | ( | hessian_ref | symmetric | ) | const [inline, protected] |
Set a symmetric matrix to zero.
Referenced by roboptim::GenericNumericQuadraticFunction< T >::GenericNumericQuadraticFunction(), and roboptim::GenericTwiceDifferentiableFunction< T >::hessian().