ATLAS Offline Software
Loading...
Searching...
No Matches
DerivationFramework::JetGhostThinning Class Reference

#include <JetGhostThinning.h>

Inheritance diagram for DerivationFramework::JetGhostThinning:
Collaboration diagram for DerivationFramework::JetGhostThinning:

Public Member Functions

 JetGhostThinning (const std::string &t, const std::string &n, const IInterface *p)
virtual ~JetGhostThinning ()
virtual StatusCode initialize () override
virtual StatusCode finalize () override
virtual StatusCode doThinning () const override

Private Attributes

StringProperty m_streamName
SG::ReadHandleKey< xAOD::JetContainerm_jetSGKey
StringProperty m_selectionString
StringProperty m_ghostName
StringProperty m_ghostContainerName
SG::ThinningHandleKey< xAOD::IParticleContainerm_ghostContainerKey

Detailed Description

Definition at line 26 of file JetGhostThinning.h.

Constructor & Destructor Documentation

◆ JetGhostThinning()

DerivationFramework::JetGhostThinning::JetGhostThinning ( const std::string & t,
const std::string & n,
const IInterface * p )

Definition at line 15 of file JetGhostThinning.cxx.

17 : base_class(t, n, p) {}

◆ ~JetGhostThinning()

DerivationFramework::JetGhostThinning::~JetGhostThinning ( )
virtualdefault

Member Function Documentation

◆ doThinning()

StatusCode DerivationFramework::JetGhostThinning::doThinning ( ) const
overridevirtual

Definition at line 70 of file JetGhostThinning.cxx.

70 {
71 const EventContext &ctx = Gaudi::Hive::currentContext();
72
73 // Retrieve jet collection
74 SG::ReadHandle<xAOD::JetContainer> jets(m_jetSGKey, ctx);
75 if (!jets.isValid()) {
76 ATH_MSG_ERROR("Failed to retrieve jet collection " << m_jetSGKey.key());
77 return StatusCode::FAILURE;
78 }
79
80 // Get the jets that pass the selection
81 std::vector<const xAOD::Jet*> selectedJets;
82
83 if (!m_selectionString.empty()) {
84 // Use the expression parser
85 std::vector<int> entries = m_parser->evaluateAsVector();
86 if (entries.size() != jets->size()) {
87 ATH_MSG_ERROR("Selection string evaluation size mismatch!");
88 return StatusCode::FAILURE;
89 }
90
91 for (size_t i = 0; i < jets->size(); ++i) {
92 if (entries[i] == 1) {
93 selectedJets.push_back((*jets)[i]);
94 }
95 }
96 } else {
97 // Keep all jets
98 for (const auto* jet : *jets) {
99 selectedJets.push_back(jet);
100 }
101 }
102
103 ATH_MSG_DEBUG("Number of selected jets: " << selectedJets.size()
104 << " out of " << jets->size());
105
106 // Get thinning handle for the ghost container
107 SG::ThinningHandle<xAOD::IParticleContainer> ghostContainer(m_ghostContainerKey, ctx);
108
109 if (!ghostContainer.isValid()) {
110 ATH_MSG_WARNING("Ghost container " << m_ghostContainerKey.key() << " not valid, skipping");
111 return StatusCode::SUCCESS;
112 }
113
114 size_t nObjects = ghostContainer->size();
115 std::vector<bool> mask(nObjects, false);
116 const int maskSize = static_cast<int>(mask.size());
117
118 // Create accessor for the ghost association
120
121 size_t nGhostLinks = 0;
122
123 // Loop over selected jets and mark ghost objects to keep using their indices
124 for (const auto* jet : selectedJets) {
125 if (!jet) continue;
126
127 // Check if this jet has the ghost association
128 if (!ghostAcc.isAvailable(*jet)) {
129 ATH_MSG_VERBOSE("Jet does not have ghost association: " << m_ghostName);
130 continue;
131 }
132
133 // Get the ghost links
134 const std::vector<ElementLink<xAOD::IParticleContainer>>& ghostLinks = ghostAcc(*jet);
135
136 ATH_MSG_VERBOSE("Jet has " << ghostLinks.size() << " ghost objects");
137
138 // Mark all valid ghost objects using their indices
139 for (const auto& link : ghostLinks) {
140 if (!link.isValid()) continue;
141
142 int index = link.index();
143 if (index < 0) {
144 ATH_MSG_VERBOSE(" Ghost link has negative index, skipping");
145 continue;
146 }
147
148 if (index < maskSize) {
149 mask[index] = true;
150 nGhostLinks++;
151 const xAOD::IParticle* ghostObj = *link;
152 if (ghostObj) {
153 ATH_MSG_VERBOSE(" Ghost object at index " << index << ": pt=" << ghostObj->pt()
154 << ", eta=" << ghostObj->eta());
155 }
156 }
157 }
158 }
159
160 size_t nKept = std::count(mask.begin(), mask.end(), true);
161 ATH_MSG_DEBUG("Found " << nGhostLinks << " ghost links from selected jets");
162 ATH_MSG_DEBUG("Ghost container " << m_ghostContainerKey.key() << ": keeping "
163 << nKept << " out of " << nObjects << " objects");
164
165 ghostContainer.keep(mask);
166
167 return StatusCode::SUCCESS;
168}
#define ATH_MSG_ERROR(x)
#define ATH_MSG_VERBOSE(x)
#define ATH_MSG_WARNING(x)
#define ATH_MSG_DEBUG(x)
SG::ThinningHandleKey< xAOD::IParticleContainer > m_ghostContainerKey
SG::ReadHandleKey< xAOD::JetContainer > m_jetSGKey
SG::ConstAccessor< T, ALLOC > ConstAccessor
Definition AuxElement.h:569
virtual double eta() const =0
The pseudorapidity ( ) of the particle.
virtual double pt() const =0
The transverse momentum ( ) of the particle.
double entries
Definition listroot.cxx:49
str index
Definition DeMoScan.py:362
const uint32_t maskSize

◆ finalize()

StatusCode DerivationFramework::JetGhostThinning::finalize ( )
overridevirtual

Definition at line 64 of file JetGhostThinning.cxx.

64 {
65 ATH_MSG_VERBOSE("finalize() ...");
66 return StatusCode::SUCCESS;
67}

◆ initialize()

StatusCode DerivationFramework::JetGhostThinning::initialize ( )
overridevirtual

Definition at line 23 of file JetGhostThinning.cxx.

23 {
24 ATH_MSG_VERBOSE("initialize() ...");
25
26 // Check that we have a jet container
27 if (m_jetSGKey.empty()) {
28 ATH_MSG_FATAL("No jet collection provided!");
29 return StatusCode::FAILURE;
30 }
31
32 ATH_CHECK(m_jetSGKey.initialize());
33 ATH_MSG_INFO("Using " << m_jetSGKey.key() << " as the jet collection");
34
35 // Initialize the selection string parser if provided
36 if (!m_selectionString.empty()) {
37 ATH_CHECK(initializeParser(m_selectionString));
38 ATH_MSG_INFO("Jet selection string: " << m_selectionString);
39 }
40
41 // Check that we have a ghost name
42 if (m_ghostName.empty()) {
43 ATH_MSG_FATAL("No ghost name provided!");
44 return StatusCode::FAILURE;
45 }
46
47 // Check that we have a ghost container name
48 if (m_ghostContainerName.empty()) {
49 ATH_MSG_FATAL("No ghost container name provided!");
50 return StatusCode::FAILURE;
51 }
52
53 // Initialize thinning handle key
54 m_ghostContainerKey = SG::ThinningHandleKey<xAOD::IParticleContainer>(m_ghostContainerName);
56
57 ATH_MSG_INFO("Thinning ghost objects:");
58 ATH_MSG_INFO(" Ghost name: " << m_ghostName);
59 ATH_MSG_INFO(" Ghost container: " << m_ghostContainerName);
60
61 return StatusCode::SUCCESS;
62}
#define ATH_CHECK
Evaluate an expression and check for errors.
#define ATH_MSG_FATAL(x)
#define ATH_MSG_INFO(x)

Member Data Documentation

◆ m_ghostContainerKey

SG::ThinningHandleKey<xAOD::IParticleContainer> DerivationFramework::JetGhostThinning::m_ghostContainerKey
private

Definition at line 52 of file JetGhostThinning.h.

◆ m_ghostContainerName

StringProperty DerivationFramework::JetGhostThinning::m_ghostContainerName
private
Initial value:
{
this, "GhostContainerName", "", "Name of the ghost object container (e.g., CaloCalFwdTopoTowers)"}

Definition at line 49 of file JetGhostThinning.h.

49 {
50 this, "GhostContainerName", "", "Name of the ghost object container (e.g., CaloCalFwdTopoTowers)"};

◆ m_ghostName

StringProperty DerivationFramework::JetGhostThinning::m_ghostName
private
Initial value:
{
this, "GhostName", "", "Name of the ghost association (e.g., GhostTower)"}

Definition at line 46 of file JetGhostThinning.h.

46 {
47 this, "GhostName", "", "Name of the ghost association (e.g., GhostTower)"};

◆ m_jetSGKey

SG::ReadHandleKey<xAOD::JetContainer> DerivationFramework::JetGhostThinning::m_jetSGKey
private
Initial value:
{
this, "JetKey", "", "SG key for jet container"}

Definition at line 40 of file JetGhostThinning.h.

40 {
41 this, "JetKey", "", "SG key for jet container"};

◆ m_selectionString

StringProperty DerivationFramework::JetGhostThinning::m_selectionString
private
Initial value:
{
this, "SelectionString", "", "Selection string for jets"}

Definition at line 43 of file JetGhostThinning.h.

43 {
44 this, "SelectionString", "", "Selection string for jets"};

◆ m_streamName

StringProperty DerivationFramework::JetGhostThinning::m_streamName
private
Initial value:
{this, "StreamName", "",
"Name of the stream being thinned"}

Definition at line 37 of file JetGhostThinning.h.

37 {this, "StreamName", "",
38 "Name of the stream being thinned"};

The documentation for this class was generated from the following files: