14#ifndef ROOT_Math_Integrator
15#define ROOT_Math_Integrator
159 template<
class Function>
192 template<
class Function>
227 template<
class Function>
303 template<
class Function>
325 template<
class Function>
392 double Integral(
const std::vector<double> & pts) {
487template<
class Function>
494template<
class Function>
524template<
class Function>
531template<
class Function>
size_t size(const MatrixT &matrix)
retrieve the size of a square matrix
Double_t(* Function)(Double_t)
Numerical one dimensional integration options.
std::string Integrator() const override
name of 1D integrator
User Class for performing numerical integration of a function in one dimension.
void SetAbsTolerance(double absTolerance)
set the desired absolute Error
static std::string GetName(IntegrationOneDim::Type)
static function to get a string from the enumeration
void SetFunction(const IGenFunction &f, bool copy=false)
set one dimensional function for 1D integration
double Integral(const IGenFunction &f)
evaluate the Integral of a function f over the infinite interval (-inf,+inf)
IntegratorOneDim(IntegrationOneDim::Type type=IntegrationOneDim::kDEFAULT, double absTol=-1, double relTol=-1, unsigned int size=0, unsigned int rule=0)
Constructor of one dimensional Integrator, default type is adaptive.
double IntegralCauchy(const IGenFunction &f, double a, double b, double c)
evaluate the Cauchy principal value of the integral of a function f over the defined interval (a,...
double operator()(double x)
define operator() for IntegralLow
void SetRelTolerance(double relTolerance)
set the desired relative Error
VirtualIntegratorOneDim * fIntegrator
pointer to integrator interface class
std::string Name() const
return name of integrator
VirtualIntegratorOneDim * GetIntegrator()
return a pointer to integrator object
IntegratorOneDim & operator=(const IntegratorOneDim &)
double IntegralLow(double b)
evaluate the Integral of a function f over the over the semi-infinite interval (-inf,...
double IntegralUp(double a)
evaluate the Integral of a function f over the semi-infinite interval (a,+inf) using the function pre...
int Status() const
return the Error Status of the last Integral calculation
double Result() const
return the Result of the last Integral calculation
virtual ~IntegratorOneDim()
destructor (will delete contained pointers)
VirtualIntegratorOneDim * CreateIntegrator(IntegrationOneDim::Type type, double absTol, double relTol, unsigned int size, int rule)
void SetOptions(const ROOT::Math::IntegratorOneDimOptions &opt)
set the options
IGenFunction * fFunc
pointer to owned function
ROOT::Math::IntegratorOneDimOptions Options() const
retrieve the options
double IntegralUp(const IGenFunction &f, double a)
evaluate the Integral of a function f over the semi-infinite interval (a,+inf)
void SetFunction(Function &f)
method to set the a generic integration function
double Integral(Function &f, double a, double b)
evaluate the Integral of a function f over the defined interval (a,b)
double Integral(const IGenFunction &f, double a, double b)
evaluate the Integral of a function f over the defined interval (a,b)
int NEval() const
return number of function evaluations in calculating the integral (if integrator do not implement thi...
double IntegralCauchy(Function &f, double a, double b, double c)
evaluate the Cauchy principal value of the integral of a function f over the defined interval (a,...
double IntegralCauchy(double a, double b, double c)
evaluate the Cauchy principal value of the integral of a function f over the defined interval (a,...
IntegrationOneDim::Type Type
double Error() const
return the estimate of the absolute Error of the last Integral calculation
double Integral(double a, double b)
evaluate the Integral over the defined interval (a,b) using the function previously set with Integrat...
IntegratorOneDim(Function &f, IntegrationOneDim::Type type=IntegrationOneDim::kDEFAULT, double absTol=-1, double relTol=-1, unsigned int size=0, int rule=0)
Template Constructor of one dimensional Integrator passing a generic function object.
IntegratorOneDim(const IGenFunction &f, IntegrationOneDim::Type type=IntegrationOneDim::kDEFAULT, double absTol=-1, double relTol=-1, unsigned int size=0, int rule=0)
Constructor of one dimensional Integrator passing a function interface.
double Integral(const IGenFunction &f, const std::vector< double > &pts)
evaluate the Integral of a function f with known singular points over the defined Integral (a,...
IntegratorOneDim(const IntegratorOneDim &)
double Integral(const std::vector< double > &pts)
evaluate the Integral over the defined interval (a,b) using the function previously set with Integrat...
double IntegralLow(const IGenFunction &f, double b)
evaluate the Integral of a function f over the over the semi-infinite interval (-inf,...
double Integral()
evaluate the Integral over the infinite interval (-inf,+inf) using the function previously set with I...
static IntegrationOneDim::Type GetType(const char *name)
static function to get the enumeration from a string
Interface (abstract) class for 1D numerical integration It must be implemented by the concrete Integr...
Template class to wrap any C++ callable object which takes one argument i.e.
Type
enumeration specifying the integration types.
@ kDEFAULT
default type specified in the static options
IMultiGenFunctionTempl< double > IMultiGenFunction
IntegratorOneDim Integrator
IBaseFunctionOneDim IGenFunction