14#ifndef TGO4FITPEAKFINDER_H
15#define TGO4FITPEAKFINDER_H
41 TGo4FitPeakFinder(
const char *Name,
const char *DataName =
nullptr, Bool_t ClearModels = kFALSE, Int_t PolOrder = -1);
55 void SetupForFirst(Double_t MaxAmplFactor, Double_t MinWidth, Double_t MaxWidth);
59 void SetupForThird(Double_t NoiseFactor, Double_t NoiseMinimum, Int_t ChannelSum);
97 void Print(Option_t *option =
"")
const override;
116 Double_t AmplThreshold,
126 Int_t MaxNumPeaks = 50,
127 Int_t ChannelSum = 1,
128 Double_t NoiseFactor = 2.,
129 Double_t NoiseMinimum = 10.,
130 Int_t MinimasOrder = -1);
136 Double_t *weight =
nullptr,
137 Double_t *backgr =
nullptr,
138 Char_t *use =
nullptr);
140 static void DefinePolynomEx(Int_t size, Double_t *bins, Double_t *scales, Double_t *weight, Double_t *backgr,
141 Int_t lbound, Int_t rbound, TArrayD& Coef);
143 static Double_t
CalcPolynom(
const TArrayD &Coef, Double_t x);
Basic abstract class for representing data, which should be fitted.
void Set0MinWidth(Double_t min)
Double_t Get0MaxAmplFactor() const
Double_t Get1LineWidth() const
virtual ~TGo4FitPeakFinder()
Destroys TGo4FitPeakFinder object.
void SetupForThird(Double_t NoiseFactor, Double_t NoiseMinimum, Int_t ChannelSum)
const char * GetDataName() const
void Print(Option_t *option="") const override
Print information on standard output.
void ROOTPeakFinder(TGo4Fitter *fitter, TGo4FitData *data, Int_t PolynomOrder, Double_t Sigma)
void DoAction(TGo4FitterAbstract *Fitter) override
Bool_t GetUsePolynom() const
static void DefinePolynomEx(Int_t size, Double_t *bins, Double_t *scales, Double_t *weight, Double_t *backgr, Int_t lbound, Int_t rbound, TArrayD &Coef)
Int_t GetPeakFinderType() const
void SetPolynomOrder(Int_t order)
Bool_t CanChangeFitter() const override
void SetupForSecond(Double_t LineWidth)
Bool_t GetClearModels() const
Double_t Get2NoiseFactor() const
void SergeyLinevPeakFinder(TGo4Fitter *fitter, TGo4FitData *data, Int_t PolOrder, Double_t AmplThreshold, Double_t MinWidth, Double_t MaxWidth)
Perform simple peak finder algorithm.
void Set0MaxWidth(Double_t max)
Double_t Get0MaxWidth() const
void Set0MaxAmplFactor(Double_t factor)
static Double_t CalcPolynom(const TArrayD &Coef, Double_t x)
void SetPeakFinderType(Int_t typ)
void HansEsselPeakFinder(TGo4Fitter *fitter, TGo4FitData *data, Int_t MaxNumPeaks=50, Int_t ChannelSum=1, Double_t NoiseFactor=2., Double_t NoiseMinimum=10., Int_t MinimasOrder=-1)
Hans Essel (c) peak finder.
Int_t Get2ChannelSum() const
void Set2NoiseFactor(Double_t factor)
Double_t Get2NoiseMinimum() const
void SetDataName(const char *name)
void SetClearModels(Bool_t clear)
TGo4FitPeakFinder()
Default constructor.
void Set1LineWidth(Double_t width)
void Set2ChannelSum(Int_t sum)
void SetUsePolynom(Bool_t use)
void SetupPolynomialBackground(Int_t PolynomOrder)
Double_t Get0MinWidth() const
void Set2NoiseMinimum(Double_t min)
Double_t fd0MaxAmplFactor
Int_t GetPolynomOrder() const
static void DefinePolynom(Int_t size, Double_t *bins, Double_t *scales, TArrayD &Coef, Double_t *weight=nullptr, Double_t *backgr=nullptr, Char_t *use=nullptr)
void SetupForFirst(Double_t MaxAmplFactor, Double_t MinWidth, Double_t MaxWidth)
TGo4FitterAction()
Default constructor.
Central class of Go4Fit package.