Skip to content

Commit

Permalink
leave the possibility to plot TH1s instead of TProfiles, off, by default
Browse files Browse the repository at this point in the history
  • Loading branch information
mmusich committed May 27, 2023
1 parent b7f2883 commit e8c139d
Show file tree
Hide file tree
Showing 2 changed files with 85 additions and 13 deletions.
8 changes: 7 additions & 1 deletion DQMOffline/Alignment/interface/DiMuonMassBiasClient.h
Original file line number Diff line number Diff line change
Expand Up @@ -81,10 +81,12 @@ class DiMuonMassBiasClient : public DQMEDHarvester {
void bookMEs(DQMStore::IBooker& ibooker);
void getMEsToHarvest(DQMStore::IGetter& igetter);
diMuonMassBias::fitOutputs fitLineShape(TH1* hist, const bool& fitBackground = false) const;
void fitAndFill(std::pair<std::string, MonitorElement*> toHarvest, DQMStore::IBooker& iBooker);
void fitAndFillProfile(std::pair<std::string, MonitorElement*> toHarvest, DQMStore::IBooker& iBooker);
void fitAndFillHisto(std::pair<std::string, MonitorElement*> toHarvest, DQMStore::IBooker& iBooker);

// data members
const std::string TopFolder_;
const bool useTH1s_;
const bool fitBackground_;
const bool useRooCBShape_;
const bool useRooCMSShape_;
Expand All @@ -98,6 +100,10 @@ class DiMuonMassBiasClient : public DQMEDHarvester {
std::vector<std::string> MEtoHarvest_;

// the histograms to be filled
std::map<std::string, MonitorElement*> meanHistos_;
std::map<std::string, MonitorElement*> widthHistos_;

// the profiles to be filled
std::map<std::string, MonitorElement*> meanProfiles_;
std::map<std::string, MonitorElement*> widthProfiles_;

Expand Down
90 changes: 78 additions & 12 deletions DQMOffline/Alignment/src/DiMuonMassBiasClient.cc
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
//-----------------------------------------------------------------------------------
DiMuonMassBiasClient::DiMuonMassBiasClient(edm::ParameterSet const& iConfig)
: TopFolder_(iConfig.getParameter<std::string>("FolderName")),
useTH1s_(iConfig.getParameter<bool>("useTH1s")),
fitBackground_(iConfig.getParameter<bool>("fitBackground")),
useRooCBShape_(iConfig.getParameter<bool>("useRooCBShape")),
useRooCMSShape_(iConfig.getParameter<bool>("useRooCMSShape")),
Expand Down Expand Up @@ -83,16 +84,14 @@ void DiMuonMassBiasClient::bookMEs(DQMStore::IBooker& iBooker)
const auto& nxbins = ME->getNbinsX();
const auto& xmin = ME->getAxisMin(1);
const auto& xmax = ME->getAxisMax(1);
const auto& ymin = ME->getAxisMin(2);
const auto& ymax = ME->getAxisMax(2);

MonitorElement* meanToBook =
iBooker.bookProfile(("Mean" + key), (title + ";" + xtitle + ";" + ytitle), nxbins, xmin, xmax, ymin, ymax);
meanProfiles_.insert({key, meanToBook});
iBooker.book1D(("Mean" + key), (title + ";" + xtitle + ";" + ytitle), nxbins, xmin, xmax);
meanHistos_.insert({key, meanToBook});

MonitorElement* sigmaToBook = iBooker.bookProfile(
("Sigma" + key), (title + ";" + xtitle + ";" + "#sigma of " + ytitle), nxbins, xmin, xmax, ymin, ymax);
widthProfiles_.insert({key, sigmaToBook});
MonitorElement* sigmaToBook =
iBooker.book1D(("Sigma" + key), (title + ";" + xtitle + ";" + "#sigma of " + ytitle), nxbins, xmin, xmax);
widthHistos_.insert({key, sigmaToBook});
}
}

Expand All @@ -116,7 +115,8 @@ void DiMuonMassBiasClient::getMEsToHarvest(DQMStore::IGetter& iGetter)
}

//-----------------------------------------------------------------------------------
void DiMuonMassBiasClient::fitAndFill(std::pair<std::string, MonitorElement*> toHarvest, DQMStore::IBooker& iBooker)
void DiMuonMassBiasClient::fitAndFillProfile(std::pair<std::string, MonitorElement*> toHarvest,
DQMStore::IBooker& iBooker)
//-----------------------------------------------------------------------------------
{
const auto& key = toHarvest.first;
Expand All @@ -137,8 +137,6 @@ void DiMuonMassBiasClient::fitAndFill(std::pair<std::string, MonitorElement*> to
const auto& nxbins = ME->getNbinsX();
const auto& xmin = ME->getAxisMin(1);
const auto& xmax = ME->getAxisMax(1);
//const auto& ymin = ME->getAxisMin(2);
//const auto& ymax = ME->getAxisMax(2);

TProfile* p_mean = new TProfile(
("Mean" + key).c_str(), (title + ";" + xtitle + ";#LT" + ytitle + "#GT").c_str(), nxbins, xmin, xmax, "g");
Expand Down Expand Up @@ -171,6 +169,14 @@ void DiMuonMassBiasClient::fitAndFill(std::pair<std::string, MonitorElement*> to

// fill the mean profiles
const Measurement1D& bias = results.getBias();

// ============================================= DISCLAIMER ================================================
// N.B. this is sort of a hack in order to fill arbitrarily both central values and error bars of a TProfile.
// Choosing the option "g" in the constructor the bin error will be 1/sqrt(W(j)), where W(j) is the sum of weights.
// Filling the sum of weights with the 1 / err^2, the bin error automatically becomes "err".
// In order to avoid the central value to be shifted, that's divided by 1 / err^2 as well.
// For more information, please consult the https://root.cern.ch/doc/master/classTProfile.html

p_mean->SetBinContent(bin, bias.value() / (bias.error() * bias.error()));
p_mean->SetBinEntries(bin, 1. / (bias.error() * bias.error()));

Expand All @@ -181,6 +187,8 @@ void DiMuonMassBiasClient::fitAndFill(std::pair<std::string, MonitorElement*> to

// fill the width profiles
const Measurement1D& width = results.getWidth();

// see discussion above
p_width->SetBinContent(bin, width.value() / (width.error() * width.error()));
p_width->SetBinEntries(bin, 1. / (width.error() * width.error()));
}
Expand All @@ -197,17 +205,74 @@ void DiMuonMassBiasClient::fitAndFill(std::pair<std::string, MonitorElement*> to
delete p_width;
}

//-----------------------------------------------------------------------------------
void DiMuonMassBiasClient::fitAndFillHisto(std::pair<std::string, MonitorElement*> toHarvest,
DQMStore::IBooker& iBooker)
//-----------------------------------------------------------------------------------
{
const auto& key = toHarvest.first;
const auto& ME = toHarvest.second;

if (debugMode_)
edm::LogPrint("DiMuonMassBiasClient") << "dealing with key: " << key << std::endl;

if (ME == nullptr) {
edm::LogError("DiMuonMassBiasClient") << "could not find MonitorElement for key: " << key << std::endl;
return;
}

TH2F* bareHisto = ME->getTH2F();
for (int bin = 1; bin <= ME->getNbinsX(); bin++) {
const auto& xaxis = bareHisto->GetXaxis();
const auto& low_edge = xaxis->GetBinLowEdge(bin);
const auto& high_edge = xaxis->GetBinUpEdge(bin);

if (debugMode_)
edm::LogPrint("DiMuonMassBiasClient") << "dealing with bin: " << bin << " range: (" << std::setprecision(2)
<< low_edge << "," << std::setprecision(2) << high_edge << ")";
TH1D* Proj = bareHisto->ProjectionY(Form("%s_proj_%i", key.c_str(), bin), bin, bin);
Proj->SetTitle(Form("%s #in (%.2f,%.2f), bin: %i", Proj->GetTitle(), low_edge, high_edge, bin));

diMuonMassBias::fitOutputs results = fitLineShape(Proj);

if (results.isInvalid()) {
edm::LogWarning("DiMuonMassBiasClient") << "the current bin has invalid data" << std::endl;
continue;
}

// fill the mean profiles
const Measurement1D& bias = results.getBias();
meanHistos_[key]->setBinContent(bin, bias.value());
meanHistos_[key]->setBinError(bin, bias.error());

// fill the width profiles
const Measurement1D& width = results.getWidth();
widthHistos_[key]->setBinContent(bin, width.value());
widthHistos_[key]->setBinError(bin, width.error());
}
}

//-----------------------------------------------------------------------------------
void DiMuonMassBiasClient::dqmEndJob(DQMStore::IBooker& ibooker, DQMStore::IGetter& igetter)
//-----------------------------------------------------------------------------------
{
edm::LogInfo("DiMuonMassBiasClient") << "DiMuonMassBiasClient::endLuminosityBlock";

getMEsToHarvest(igetter);
//bookMEs(ibooker);

// book the histograms upfront
if (useTH1s_) {
bookMEs(ibooker);
}

for (const auto& element : harvestTargets_) {
this->fitAndFill(element, ibooker);
if (!useTH1s_) {
// if using profiles
this->fitAndFillProfile(element, ibooker);
} else {
// if using histograms
this->fitAndFillHisto(element, ibooker);
}
}
}

Expand Down Expand Up @@ -352,6 +417,7 @@ void DiMuonMassBiasClient::fillDescriptions(edm::ConfigurationDescriptions& desc
{
edm::ParameterSetDescription desc;
desc.add<std::string>("FolderName", "DiMuonMassBiasMonitor");
desc.add<bool>("useTH1s", false);
desc.add<bool>("fitBackground", false);
desc.add<bool>("useRooCMSShape", false);
desc.add<bool>("useRooCBShape", false);
Expand Down

0 comments on commit e8c139d

Please sign in to comment.