13 #ifndef ROOT_Minuit2_HybridMinimizer 14 #define ROOT_Minuit2_HybridMinimizer 16 #include "Math/Minimizer.h" 17 #include "Minuit2/MnUserParameterState.h" 18 #include "Math/IFunctionfwd.h" 19 #include "Minuit2/MinosError.h" 20 #include "Minuit2/ModularFunctionMinimizer.h" 21 #include "Minuit2/FumiliMinimizer.h" 27 class ModularFunctionMinimizer;
29 class FunctionMinimum;
79 void Clear()
override;
137 const double *
X()
const override;
147 unsigned int NDim()
const override {
return fDim; }
151 unsigned int NFree()
const override {
return fState.VariableParameters(); }
157 const double *
Errors()
const override;
166 double CovMatrix(
unsigned int i,
unsigned int j)
const override;
201 double Correlation(
unsigned int i,
unsigned int j)
const override;
209 double GlobalCC(
unsigned int i)
const override;
223 bool GetMinosError(
unsigned int i,
double &errLow,
double &errUp,
int = 0)
override;
229 bool Scan(
unsigned int i,
unsigned int &nstep,
double *x,
double *y,
double xmin = 0,
double xmax = 0)
override;
235 bool Contour(
unsigned int i,
unsigned int j,
unsigned int &
npoints,
double *
xi,
double *xj)
override;
247 bool Hesse()
override;
256 const ROOT::Minuit2::MnUserParameterState &
State() {
return fState; }
276 ROOT::Minuit2::MnUserParameterState
fState;
bool SetVariable(unsigned int ivar, const std::string &name, double val, double step) override
set free variable
unsigned int NCalls() const override
number of function calls to reach the minimum
bool Contour(unsigned int i, unsigned int j, unsigned int &npoints, double *xi, double *xj) override
virtual const ROOT::Minuit2::FCNBase * GetFCN() const
ROOT::Minuit2::MnUserParameterState fState
ROOT::Minuit2::FCNBase * fMinuitFCN
ROOT::Minuit2::FunctionMinimum * fMinimum
HybridMinimizer(EMinimizerType type=kMigrad)
const double * MinGradient() const override
return pointer to gradient values at the minimum
void SetFunction(const ROOT::Math::IMultiGenFunction &func) override
set the function to minimize
bool SetVariableValue(unsigned int ivar, double val) override
set variable
bool SetLowerLimitedVariable(unsigned int ivar, const std::string &name, double val, double step, double lower) override
set lower limit variable (override if minimizer supports them )
unsigned int NFree() const override
void SetMinimizerType(EMinimizerType type)
bool GetMinosError(unsigned int i, double &errLow, double &errUp, int=0) override
std::vector< double > fErrors
const ROOT::Minuit2::MnUserParameterState & State()
return the minimizer state (containing values, step size , etc..)
const double * Errors() const override
return errors at the minimum
bool SetFixedVariable(unsigned int, const std::string &, double) override
set fixed variable (override if minimizer supports them )
double Edm() const override
return expected distance reached from the minimum
bool ExamineMinimum(const ROOT::Minuit2::FunctionMinimum &min)
examine the minimum result
bool GetCovMatrix(double *cov) const override
~HybridMinimizer() override
virtual void SetMinimizer(ROOT::Minuit2::ModularFunctionMinimizer *m)
double GlobalCC(unsigned int i) const override
bool GetHessianMatrix(double *h) const override
virtual const ROOT::Minuit2::ModularFunctionMinimizer * GetMinimizer() const
bool SetVariableValues(const double *val) override
double Correlation(unsigned int i, unsigned int j) const override
unsigned int NDim() const override
std::string VariableName(unsigned int ivar) const override
get name of variables (override if minimizer support storing of variable names)
HybridMinimizer & operator=(const HybridMinimizer &rhs)
double MinValue() const override
return minimum function value
bool ProvidesError() const override
minimizer provides error and error matrix
int CovMatrixStatus() const override
int VariableIndex(const std::string &name) const override
std::vector< double > fValues
ROOT::Minuit2::ModularFunctionMinimizer * fMinimizer
bool SetLimitedVariable(unsigned int ivar, const std::string &name, double val, double step, double, double) override
set upper/lower limited variable (override if minimizer supports them )
double CovMatrix(unsigned int i, unsigned int j) const override
const double * X() const override
return pointer to X values at the minimum
void PrintResults() override
print result of minimization
The Signals That Services Can Subscribe To This is based on ActivityRegistry h
Helper function to determine trigger accepts.
bool Scan(unsigned int i, unsigned int &nstep, double *x, double *y, double xmin=0, double xmax=0) override
bool SetUpperLimitedVariable(unsigned int ivar, const std::string &name, double val, double step, double upper) override
set upper limit variable (override if minimizer supports them )