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