Skip to content

Commit

Permalink
[THRatio] fix again division of histograms with different labels (#2428)
Browse files Browse the repository at this point in the history
The ROOT `Divide()` function requires that bin labels, if present, are the
same in the numerator and the denominator, otherwise it prints a warning
message.

The changes in this commit fix the copy of bin labels from numerator to
denominator in the THxRatio `update()` functions.
  • Loading branch information
aferrero2707 authored Sep 24, 2024
1 parent 91b041e commit ea62b68
Show file tree
Hide file tree
Showing 2 changed files with 72 additions and 18 deletions.
37 changes: 31 additions & 6 deletions Modules/Common/include/Common/TH1Ratio.inl
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,28 @@
namespace o2::quality_control_modules::common
{

namespace th1ratio_internal
{

template <class T>
bool copyBinLabels(const T* srcHist, T* destHist)
{
if (srcHist->GetXaxis()->GetNbins() != destHist->GetXaxis()->GetNbins()) {
return false;
}

bool result = false;
if (srcHist->GetXaxis()->GetLabels()) {
for (int bin = 1; bin <= srcHist->GetXaxis()->GetNbins(); bin++) {
destHist->GetXaxis()->SetBinLabel(bin, srcHist->GetXaxis()->GetBinLabel(bin));
}
result = true;
}
return result;
}

}

template<class T>
TH1Ratio<T>::TH1Ratio()
: T(),
Expand Down Expand Up @@ -149,6 +171,13 @@ void TH1Ratio<T>::update()
T::GetXaxis()->Set(mHistoNum->GetXaxis()->GetNbins(), mHistoNum->GetXaxis()->GetXmin(), mHistoNum->GetXaxis()->GetXmax());
T::SetBinsLength();

// Copy bin labels between histograms.
// If set, the bin labels of the ratio histograms are copied to the numerator.
// If instead the numerator has bin labels they are copied to the ratio plot.
if (!th1ratio_internal::copyBinLabels<T>(this, mHistoNum)) {
th1ratio_internal::copyBinLabels<T>(mHistoNum, this);
}

if (mUniformScaling) {
T::Add(mHistoNum);
double entries = mHistoDen->GetBinContent(1);
Expand All @@ -160,12 +189,8 @@ void TH1Ratio<T>::update()
T::Scale(norm, "nosw2");
}
} else {
if (T::GetXaxis()->GetLabels()) {
// copy bin labels to denominator before dividing, otherwise we get a warning
for (int bin = 1; bin <= T::GetXaxis()->GetNbins(); bin++) {
mHistoDen->GetXaxis()->SetBinLabel(bin, T::GetXaxis()->GetBinLabel(bin));
}
}
// copy bin labels from numerator to denominator (if needed) before dividing, otherwise we get a warning from ROOT
th1ratio_internal::copyBinLabels<T>(mHistoNum, mHistoDen);
T::Divide(mHistoNum, mHistoDen, 1.0, 1.0, mBinominalErrors ? "B" : "");
}
}
Expand Down
53 changes: 41 additions & 12 deletions Modules/Common/include/Common/TH2Ratio.inl
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,37 @@
namespace o2::quality_control_modules::common
{

namespace th2ratio_internal
{

template <class T>
bool copyBinLabels(const T* srcHist, T* destHist)
{
if (srcHist->GetXaxis()->GetNbins() != destHist->GetXaxis()->GetNbins()) {
return false;
}
if (srcHist->GetYaxis()->GetNbins() != destHist->GetYaxis()->GetNbins()) {
return false;
}

bool result = false;
if (srcHist->GetXaxis()->GetLabels()) {
for (int bin = 1; bin <= srcHist->GetXaxis()->GetNbins(); bin++) {
destHist->GetXaxis()->SetBinLabel(bin, srcHist->GetXaxis()->GetBinLabel(bin));
}
result = true;
}
if (srcHist->GetYaxis()->GetLabels()) {
for (int bin = 1; bin <= srcHist->GetYaxis()->GetNbins(); bin++) {
destHist->GetYaxis()->SetBinLabel(bin, srcHist->GetYaxis()->GetBinLabel(bin));
}
result = true;
}
return result;
}

}

template<class T>
TH2Ratio<T>::TH2Ratio()
: T(),
Expand Down Expand Up @@ -150,6 +181,13 @@ void TH2Ratio<T>::update()
T::GetYaxis()->Set(mHistoNum->GetYaxis()->GetNbins(), mHistoNum->GetYaxis()->GetXmin(), mHistoNum->GetYaxis()->GetXmax());
T::SetBinsLength();

// Copy bin labels between histograms.
// If set, the bin labels of the ratio histograms are copied to the numerator.
// If instead the numerator has bin labels they are copied to the ratio plot.
if (!th2ratio_internal::copyBinLabels<T>(this, mHistoNum)) {
th2ratio_internal::copyBinLabels<T>(mHistoNum, this);
}

if (mUniformScaling) {
T::Add(mHistoNum);
double entries = mHistoDen->GetBinContent(1, 1);
Expand All @@ -161,17 +199,8 @@ void TH2Ratio<T>::update()
T::Scale(norm, "nosw2");
}
} else {
// copy bin labels to denominator before dividing, otherwise we get a warning
if (T::GetXaxis()->GetLabels()) {
for (int bin = 1; bin <= T::GetXaxis()->GetNbins(); bin++) {
mHistoDen->GetXaxis()->SetBinLabel(bin, T::GetXaxis()->GetBinLabel(bin));
}
}
if (T::GetYaxis()->GetLabels()) {
for (int bin = 1; bin <= T::GetYaxis()->GetNbins(); bin++) {
mHistoDen->GetYaxis()->SetBinLabel(bin, T::GetYaxis()->GetBinLabel(bin));
}
}
// copy bin labels from numerator to denominator (if needed) before dividing, otherwise we get a warning from ROOT
th2ratio_internal::copyBinLabels<T>(mHistoNum, mHistoDen);
T::Divide(mHistoNum, mHistoDen, 1.0, 1.0, mBinominalErrors ? "B" : "");
}
}
Expand Down Expand Up @@ -278,7 +307,7 @@ Bool_t TH2Ratio<T>::Add(const TH1* h1, Double_t c1)

template<class T>
void TH2Ratio<T>::SetBins(Int_t nx, Double_t xmin, Double_t xmax,
Int_t ny, Double_t ymin, Double_t ymax)
Int_t ny, Double_t ymin, Double_t ymax)
{
getNum()->SetBins(nx, xmin, xmax, ny, ymin, ymax);
getDen()->SetBins(nx, xmin, xmax, ny, ymin, ymax);
Expand Down

0 comments on commit ea62b68

Please sign in to comment.