GRSISort "v4.0.0.5"
An extension of the ROOT analysis Framework
Loading...
Searching...
No Matches
TABPeak.h
Go to the documentation of this file.
1#ifndef TABPEAK_H
2#define TABPEAK_H
3
4/** \addtogroup Fitting Fitting & Analysis
5 * @{
6 */
7
8#include <cstdarg>
9
10#include "TF1.h"
11
12#include "TSinglePeak.h"
13
14/////////////////////////////////////////////////////////////////
15///
16/// \class TABPeak
17///
18/// This class is used to fit Addback peaks in data
19///
20/////////////////////////////////////////////////////////////////
21
22class TABPeak : public TSinglePeak {
23public:
24 // ctors and dtors
25 TABPeak() = default;
26 explicit TABPeak(Double_t centroid) { Centroid(centroid); }
27 TABPeak(const TABPeak&) = default;
28 TABPeak(TABPeak&&) noexcept = default;
29 TABPeak& operator=(const TABPeak&) = default;
30 TABPeak& operator=(TABPeak&&) noexcept = default;
31 ~TABPeak() = default;
32
33 void InitParNames() override;
34 void InitializeParameters(TH1* hist, const double& rangeLow, const double& rangeHigh) override;
35
36 void Centroid(const Double_t& centroid) override;
37
38 Double_t Centroid() const override;
39 Double_t CentroidErr() const override;
40 Double_t Width() const override;
41 Double_t Sigma() const override;
42 Double_t SigmaErr() const override { return GetFitFunction()->GetParError(GetFitFunction()->GetParNumber("sigma")); }
43
44 void DrawComponents(Option_t* opt = "") override;
45
46protected:
47 Double_t PeakFunction(Double_t* dim, Double_t* par) override;
48 Double_t BackgroundFunction(Double_t* dim, Double_t* par) override;
49
50private:
51 static Double_t OneHitPeakFunction(Double_t* dim, Double_t* par);
52 static Double_t TwoHitPeakFunction(Double_t* dim, Double_t* par);
53 Double_t OneHitPeakOnGlobalFunction(Double_t* dim, Double_t* par);
54 Double_t TwoHitPeakOnGlobalFunction(Double_t* dim, Double_t* par);
55
56 TF1* fOneHitOnGlobal{nullptr};
57 TF1* fTwoHitOnGlobal{nullptr};
58
59public:
60 /// \cond CLASSIMP
61 ClassDefOverride(TABPeak, 2) // NOLINT(readability-else-after-return)
62 /// \endcond
63};
64/*! @} */
65#endif
TH1D * hist
Definition UserFillObj.h:3
TF1 * fTwoHitOnGlobal
Definition TABPeak.h:57
Double_t CentroidErr() const override
Definition TABPeak.cxx:64
void DrawComponents(Option_t *opt="") override
Definition TABPeak.cxx:129
Double_t Sigma() const override
Definition TABPeak.cxx:74
Double_t Centroid() const override
Definition TABPeak.cxx:59
Double_t SigmaErr() const override
Definition TABPeak.h:42
void InitParNames() override
Definition TABPeak.cxx:14
static Double_t OneHitPeakFunction(Double_t *dim, Double_t *par)
Definition TABPeak.cxx:84
void InitializeParameters(TH1 *hist, const double &rangeLow, const double &rangeHigh) override
Definition TABPeak.cxx:24
static Double_t TwoHitPeakFunction(Double_t *dim, Double_t *par)
Definition TABPeak.cxx:94
Double_t BackgroundFunction(Double_t *dim, Double_t *par) override
Definition TABPeak.cxx:116
TABPeak()=default
TABPeak(Double_t centroid)
Definition TABPeak.h:26
Double_t Width() const override
Definition TABPeak.cxx:69
Double_t TwoHitPeakOnGlobalFunction(Double_t *dim, Double_t *par)
Definition TABPeak.cxx:111
TF1 * fOneHitOnGlobal
Definition TABPeak.h:56
TABPeak(const TABPeak &)=default
Double_t PeakFunction(Double_t *dim, Double_t *par) override
Definition TABPeak.cxx:79
Double_t OneHitPeakOnGlobalFunction(Double_t *dim, Double_t *par)
Definition TABPeak.cxx:106
TABPeak(TABPeak &&) noexcept=default
TF1 * GetFitFunction() const
Definition TSinglePeak.h:72