13 #ifndef ROOT_Math_OneDimFunctionAdapter 14 #define ROOT_Math_OneDimFunctionAdapter 16 #ifndef ROOT_Math_IFunction 19 #ifndef ROOT_Math_IParamFunction 32 template<
class MultiFuncType>
35 static double F (MultiFuncType
f,
const double *
x,
const double * = 0 ) {
59 template <
class MultiFuncType = const ROOT::Math::IMultiGenFunction &>
71 fX( const_cast<double *>(x) ),
107 std::copy(fX, fX+fDim, f->
fX);
120 template<
class Iterator>
121 void SetX(Iterator begin, Iterator end) {
122 if (fOwn) std::copy(begin, end, fX);
137 if (fOwn) std::copy(x, x+fDim, fX);
139 SetX( const_cast<double *>(x) );
148 fParams(rhs.fParams),
154 fX =
new double[fDim];
155 std::copy( rhs.
fX, rhs.
fX+fDim, fX);
165 if (
this == &rhs)
return *
this;
182 double xprev = fX[fCoord];
216 template <
class ParamFuncType = ROOT::Math::IParamMultiFunction &>
232 assert(fParams != 0);
257 double * p =
const_cast<double *
>(fParams);
258 double pprev = fParams[fIpar];
260 double y = fFunc( fX, p );
Interface (abstract class) for generic functions objects of one-dimension Provides a method to evalua...
static double F(MultiFuncType f, const double *x, const double *=0)
This namespace contains pre-defined functions to be used in conjuction with TExecutor::Map and TExecu...
double DoEval(double x) const
evaluate function at the values x[] given in the constructor and as function of the coordinate fCoord...
virtual ~OneDimMultiFunctionAdapter()
Destructor (no operations)
static double F(const ROOT::Math::IParamMultiFunction &f, const double *x, const double *p=0)
OneDimMultiFunctionAdapter class to wrap a multidimensional function in one dimensional one...
virtual OneDimMultiFunctionAdapter * Clone() const
clone
~OneDimParamFunctionAdapter()
Destructor (no operations)
OneDimMultiFunctionAdapter(MultiFuncType f, const double *x, unsigned int icoord=0, const double *p=0)
Constructor from the function object , pointer to an external array of x values and coordinate we wan...
OneDimMultiFunctionAdapter(const OneDimMultiFunctionAdapter &rhs)
IParamFunction interface (abstract class) describing multi-dimensional parameteric functions It is a ...
OneDimMultiFunctionAdapter(MultiFuncType f, unsigned int dim=1, unsigned int icoord=0, const double *p=0)
Constructor from the function object , dimension of the function and and coordinate we want to adapt...
OneDimParamFunctionAdapter class to wrap a multi-dim parameteric function in one dimensional one...
void SetX(const double *x)
set values
double DoEval(double x) const
evaluate function at the values x[] given in the constructor and as function of the coordinate fCoord...
void SetX(Iterator begin, Iterator end)
Set X values in case vector is own, iterator size must match previous set dimension.
Namespace for new Math classes and functions.
void SetX(double *x)
set pointer without copying the values
void SetCoord(int icoord)
virtual OneDimParamFunctionAdapter * Clone() const
clone
OneDimParamFunctionAdapter(ParamFuncType f, const double *x, const double *p, unsigned int ipar=0)
Constructor from the function object , x value and coordinate we want to adapt.