CMS 3D CMS Logo

HistoPoissonLikelihoodRatio.h
Go to the documentation of this file.
1 #ifndef PhysicsTools_Utilities_HistoPoissonLikelihoodRatio_h
2 #define PhysicsTools_Utilities_HistoPoissonLikelihoodRatio_h
4 #include <vector>
5 #include <cmath>
6 #include "TH1.h"
7 #include "TMath.h"
8 
9 namespace fit {
10  template <typename T>
12  public:
14  HistoPoissonLikelihoodRatio(T &t, TH1 *histo, double rangeMin, double rangeMax)
15  : t_(&t), rangeMin_(rangeMin), rangeMax_(rangeMax) {
16  nBins_ = histo->GetNbinsX();
17  xMin_ = histo->GetXaxis()->GetXmin();
18  xMax_ = histo->GetXaxis()->GetXmax();
19  deltaX_ = (xMax_ - xMin_) / nBins_;
20  for (size_t i = 0; i < nBins_; ++i) {
21  cont_.push_back(histo->GetBinContent(i + 1));
22  }
23  }
24  double operator()() const {
25  double chi2lambda = 0;
26  for (size_t i = 0; i < nBins_; ++i) {
27  double x = xMin_ + (i + .5) * deltaX_;
28  if ((x > rangeMin_) && (x < rangeMax_)) {
29  double nu = (*t_)(x);
30  if (nu > 0 && cont_[i] > 0)
31  chi2lambda += nu - cont_[i] + cont_[i] * log(cont_[i] / nu);
32  }
33  }
34  chi2lambda *= 2;
35  return chi2lambda;
36  }
37  void setHistos(TH1 *histo) {
38  nBins_ = histo->GetNbinsX();
39  xMin_ = histo->GetXaxis()->GetXmin();
40  xMax_ = histo->GetXaxis()->GetXmax();
41  deltaX_ = (xMax_ - xMin_) / nBins_;
42  }
43  size_t numberOfBins() const {
44  size_t fullBins = 0;
45  for (size_t i = 0; i < nBins_; ++i) {
46  double x = xMin_ + (i + .5) * deltaX_;
47  if ((x > rangeMin_) && (x < rangeMax_))
48  fullBins++;
49  }
50  return fullBins;
51  }
52  T &function() { return *t_; }
53  const T &function() const { return *t_; }
54 
55  private:
56  T *t_;
58  size_t nBins_;
59  double xMin_, xMax_, deltaX_;
60  std::vector<double> cont_;
61  };
62 
63  template <typename T>
65  static void print(double amin, unsigned int numberOfFreeParameters, const HistoPoissonLikelihoodRatio<T> &f) {
66  unsigned int ndof = f.numberOfBins() - numberOfFreeParameters;
67  std::cout << "chi-squared/n.d.o.f. = " << amin << "/" << ndof << " = " << amin / ndof
68  << "; prob: " << TMath::Prob(amin, ndof) << std::endl;
69  }
70  };
71 } // namespace fit
72 
73 #endif
mps_fire.i
i
Definition: mps_fire.py:428
fit::HistoPoissonLikelihoodRatio::HistoPoissonLikelihoodRatio
HistoPoissonLikelihoodRatio(T &t, TH1 *histo, double rangeMin, double rangeMax)
Definition: HistoPoissonLikelihoodRatio.h:14
f
double f[11][100]
Definition: MuScleFitUtils.cc:78
gather_cfg.cout
cout
Definition: gather_cfg.py:144
timingPdfMaker.histo
histo
Definition: timingPdfMaker.py:279
fit::HistoPoissonLikelihoodRatio::rangeMin_
double rangeMin_
Definition: HistoPoissonLikelihoodRatio.h:57
ndof
Definition: HIMultiTrackSelector.h:49
fit::HistoPoissonLikelihoodRatio::nBins_
size_t nBins_
Definition: HistoPoissonLikelihoodRatio.h:58
fit::HistoPoissonLikelihoodRatio::deltaX_
double deltaX_
Definition: HistoPoissonLikelihoodRatio.h:59
fit::HistoPoissonLikelihoodRatio
Definition: HistoPoissonLikelihoodRatio.h:11
fit::HistoPoissonLikelihoodRatio::operator()
double operator()() const
Definition: HistoPoissonLikelihoodRatio.h:24
fit::RootMinuitResultPrinter< HistoPoissonLikelihoodRatio< T > >::print
static void print(double amin, unsigned int numberOfFreeParameters, const HistoPoissonLikelihoodRatio< T > &f)
Definition: HistoPoissonLikelihoodRatio.h:65
fit::HistoPoissonLikelihoodRatio::cont_
std::vector< double > cont_
Definition: HistoPoissonLikelihoodRatio.h:60
fit::HistoPoissonLikelihoodRatio::rangeMax_
double rangeMax_
Definition: HistoPoissonLikelihoodRatio.h:57
fit::HistoPoissonLikelihoodRatio::t_
T * t_
Definition: HistoPoissonLikelihoodRatio.h:56
fit::HistoPoissonLikelihoodRatio::numberOfBins
size_t numberOfBins() const
Definition: HistoPoissonLikelihoodRatio.h:43
RootMinuitResultPrinter.h
T
long double T
Definition: Basic3DVectorLD.h:48
fit::HistoPoissonLikelihoodRatio::HistoPoissonLikelihoodRatio
HistoPoissonLikelihoodRatio()
Definition: HistoPoissonLikelihoodRatio.h:13
fit::HistoPoissonLikelihoodRatio::setHistos
void setHistos(TH1 *histo)
Definition: HistoPoissonLikelihoodRatio.h:37
dqm-mbProfile.log
log
Definition: dqm-mbProfile.py:17
fit::HistoPoissonLikelihoodRatio::xMin_
double xMin_
Definition: HistoPoissonLikelihoodRatio.h:59
fit::RootMinuitResultPrinter
Definition: RootMinuitResultPrinter.h:8
submitPVValidationJobs.t
string t
Definition: submitPVValidationJobs.py:644
fit
Definition: CombinedChiSquaredLikelihood.h:6
fit::HistoPoissonLikelihoodRatio::xMax_
double xMax_
Definition: HistoPoissonLikelihoodRatio.h:59