ATLAS Offline Software
Loading...
Searching...
No Matches
ObjectCutFlowHistAlg.cxx
Go to the documentation of this file.
1/*
2 Copyright (C) 2002-2025 CERN for the benefit of the ATLAS collaboration
3*/
4
7
8
9//
10// includes
11//
12
14
15#include <TH1.h>
16
17//
18// method implementations
19//
20
21namespace CP
22{
23
24 StatusCode ObjectCutFlowHistAlg ::
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 ObjectCutFlowHistAlg ::
52 execute ()
53 {
54 for (const auto& sys : m_systematicsList.systematicsVector())
55 {
56 const xAOD::IParticleContainer *input = nullptr;
57 ANA_CHECK (m_inputHandle.retrieve (input, 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 for (const xAOD::IParticle *particle : *input) {
81 if (m_preselection.getBool (*particle, sys)) {
82 unsigned cutIndex = 1;
83 histIter->second->Fill (0);
84 bool selected{true};
85 for (size_t i{}; i < m_selections.size(); i++) {
86 if ((!m_forceCutSequence.value() || selected) && m_selections.at(i).getBool (*particle, sys) > 0) {
87 histIter->second->Fill (cutIndex);
88 } else {
89 selected = false;
90 }
91 cutIndex++;
92 }
93 }
94 }
95
96 }
97 return StatusCode::SUCCESS;
98 }
99}
#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
SysReadSelectionHandleArray m_selections
the input object selections for which to create a cutflow
unsigned m_allCutsNum
the total number of cuts configured (needed to configure histograms)
Gaudi::Property< bool > m_forceCutSequence
force cut sequence
SysReadHandle< xAOD::IParticleContainer > m_inputHandle
the particle collection we run on
Gaudi::Property< std::string > m_histTitle
the histogram title to use
SysReadSelectionHandle m_preselection
the preselection we apply to our input
ServiceHandle< ISelectionNameSvc > m_selectionNameSvc
the selection name service
SysListHandle m_systematicsList
the systematics list we run
std::unordered_map< CP::SystematicSet, TH1 * > m_hist
the created histograms
Gaudi::Property< std::string > m_histPattern
the pattern for histogram names
Class providing the definition of the 4-vector interface.
std::string label(const std::string &format, int i)
Definition label.h:19
Select isolated Photons, Electrons and Muons.
DataVector< IParticle > IParticleContainer
Simple convenience declaration of IParticleContainer.