ATLAS Offline Software
Loading...
Searching...
No Matches
EventCutFlowHistAlg.cxx
Go to the documentation of this file.
1/*
2 Copyright (C) 2002-2025 CERN for the benefit of the ATLAS collaboration
3*/
4
6
7
8//
9// includes
10//
11
13
15#include <TH1.h>
16
17//
18// method implementations
19//
20
21namespace CP
22{
23
24 StatusCode EventCutFlowHistAlg ::
25 initialize ()
26 {
30 ANA_CHECK (m_systematicsList.initialize());
31 ANA_CHECK (m_selectionNameSvc.retrieve());
32
33 // Total label
34 m_labels.push_back ("total");
35 // Individual labels
36 for (size_t i{}; i < m_selections.size(); i++) {
37 std::string label = m_selections.at(i).getSelectionName();
38 // Check if the string ends with "_%SYS%"
39 if (label.size() >= 6 && label.substr(label.size() - 6) == "_%SYS%") {
40 // Remove "_%SYS%" from the end of the string
41 label.erase(label.size() - 6);
42 }
43 m_labels.push_back (std::move(label));
44 m_allCutsNum ++;
45 }
46 assert (m_allCutsNum+1 == m_labels.size());
47
48 return StatusCode::SUCCESS;
49 }
50
51 StatusCode EventCutFlowHistAlg ::
52 execute ()
53 {
54 for (const auto& sys : m_systematicsList.systematicsVector())
55 {
56 const xAOD::EventInfo *evtInfo = nullptr;
57 ANA_CHECK (m_eventInfoHandle.retrieve (evtInfo, sys));
58
59 auto histIter = m_hist.find (sys);
60 if (histIter == m_hist.end())
61 {
62 std::string name;
63 ANA_CHECK (m_systematicsList.service().makeSystematicsName (name, m_histPattern, sys));
64
65 std::string title = m_histTitle.value();
66 if (!sys.empty())
67 title += " (" + sys.name() + ")";
68 ANA_CHECK (book (TH1F (name.c_str(), title.c_str(), m_allCutsNum+1, 0, m_allCutsNum+1)));
69
70 m_hist.insert (std::make_pair (sys, hist (name)));
71 histIter = m_hist.find (sys);
72 assert (histIter != m_hist.end());
73
74 for (unsigned i = 0; i < m_allCutsNum+1; i++)
75 {
76 histIter->second->GetXaxis()->SetBinLabel(i + 1, m_labels[i].c_str());
77 }
78 }
79
80 if (m_preselection.getBool (*evtInfo, sys)) {
81 unsigned cutIndex = 1;
82 histIter->second->Fill (0);
83 for (size_t i{}; i < m_selections.size(); i++) {
84 if (m_selections.at(i).getBool (*evtInfo, sys) > 0) {
85 histIter->second->Fill (cutIndex);
86 }
87 cutIndex++;
88 }
89 }
90 }
91 return StatusCode::SUCCESS;
92 }
93}
#define ANA_CHECK(EXP)
check whether the given expression was successful
StatusCode book(const TH1 &hist, const std::string &tDir="", const std::string &stream="")
Simplify the booking and registering (into THistSvc) of histograms.
TH1 * hist(const std::string &histName, const std::string &tDir="", const std::string &stream="")
Simplify the retrieval of registered histograms of any type.
std::vector< std::string > m_labels
histogram bin labels
SysListHandle m_systematicsList
the systematics list we run
Gaudi::Property< std::string > m_histTitle
the histogram title to use
SysReadSelectionHandleArray m_selections
the input object selections for which to create a cutflow
std::unordered_map< CP::SystematicSet, TH1 * > m_hist
the created histograms
SysReadHandle< xAOD::EventInfo > m_eventInfoHandle
the jet collection we run on
SysReadSelectionHandle m_preselection
the preselection we apply to our input
Gaudi::Property< std::string > m_histPattern
the pattern for histogram names
ServiceHandle< ISelectionNameSvc > m_selectionNameSvc
the selection name service
unsigned m_allCutsNum
the total number of cuts configured (needed to configure histograms)
std::string label(const std::string &format, int i)
Definition label.h:19
Select isolated Photons, Electrons and Muons.
EventInfo_v1 EventInfo
Definition of the latest event info version.