28 SigScale, SigSigma, SigMean,
31const std::map<ParIndex_t,std::string> parNames{
32 {Bkg0,
"Bkg0"}, {Bkg1,
"Bkg1"}, {Bkg2,
"Bkg2"},
33 {SigScale,
"Gauss scale"}, {SigSigma,
"Gauss #sigma"}, {SigMean,
"Gauss #mu"}
38double background(
double *
x,
double *par) {
39 return par[Bkg0] + par[Bkg1]*
x[0] + par[Bkg2]*
x[0]*
x[0];
43double signal(
double *
x,
double *par) {
44 return par[SigScale]*
TMath::Gaus(
x[0], par[SigMean], par[SigSigma],
true);
49double fitFunction(
double *
x,
double *par) {
50 return background(
x, par) + signal(
x, par);
57 TF1 fitFcn(
"fitFcn",fitFunction,fitxmin,fitxmax,N_PAR);
59 fitFcn.SetLineWidth(2);
60 fitFcn.SetLineColor(
kBlue);
63 for (
auto& idx_name : parNames) {
64 fitFcn.SetParName(idx_name.first, idx_name.second.c_str());
68 fitFcn.SetParameters(30,0,0,50.,0.1,1.);
70 histo->
Fit(
"fitFcn",
"VR+",
"ep");
74 TF1 backFcn(
"backFcn",background,fitxmin,fitxmax,N_PAR);
75 backFcn.SetLineColor(
kRed);
76 TF1 signalFcn(
"signalFcn",signal,fitxmin,fitxmax,N_PAR);
77 signalFcn.SetLineColor(
kBlue);
78 signalFcn.SetNpx(500);
82 fitFcn.GetParameters(par);
84 backFcn.SetParameters(par);
85 backFcn.DrawCopy(
"same");
87 signalFcn.SetParameters(par);
88 signalFcn.SetLineColor(
kGreen);
89 signalFcn.DrawCopy(
"same");
92 const double integral = signalFcn.Integral(0.,3.);
93 std::cout <<
"number of signal events = " << integral/binwidth <<
" " << binwidth<< std::endl;
96 TLegend legend(0.15,0.7,0.28,0.85);
97 legend.SetTextFont(72);
98 legend.SetTextSize(0.03);
99 legend.AddEntry(histo,
"Data",
"lpe");
100 legend.AddEntry(&backFcn,
"Bgd",
"l");
101 legend.AddEntry(&signalFcn,
"Sig",
"l");
102 legend.AddEntry(&fitFcn,
"Sig+Bgd",
"l");
104 histo->
Draw(
"esame");
109void CreateRootFile(){
111 const int nBins = 60;
112 double data[nBins] = { 6, 1,10,12, 6,13,23,22,15,21,
113 23,26,36,25,27,35,40,44,66,81,
114 75,57,43,37,36,31,35,36,43,32,
115 40,37,38,33,36,44,42,37,32,32,
116 43,44,35,33,33,39,29,41,32,44,
117 26,39,29,35,32,21,21,15,25,15};
119 TFile*
f =
new TFile(
"exampleRootFile.root",
"RECREATE");
120 TH1D *histo =
new TH1D(
"histo",
"Gauss Peak on Quadratic Background;x;Events/0.05",60,0,3);
127void FitHistoInFile() {
135 TCanvas *
c1 =
new TCanvas(
"c1",
"Fitting Demo of Histogram in File",10,10,700,500);
138 TH1D* histo=
nullptr;
139 f->GetObject(
"histo",histo);
141 std::cout <<
"histo not found" << std::endl;
147 FitRoutine(
c1,histo, fitxmin, fitxmax,
"FitHistoInFile.pdf");
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void data
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char filename
R__EXTERN TStyle * gStyle
virtual void SetMarkerStyle(Style_t mstyle=1)
Set the marker style.
virtual void SetMarkerSize(Size_t msize=1)
Set the marker size.
virtual void SetRange(Int_t first=0, Int_t last=0)
Set the viewing range for the axis using bin numbers.
virtual Double_t GetBinWidth(Int_t bin) const
Return bin width.
A ROOT file is composed of a header, followed by consecutive data records (TKey instances) with a wel...
1-D histogram with a double per channel (see TH1 documentation)}
TH1 is the base class of all histogram classes in ROOT.
virtual TFitResultPtr Fit(const char *formula, Option_t *option="", Option_t *goption="", Double_t xmin=0, Double_t xmax=0)
Fit histogram with function fname.
void Draw(Option_t *option="") override
Draw this histogram with options.
virtual void SetBinContent(Int_t bin, Double_t content)
Set bin content see convention for numbering bins in TH1::GetBin In case the bin number is greater th...
This class displays a legend box (TPaveText) containing several legend entries.
void SetOptStat(Int_t stat=1)
The type of information printed in the histogram statistics box can be selected via the parameter mod...
void SetOptFit(Int_t fit=1)
The type of information about fit parameters printed in the histogram statistics box can be selected ...
Double_t Gaus(Double_t x, Double_t mean=0, Double_t sigma=1, Bool_t norm=kFALSE)
Calculates a gaussian function with mean and sigma.