Get in memory an histogram from a root file and fit a user defined function.
Note that a user defined function must always be defined as in this example:
- first parameter: array of variables (in this example only 1-dimension)
- second parameter: array of parameters Note also that in case of user defined functions, one must set an initial value for each parameter.
****************************************
Minimizer is Minuit2 / Migrad
Chi2 = 36.7428
NDf = 47
Edm = 2.03167e-06
NCalls = 101
Constant = 797.969 +/- 6.79742
Mean_value = -7.42918e-05 +/- 0.00734861
Sigma = 0.998754 +/- 0.0071337
Integral of function = 1907.36
#include <cmath>
double fitf(
double *
x,
double *par)
{
double arg = 0;
if (par[2] != 0) arg = (
x[0] - par[1])/par[2];
double fitval = par[0]*std::exp(-0.5*arg*arg);
}
{
dir.Append(
"/hsimple.C");
dir.ReplaceAll(
"/./",
"/");
}
ROOT::Detail::TRangeCast< T, true > TRangeDynCast
TRangeDynCast is an adapter class that allows the typed iteration through a TCollection.
virtual Double_t Integral(Double_t a, Double_t b, Double_t epsrel=1.e-12)
IntegralOneDim or analytical integral.
virtual void SetParNames(const char *name0="", const char *name1="", const char *name2="", const char *name3="", const char *name4="", const char *name5="", const char *name6="", const char *name7="", const char *name8="", const char *name9="", const char *name10="")
Set up to 10 parameter names.
virtual void SetParameters(const Double_t *params)
A ROOT file is an on-disk file, usually with extension .root, that stores objects in a file-system-li...
1-D histogram with a float per channel (see TH1 documentation)
- Author
- Rene Brun
Definition in file myfit.C.