25double background(
double *
x,
double *par) {
26 return par[0] + par[1]*
x[0] + par[2]*
x[0]*
x[0];
31double lorentzianPeak(
double *
x,
double *par) {
38double fitFunction(
double *
x,
double *par) {
39 return background(
x,par) + lorentzianPeak(
x,&par[3]);
47 double data[nBins] = { 6, 1,10,12, 6,13,23,22,15,21,
48 23,26,36,25,27,35,40,44,66,81,
49 75,57,48,45,46,41,35,36,53,32,
50 40,37,38,31,36,44,42,37,32,32,
51 43,44,35,33,33,39,29,41,32,44,
52 26,39,29,35,32,21,21,15,25,15};
55 c1->SetFrameFillColor(41);
59 "Lorentzian Peak on Quadratic Background",60,0,3);
67 TF1 *fitFcn =
new TF1(
"fitFcn",fitFunction,0,3,6);
78 histo->
Fit(
"fitFcn",
"0");
84 histo->
Fit(
"fitFcn",
"V+",
"ep");
87 TF1 *backFcn =
new TF1(
"backFcn",background,0,3,3);
89 TF1 *signalFcn =
new TF1(
"signalFcn",lorentzianPeak,0,3,3);
98 backFcn->
Draw(
"same");
101 signalFcn->
Draw(
"same");
107 legend->
AddEntry(histo,
"Data",
"lpe");
108 legend->
AddEntry(backFcn,
"Background fit",
"l");
109 legend->
AddEntry(signalFcn,
"Signal fit",
"l");
110 legend->
AddEntry(fitFcn,
"Global Fit",
"l");
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void data
virtual void SetLineWidth(Width_t lwidth)
Set the line width.
virtual void SetLineColor(Color_t lcolor)
Set the line color.
virtual void SetMarkerStyle(Style_t mstyle=1)
Set the marker style.
virtual void SetMarkerSize(Size_t msize=1)
Set the marker size.
virtual void SetTextFont(Font_t tfont=62)
Set the text font.
virtual void SetTextSize(Float_t tsize=1)
Set the text size.
virtual void SetNpx(Int_t npx=100)
Set the number of points used to draw the function.
virtual Double_t * GetParameters() const
void Draw(Option_t *option="") override
Draw this function with its current attributes.
virtual void SetParameters(const Double_t *params)
virtual void SetParameter(Int_t param, Double_t value)
1-D histogram with a float per channel (see TH1 documentation)
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.
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...
virtual void SetStats(Bool_t stats=kTRUE)
Set statistics option on/off.
This class displays a legend box (TPaveText) containing several legend entries.
TLegendEntry * AddEntry(const TObject *obj, const char *label="", Option_t *option="lpf")
Add a new entry to this legend.
void Draw(Option_t *option="") override
Draw this legend with its current attributes.
Short_t Max(Short_t a, Short_t b)
Returns the largest of a and b.