Interface (abstract class) for parametric gradient multi-dimensional functions providing in addition to function evaluation with respect to the coordinates also the gradient with respect to the parameters, via the method ParameterGradient.
It is a derived class from ROOT::Math::IParametricFunctionMultiDim.
The pure private virtual method DoParameterGradient must be implemented by the derived classes in addition to those inherited by the base abstract classes.
Definition at line 227 of file IParamFunction.h.
Public Types | |
| typedef T | BackendType |
| using | BaseFunc = typename IParametricFunctionMultiDimTempl<T>::BaseFunc |
| using | BaseGradFunc = IGradientFunctionMultiDimTempl<T> |
| using | BaseParamFunc = IParametricFunctionMultiDimTempl<T> |
Public Member Functions | |
| ~IParametricGradFunctionMultiDimTempl () override | |
| Virtual Destructor (no operations). | |
| virtual IBaseFunctionMultiDimTempl< T > * | Clone () const =0 |
| Clone a function. | |
| T | Derivative (const T *x, unsigned int icoord, T *previous_grad, T *previous_g2, T *previous_gstep) const |
| In some cases, the derivative algorithm will use information from the previous step, these can be passed in with this overload. | |
| T | Derivative (const T *x, unsigned int icoord=0) const |
| Return the partial derivative with respect to the passed coordinate. | |
| virtual void | FdF (const T *x, T &f, T *df) const |
| Optimized method to evaluate at the same time the function value and derivative at a point x. | |
| virtual void | Gradient (const T *x, T *grad) const |
| Evaluate all the vector of function derivatives (gradient) at a point x. | |
| virtual bool | HasGradient () const |
| virtual bool | HasParameterHessian () const |
| virtual unsigned int | NDim () const =0 |
| Retrieve the dimension of the function. | |
| virtual unsigned int | NPar () const =0 |
| Return the number of Parameters. | |
| T | operator() (const T *x) const |
| T | operator() (const T *x, const double *p) const |
| T | ParameterDerivative (const T *x, const double *p, unsigned int ipar=0) const |
| Evaluate the partial derivative w.r.t a parameter ipar from values and parameters. | |
| T | ParameterDerivative (const T *x, unsigned int ipar=0) const |
| Evaluate partial derivative using cached parameter values. | |
| virtual bool | ParameterG2 (const T *, const double *, T *) const |
| Evaluate all the second derivatives (diagonal ones) of the function with respect to the parameters at a point x. | |
| virtual void | ParameterGradient (const T *x, const double *p, T *grad) const |
| Evaluate the all the derivatives (gradient vector) of the function with respect to the parameters at a point x. | |
| void | ParameterGradient (const T *x, T *grad) const |
| Evaluate all derivatives using cached parameter values. | |
| virtual bool | ParameterHessian (const T *, const double *, T *) const |
| Evaluate the all the Hessian (second derivatives matrix) of the function with respect to the parameters at a point x. | |
| virtual std::string | ParameterName (unsigned int i) const |
| Return the name of the i-th parameter (starting from zero) Overwrite if want to avoid the default name ("Par_0, Par_1, ..."). | |
| virtual const double * | Parameters () const =0 |
| Access the parameter values. | |
| virtual void | SetParameters (const double *p)=0 |
| Set the parameter values. | |
Private Member Functions | |
| T | DoEval (const T *x) const override |
| Implement the ROOT::Math::IBaseFunctionMultiDim interface DoEval(x) using the cached parameter values. | |
| T | DoEvalPar (const T *x, const double *p) const override=0 |
| Implementation of the evaluation function using the x values and the parameters. | |
| virtual T | DoParameterDerivative (const T *x, const double *p, unsigned int ipar) const =0 |
| Evaluate the partial derivative w.r.t a parameter ipar , to be implemented by the derived classes. | |
#include <Math/IParamFunction.h>
|
inherited |
Definition at line 67 of file IFunction.h.
| using ROOT::Math::IParametricGradFunctionMultiDimTempl< T >::BaseFunc = typename IParametricFunctionMultiDimTempl<T>::BaseFunc |
Definition at line 232 of file IParamFunction.h.
| using ROOT::Math::IParametricGradFunctionMultiDimTempl< T >::BaseGradFunc = IGradientFunctionMultiDimTempl<T> |
Definition at line 231 of file IParamFunction.h.
| using ROOT::Math::IParametricGradFunctionMultiDimTempl< T >::BaseParamFunc = IParametricFunctionMultiDimTempl<T> |
Definition at line 230 of file IParamFunction.h.
|
inlineoverride |
Virtual Destructor (no operations).
Definition at line 238 of file IParamFunction.h.
|
pure virtualinherited |
Clone a function.
Each derived class must implement their version of the Clone method.
Implemented in ROOT::Fit::FcnAdapter, ROOT::Math::Functor, ROOT::Math::GradFunctor, ROOT::Math::LSResidualFunc< Func >, ROOT::Math::MinimTransformFunction, ROOT::Math::MultiDimParamFunctionAdapter, ROOT::Math::MultiDimParamGradFunctionAdapter, ROOT::Math::MultiNumGradFunction, ROOT::Math::WrappedMemMultiFunction< FuncObj, MemFuncPtr >, ROOT::Math::WrappedMultiFunction< Func >, ROOT::Math::WrappedMultiTF1Templ< T >, ROOT::Math::WrappedMultiTF1Templ< double >, ROOT::Math::WrappedParamFunction< FuncPtr >, and ROOT::Math::WrappedParamFunctionGen< FuncPtr >.
|
inlineinherited |
In some cases, the derivative algorithm will use information from the previous step, these can be passed in with this overload.
The previous_* arrays can also be used to return second derivative and step size so that these can be passed forward again as well at the call site, if necessary.
Definition at line 120 of file IFunction.h.
|
inlineinherited |
Return the partial derivative with respect to the passed coordinate.
Definition at line 115 of file IFunction.h.
|
inlineoverrideprivatevirtual |
Implement the ROOT::Math::IBaseFunctionMultiDim interface DoEval(x) using the cached parameter values.
Reimplemented from ROOT::Math::IParametricFunctionMultiDimTempl< T >.
Reimplemented in ROOT::Math::WrappedMultiTF1Templ< T >, and ROOT::Math::WrappedMultiTF1Templ< double >.
Definition at line 307 of file IParamFunction.h.
|
overrideprivatepure virtual |
Implementation of the evaluation function using the x values and the parameters.
Must be implemented by derived classes
Implements ROOT::Math::IParametricFunctionMultiDimTempl< T >.
Implemented in ROOT::Math::MultiDimParamGradFunctionAdapter, ROOT::Math::WrappedMultiTF1Templ< T >, and ROOT::Math::WrappedMultiTF1Templ< double >.
|
privatepure virtual |
Evaluate the partial derivative w.r.t a parameter ipar , to be implemented by the derived classes.
Implemented in ROOT::Math::MultiDimParamGradFunctionAdapter, ROOT::Math::WrappedMultiTF1Templ< T >, and ROOT::Math::WrappedMultiTF1Templ< double >.
|
inlinevirtualinherited |
Optimized method to evaluate at the same time the function value and derivative at a point x.
Often both value and derivatives are needed and it is often more efficient to compute them at the same time. Derived class should implement this method if performances play an important role and if it is faster to evaluate value and derivative at the same time
Reimplemented in ROOT::Math::LSResidualFunc< Func >.
Definition at line 108 of file IFunction.h.
|
inlinevirtualinherited |
Evaluate all the vector of function derivatives (gradient) at a point x.
Derived classes must re-implement it if more efficient than evaluating one at a time
Reimplemented in ROOT::Math::GradFunctor, and ROOT::Math::LSResidualFunc< Func >.
Definition at line 96 of file IFunction.h.
|
inlinevirtualinherited |
Reimplemented in ROOT::Math::IGradientFunctionMultiDimTempl< T >, and ROOT::Math::IGradientFunctionMultiDimTempl< double >.
Definition at line 92 of file IFunction.h.
|
inlinevirtual |
Reimplemented in ROOT::Math::WrappedMultiTF1Templ< T >, and ROOT::Math::WrappedMultiTF1Templ< double >.
Definition at line 265 of file IParamFunction.h.
|
pure virtualinherited |
Retrieve the dimension of the function.
Implemented in ROOT::Fit::FcnAdapter, ROOT::Math::BasicFitMethodFunction< ROOT::Math::IMultiGenFunction >, ROOT::Math::BasicFitMethodFunction< ROOT::Math::IMultiGradFunction >, ROOT::Math::Functor, ROOT::Math::GradFunctor, ROOT::Math::LSResidualFunc< Func >, ROOT::Math::MinimTransformFunction, ROOT::Math::MultiDimParamFunctionAdapter, ROOT::Math::MultiDimParamGradFunctionAdapter, ROOT::Math::MultiNumGradFunction, ROOT::Math::WrappedMemMultiFunction< FuncObj, MemFuncPtr >, ROOT::Math::WrappedMultiFunction< Func >, ROOT::Math::WrappedMultiTF1Templ< T >, ROOT::Math::WrappedMultiTF1Templ< double >, ROOT::Math::WrappedParamFunction< FuncPtr >, and ROOT::Math::WrappedParamFunctionGen< FuncPtr >.
|
pure virtualinherited |
Return the number of Parameters.
Implemented in ROOT::Math::MultiDimParamFunctionAdapter, ROOT::Math::MultiDimParamGradFunctionAdapter, ROOT::Math::ParamFunction< IParamGradFunction >, ROOT::Math::VavilovAccurateCdf, ROOT::Math::VavilovAccuratePdf, ROOT::Math::VavilovAccurateQuantile, ROOT::Math::WrappedMultiTF1Templ< T >, ROOT::Math::WrappedMultiTF1Templ< double >, ROOT::Math::WrappedParamFunction< FuncPtr >, ROOT::Math::WrappedParamFunctionGen< FuncPtr >, and ROOT::Math::WrappedTF1.
|
inline |
Definition at line 248 of file IParamFunction.h.
|
inline |
Definition at line 243 of file IParamFunction.h.
|
inline |
Evaluate the partial derivative w.r.t a parameter ipar from values and parameters.
Definition at line 283 of file IParamFunction.h.
|
inline |
Evaluate partial derivative using cached parameter values.
Definition at line 295 of file IParamFunction.h.
|
inlinevirtual |
Evaluate all the second derivatives (diagonal ones) of the function with respect to the parameters at a point x.
g2 is a vector of dimension npar
Reimplemented in ROOT::Math::WrappedMultiTF1Templ< T >, and ROOT::Math::WrappedMultiTF1Templ< double >.
Definition at line 278 of file IParamFunction.h.
|
inlinevirtual |
Evaluate the all the derivatives (gradient vector) of the function with respect to the parameters at a point x.
It is optional to be implemented by the derived classes for better efficiency
Reimplemented in ROOT::Math::MultiDimParamGradFunctionAdapter, ROOT::Math::WrappedMultiTF1Templ< T >, and ROOT::Math::WrappedMultiTF1Templ< double >.
Definition at line 257 of file IParamFunction.h.
|
inline |
Evaluate all derivatives using cached parameter values.
Definition at line 291 of file IParamFunction.h.
|
inlinevirtual |
Evaluate the all the Hessian (second derivatives matrix) of the function with respect to the parameters at a point x.
It is optional to be implemented by the derived classes if needed. If it is not implemented return a false. h must be dimensioned as a n x (n+1)/2 matrix (since it is a symmetric matrix)
Reimplemented in ROOT::Math::WrappedMultiTF1Templ< T >, and ROOT::Math::WrappedMultiTF1Templ< double >.
Definition at line 272 of file IParamFunction.h.
|
inlinevirtualinherited |
Return the name of the i-th parameter (starting from zero) Overwrite if want to avoid the default name ("Par_0, Par_1, ...").
Reimplemented in ROOT::Math::VavilovAccurateCdf, ROOT::Math::VavilovAccuratePdf, ROOT::Math::VavilovAccurateQuantile, ROOT::Math::WrappedMultiTF1Templ< T >, ROOT::Math::WrappedMultiTF1Templ< double >, and ROOT::Math::WrappedTF1.
Definition at line 86 of file IParamFunction.h.
|
pure virtualinherited |
Access the parameter values.
Implemented in ROOT::Math::MultiDimParamFunctionAdapter, ROOT::Math::MultiDimParamGradFunctionAdapter, ROOT::Math::ParamFunction< IParamGradFunction >, ROOT::Math::VavilovAccurateCdf, ROOT::Math::VavilovAccuratePdf, ROOT::Math::VavilovAccurateQuantile, ROOT::Math::WrappedMultiTF1Templ< T >, ROOT::Math::WrappedMultiTF1Templ< double >, ROOT::Math::WrappedParamFunction< FuncPtr >, ROOT::Math::WrappedParamFunctionGen< FuncPtr >, and ROOT::Math::WrappedTF1.
|
pure virtualinherited |
Set the parameter values.
| p | vector of doubles containing the parameter values. |
to be defined: can user change number of params ? At the moment no.
Implemented in ROOT::Math::MultiDimParamFunctionAdapter, ROOT::Math::MultiDimParamGradFunctionAdapter, ROOT::Math::ParamFunction< IParamGradFunction >, ROOT::Math::VavilovAccurateCdf, ROOT::Math::VavilovAccuratePdf, ROOT::Math::VavilovAccurateQuantile, ROOT::Math::WrappedMultiTF1Templ< T >, ROOT::Math::WrappedMultiTF1Templ< double >, ROOT::Math::WrappedParamFunction< FuncPtr >, ROOT::Math::WrappedParamFunctionGen< FuncPtr >, and ROOT::Math::WrappedTF1.