31 #ifndef ROOT_Math_GSL_RootFinderDeriv
32 #define ROOT_Math_GSL_RootFinderDeriv
35 #ifndef ROOT_Math_GSLFunctionAdapter
39 #ifndef ROOT_Math_IFunctionfwd
42 #ifndef ROOT_Math_IFunction
46 #ifndef ROOT_Math_IRootFinderMethod
56 class GSLRootFdFSolver;
57 class GSLFunctionDerivWrapper;
97 #if defined(__MAKECINT__) || defined(G__DICTIONARY)
99 std::cerr <<
"GSLRootFinderDeriv - Error : Algorithm requirs derivatives" << std::endl;
122 bool Solve(
int maxIter = 100,
double absTol = 1
E-8,
double relTol = 1
E-10);
132 const char *
Name()
const;
int Iterate()
iterate (return GSL_SUCCESS in case of successful iteration)
Interface (abstract class) for generic functions objects of one-dimension Provides a method to evalua...
double Root() const
Returns the previously calculated root.
bool Solve(int maxIter=100, double absTol=1E-8, double relTol=1E-10)
Find the root (return false if failed)
class to wrap a gsl_function_fdf (with derivatives)
Interface (abstract class) for one-dimensional functions providing a gradient calculation.
GSLFunctionDerivWrapper * fFunction
void SetSolver(GSLRootFdFSolver *s)
Interface for finding function roots of one-dimensional functions.
bool SetFunction(const IGradFunction &f, double xstart)
Sets the function for algorithms using derivatives.
Class for adapting any C++ functor class to C function pointers used by GSL.
GSLRootFinderDeriv & operator=(const GSLRootFinderDeriv &)
Root-Finder with derivatives implementation class using GSL.
virtual bool SetFunction(const ROOT::Math::IGradFunction &, double)
Sets the function for algorithms using derivatives.
void(* GSLFdFPointer)(double, void *, double *, double *)
Base class for GSL Root-Finding algorithms for one dimensional functions which use function derivativ...
double(* GSLFuncPointer)(double, void *)
typedef void((*Func_t)())
const char * Name() const
Return name of root finder algorithm.
int Status() const
Return the status of last root finding.
int Iterations() const
Return number of iterations.
virtual ~GSLRootFinderDeriv()