13 #ifndef ROOT_Math_Minimizer
14 #define ROOT_Math_Minimizer
16 #ifndef ROOT_Math_IFunction
20 #ifndef ROOT_Math_MinimizerOptions
24 #ifndef ROOT_Math_Util
28 #ifndef ROOT_Math_Error
44 class ParameterSettings;
118 if (
this == &rhs)
return *
this;
133 SetFunction(static_cast<const ::ROOT::Math::IMultiGenFunction &> (func));
138 template<
class VariableIterator>
139 int SetVariables(
const VariableIterator & begin,
const VariableIterator & end) {
140 unsigned int ivar = 0;
141 for ( VariableIterator vitr = begin; vitr != end; ++vitr) {
143 if (vitr->IsFixed() )
145 else if (vitr->IsDoubleBound() )
146 iret =
SetLimitedVariable(ivar, vitr->Name(), vitr->Value(), vitr->StepSize(), vitr->LowerLimit(), vitr->UpperLimit() );
147 else if (vitr->HasLowerLimit() )
149 else if (vitr->HasUpperLimit() )
152 iret =
SetVariable( ivar, vitr->Name(), vitr->Value(), vitr->StepSize() );
161 virtual bool SetVariable(
unsigned int ivar,
const std::string &
name,
double val,
double step) = 0;
173 MATH_WARN_MSG(
"Minimizer::SetLimitedVariable",
"Setting of limited variable not implemented - set as unlimited");
179 MATH_ERROR_MSG(
"Minimizer::SetFixedVariable",
"Setting of fixed variable not implemented");
185 MATH_ERROR_MSG(
"Minimizer::SetVariableValue",
"Set of a variable value not implemented");
193 while ( i <=
NDim() && ret) {
200 MATH_ERROR_MSG(
"Minimizer::SetVariableStepSize",
"Setting an existing variable step size not implemented");
206 MATH_ERROR_MSG(
"Minimizer::SetVariableLowerLimit",
"Setting an existing variable limit not implemented");
212 MATH_ERROR_MSG(
"Minimizer::SetVariableUpperLimit",
"Setting an existing variable limit not implemented");
222 MATH_ERROR_MSG(
"Minimizer::FixVariable",
"Fixing an existing variable not implemented");
228 MATH_ERROR_MSG(
"Minimizer::ReleaseVariable",
"Releasing an existing variable not implemented");
235 MATH_ERROR_MSG(
"Minimizer::IsFixedVariable",
"Quering an existing variable not implemented");
241 MATH_ERROR_MSG(
"Minimizer::GetVariableSettings",
"Quering an existing variable not implemented");
256 virtual double MinValue()
const = 0;
259 virtual const double *
X()
const = 0;
262 virtual double Edm()
const {
return -1; }
268 virtual unsigned int NCalls()
const {
return 0; }
275 virtual unsigned int NDim()
const = 0;
292 virtual double CovMatrix(
unsigned int ivar ,
unsigned int jvar )
const {
334 virtual double Correlation(
unsigned int i,
unsigned int j )
const {
357 virtual bool GetMinosError(
unsigned int ivar ,
double & errLow,
double & errUp,
int option = 0) {
358 MATH_ERROR_MSG(
"Minimizer::GetMinosError",
"Minos Error not implemented");
375 virtual bool Scan(
unsigned int ivar ,
unsigned int & nstep ,
double *
x ,
double *
y ,
387 virtual bool Contour(
unsigned int ivar ,
unsigned int jvar,
unsigned int & npoints,
388 double * xi ,
double * xj ) {
405 return std::string();
411 MATH_ERROR_MSG(
"Minimizer::VariableIndex",
"Getting variable index from name not implemented");
void SetDefaultOptions()
reset the defaut options (defined in MinimizerOptions)
Interface (abstract class) for multi-dimensional functions providing a gradient calculation.
void SetMaxIterations(unsigned int maxiter)
set maximum iterations (one iteration can have many function calls)
void SetPrintLevel(int level)
set print level
void SetErrorDef(double up)
set scale for calculating the errors
unsigned int MaxFunctionCalls() const
max number of function calls
void SetTolerance(double tol)
set the tolerance
void SetMaxIterations(unsigned int maxiter)
set maximum iterations (one iteration can have many function calls)
bool IsValidError() const
return true if Minimizer has performed a detailed error validation (e.g. run Hesse for Minuit) ...
Namespace for new ROOT classes and functions.
Minimizer & operator=(const Minimizer &rhs)
Assignment operator.
Class, describing value, limits and step size of the parameters Provides functionality also to set/re...
virtual bool ReleaseVariable(unsigned int ivar)
release an existing variable
virtual void SetFunction(const ROOT::Math::IMultiGradFunction &func)
set a function to minimize using gradient
int SetVariables(const VariableIterator &begin, const VariableIterator &end)
add variables . Return number of variables successfully added
unsigned int MaxIterations() const
max iterations
void SetOptions(const MinimizerOptions &opt)
set all options in one go
unsigned int MaxIterations() const
max iterations
int Strategy() const
strategy
double ErrorDef() const
error definition
virtual void PrintResults()
return reference to the objective function virtual const ROOT::Math::IGenFunction & Function() const ...
double Tolerance() const
absolute tolerance
void SetValidError(bool on)
flag to check if minimizer needs to perform accurate error analysis (e.g. run Hesse for Minuit) ...
virtual bool SetLowerLimitedVariable(unsigned int ivar, const std::string &name, double val, double step, double lower)
set a new lower limit variable (override if minimizer supports them )
Minimizer()
Default constructor.
void SetErrorDef(double err)
set error def
#define MATH_WARN_MSG(loc, str)
ClassImp(TIterator) Bool_t TIterator return false
Compare two iterator objects.
virtual double Correlation(unsigned int i, unsigned int j) const
return correlation coefficient between variable i and j.
int Status() const
status code of minimizer
virtual bool SetLimitedVariable(unsigned int ivar, const std::string &name, double val, double step, double lower, double upper)
set a new upper/lower limited variable (override if minimizer supports them ) otherwise as default se...
void ResetToDefaultOptions()
non-static methods for setting options
virtual void Clear()
reset for consecutive minimizations - implement if needed
double Tolerance() const
absolute tolerance
double Precision() const
precision in the objective funciton calculation (value <=0 means left to default) ...
virtual std::string VariableName(unsigned int ivar) const
get name of variables (override if minimizer support storing of variable names) return an empty strin...
void SetPrecision(double prec)
set the precision
virtual const double * Errors() const
return errors at the minimum
Abstract Minimizer class, defining the interface for the various minimizer (like Minuit2, Minuit, GSL, etc..) Plug-in's exist in ROOT to be able to instantiate the derived classes like ROOT::Math::GSLMinimizer or ROOT::Math::Minuit2Minimizer via the plug-in manager.
virtual double MinValue() const =0
return minimum function value
virtual bool SetVariableValues(const double *x)
set the values of all existing variables (array must be dimensioned to the size of the existing param...
virtual bool Minimize()=0
method to perform the minimization
virtual bool Contour(unsigned int ivar, unsigned int jvar, unsigned int &npoints, double *xi, double *xj)
find the contour points (xi, xj) of the function for parameter ivar and jvar around the minimum The c...
virtual bool SetVariableInitialRange(unsigned int, double, double)
set the initial range of an existing variable
virtual const double * X() const =0
return pointer to X values at the minimum
#define MATH_ERROR_MSG(loc, str)
virtual bool SetVariableValue(unsigned int ivar, double value)
set the value of an already existing variable
int PrintLevel() const
non-static methods for retrieving options
virtual bool IsFixedVariable(unsigned int ivar) const
query if an existing variable is fixed (i.e.
double ErrorDef() const
return the statistical scale used for calculate the error is typically 1 for Chi2 and 0...
virtual void SetFunction(const ROOT::Math::IMultiGenFunction &func)=0
set the function to minimize
void SetMaxFunctionCalls(unsigned int maxfcn)
set maximum of function calls
unsigned int MaxFunctionCalls() const
max number of function calls
Minimizer(const Minimizer &)
Copy constructor.
virtual bool SetFixedVariable(unsigned int ivar, const std::string &name, double val)
set a new fixed variable (override if minimizer supports them )
virtual bool SetVariableUpperLimit(unsigned int ivar, double upper)
set the upper-limit of an already existing variable
int Strategy() const
strategy
virtual bool GetCovMatrix(double *covMat) const
Fill the passed array with the covariance matrix elements if the variable is fixed or const the value...
int PrintLevel() const
minimizer configuration parameters
virtual ~Minimizer()
Destructor (no operations)
virtual unsigned int NDim() const =0
this is <= Function().NDim() which is the total number of variables (free+ constrained ones) ...
virtual const double * MinGradient() const
return pointer to gradient values at the minimum
double Precision() const
precision of minimizer in the evaluation of the objective function ( a value <=0 corresponds to the l...
virtual bool FixVariable(unsigned int ivar)
fix an existing variable
void SetMaxFunctionCalls(unsigned int maxfcn)
set maximum of function calls
virtual bool SetUpperLimitedVariable(unsigned int ivar, const std::string &name, double val, double step, double upper)
set a new upper limit variable (override if minimizer supports them )
void SetTolerance(double tol)
set the tolerance
virtual bool ProvidesError() const
minimizer provides error and error matrix
virtual unsigned int NIterations() const
number of iterations to reach the minimum
TFitResultPtr Fit(FitObject *h1, TF1 *f1, Foption_t &option, const ROOT::Math::MinimizerOptions &moption, const char *goption, ROOT::Fit::DataRange &range)
virtual bool GetMinosError(unsigned int ivar, double &errLow, double &errUp, int option=0)
minos error for variable i, return false if Minos failed or not supported and the lower and upper err...
double func(double *x, double *p)
MinimizerOptions fOptions
void SetStrategy(int strategyLevel)
set the strategy
virtual double GlobalCC(unsigned int ivar) const
return global correlation coefficient for variable i This is a number between zero and one which give...
Namespace for new Math classes and functions.
virtual int CovMatrixStatus() const
return status of covariance matrix using Minuit convention {0 not calculated 1 approximated 2 made po...
virtual bool SetVariableLowerLimit(unsigned int ivar, double lower)
set the lower-limit of an already existing variable
virtual bool SetVariableLimits(unsigned int ivar, double lower, double upper)
set the limits of an already existing variable
virtual bool SetVariable(unsigned int ivar, const std::string &name, double val, double step)=0
set a new free variable
void SetStrategy(int stra)
set the strategy
virtual double Edm() const
return expected distance reached from the minimum (re-implement if minimizer provides it ...
virtual bool Scan(unsigned int ivar, unsigned int &nstep, double *x, double *y, double xmin=0, double xmax=0)
scan function minimum for variable i.
virtual double CovMatrix(unsigned int ivar, unsigned int jvar) const
return covariance matrices element for variables ivar,jvar if the variable is fixed the return value ...
virtual unsigned int NCalls() const
number of function calls to reach the minimum
void SetPrecision(double prec)
set in the minimizer the objective function evaluation precision ( a value <=0 means the minimizer wi...
void SetPrintLevel(int level)
set print level
virtual bool SetVariableStepSize(unsigned int ivar, double value)
set the step size of an already existing variable
Documentation for the abstract class IBaseFunctionMultiDim.
virtual bool Hesse()
perform a full calculation of the Hessian matrix for error calculation
virtual MinimizerOptions Options() const
retrieve the minimizer options (implement derived class if needed)
virtual unsigned int NFree() const
number of free variables (real dimension of the problem) this is <= Function().NDim() which is the to...
virtual int VariableIndex(const std::string &name) const
get index of variable given a variable given a name return -1 if variable is not found ...
virtual bool GetVariableSettings(unsigned int ivar, ROOT::Fit::ParameterSettings &pars) const
get variable settings in a variable object (like ROOT::Fit::ParamsSettings)
virtual bool GetHessianMatrix(double *hMat) const
Fill the passed array with the Hessian matrix elements The Hessian matrix is the matrix of the second...