ROOT logo
ROOT » MATH » MATHMORE » ROOT::Math::Derivator

class ROOT::Math::Derivator


    Class for computing numerical derivative of a function.
    Presently this class is implemented only using the numerical derivatives
    algorithms provided by GSL
    using the implementation class ROOT::Math::GSLDerivator

    This class does not support copying

    @ingroup Deriv

Function Members (Methods)

public:
virtual~Derivator()
ROOT::Math::DerivatorDerivator()
ROOT::Math::DerivatorDerivator(const ROOT::Math::IGenFunction& f)
ROOT::Math::DerivatorDerivator(const ROOT::Math::Derivator::GSLFuncPointer& f, void* p = 0)
doubleError() const
doubleEval(double x, double h = 1E-8) const
static doubleEval(const ROOT::Math::IGenFunction& f, double x, double h = 1E-8)
static doubleEval(const ROOT::Math::IMultiGenFunction& f, const double* x, unsigned int icoord = 0, double h = 1E-8)
static doubleEval(ROOT::Math::IParamFunction& f, double x, const double* p, unsigned int ipar = 0, double h = 1E-8)
static doubleEval(ROOT::Math::IParamMultiFunction& f, const double* x, const double* p, unsigned int ipar = 0, double h = 1E-8)
doubleEvalBackward(double x, double h = 1E-8) const
static doubleEvalBackward(const ROOT::Math::IGenFunction& f, double x, double h = 1E-8)
doubleEvalCentral(double x, double h = 1E-8) const
static doubleEvalCentral(const ROOT::Math::IGenFunction& f, double x, double h = 1E-8)
doubleEvalForward(double x, double h = 1E-8) const
static doubleEvalForward(const ROOT::Math::IGenFunction& f, double x, double h = 1E-8)
doubleResult() const
voidSetFunction(const ROOT::Math::IGenFunction& f)
voidSetFunction(const ROOT::Math::Derivator::GSLFuncPointer& f, void* p = 0)
intStatus() const

Data Members

private:
ROOT::Math::GSLDerivator*fDerivator

Class Charts

Inheritance Inherited Members Includes Libraries
Class Charts

Function documentation

Derivator()
      Empty Construct for a Derivator class
      Need to set the function afterwards with Derivator::SetFunction

explicit Derivator(const IGenFunction &f)
      Construct using a GSL function pointer type
       @param f :  free function pointer of the GSL required type
       @param p :  pointer to the object carrying the function state
                    (for example the function object itself)

explicit Derivator(const ROOT::Math::Derivator::GSLFuncPointer& f, void* p = 0)
virtual ~Derivator()
 destructor
Derivator(const Derivator &)
 disable copying
void SetFunction(const ROOT::Math::IGenFunction& f)
       Template methods for generic functions
       Set the function f for evaluating the derivative.
       The function type must implement the assigment operator,
       <em>  double  operator() (  double  x ) </em>

SetFunction(const ROOT::Math::Derivator::GSLFuncPointer& f, void* p = 0)
double Eval(double x, double h = 1E-8) const
       Computes the numerical derivative of a function f at a point x.
       It uses Derivator::EvalCentral to compute the derivative using an
       adaptive central difference algorithm with a step size h

double EvalCentral(double x, double h = 1E-8) const
       Computes the numerical derivative at a point x using an adaptive central
       difference algorithm with a step size h.

double EvalForward(double x, double h = 1E-8) const
       Computes the numerical derivative at a point x using an adaptive forward
       difference algorithm with a step size h.
       The function is evaluated only at points greater than x and at x itself.

double EvalBackward(double x, double h = 1E-8) const
       Computes the numerical derivative at a point x using an adaptive backward
       difference algorithm with a step size h.
       The function is evaluated only at points less than x and at x itself.

double Eval(const ROOT::Math::IGenFunction& f, double x, double h = 1E-8)
 @name --- Static methods ---
       This methods don't require to use a Derivator object, and are designed to be used in
       fast calculation. Error and status code cannot be retrieved in this case


       Computes the numerical derivative of a function f at a point x.
       It uses Derivator::EvalCentral to compute the derivative using an
       adaptive central difference algorithm with a step size h

double EvalCentral(const ROOT::Math::IGenFunction& f, double x, double h = 1E-8)
       Computes the numerical derivative of a function f at a point x using an adaptive central
       difference algorithm with a step size h

double EvalForward(const ROOT::Math::IGenFunction& f, double x, double h = 1E-8)
       Computes the numerical derivative of a function f at a point x using an adaptive forward
       difference algorithm with a step size h.
       The function is evaluated only at points greater than x and at x itself

double EvalBackward(const ROOT::Math::IGenFunction& f, double x, double h = 1E-8)
       Computes the numerical derivative of a function f at a point x using an adaptive backward
       difference algorithm with a step size h.
       The function is evaluated only at points less than x and at x itself

double Eval(const ROOT::Math::IMultiGenFunction& f, const double* x, unsigned int icoord = 0, double h = 1E-8)
 Derivatives for multi-dimension functions

      Evaluate the partial derivative of a multi-dim function
      with respect coordinate x_icoord at the point x[]

double Eval(IParamFunction & f, double x, const double * p, unsigned int ipar = 0, double h = 1E-8)
      Evaluate the derivative with respect a parameter for one-dim parameteric function
      at the point ( x,p[]) with respect the parameter p_ipar

double Eval(IParamMultiFunction & f, const double * x, const double * p, unsigned int ipar = 0, double h = 1E-8)
      Evaluate the derivative with respect a parameter for a multi-dim parameteric function
      at the point ( x[],p[]) with respect the parameter p_ipar

int Status() const
      return the error status of the last derivative calculation

double Result() const
      return  the result of the last derivative calculation

double Error() const
      return the estimate of the absolute error of the last derivative calculation