ATLAS Offline Software
Loading...
Searching...
No Matches
CaloIsolationDecorAlg.cxx
Go to the documentation of this file.
1/*
2 Copyright (C) 2002-2025 CERN for the benefit of the ATLAS collaboration
3*/
8
9//**********************************************************************
10namespace DerivationFramework {
11CaloIsolationDecorAlg::CaloIsolationDecorAlg(const std::string& name, ISvcLocator* pSvcLocator) :
12 AthReentrantAlgorithm(name, pSvcLocator) {}
13//**********************************************************************
14
16 ATH_CHECK(m_isoTool.retrieve());
17
18 m_calo_corr.calobitset.set(static_cast<unsigned int>(xAOD::Iso::coreCone));
19 m_calo_corr.calobitset.set(static_cast<unsigned int>(xAOD::Iso::pileupCorrection));
20 // isolation types to run. The ptcones each also imply the respective ptvarcone.
21
22 ATH_CHECK(m_trk_key.initialize());
23 for (const std::string& decor : m_trkSel_Decors) m_trkSel_keys.emplace_back(m_trk_key, decor);
24 ATH_CHECK(m_trkSel_keys.initialize());
25 m_topocone20_key = std::string{"topoetcone20"} + (m_customName.empty() ? "" : "_") + m_customName;
26 m_topocone30_key = std::string{"topoetcone30"} + (m_customName.empty() ? "" : "_") + m_customName;
27 m_topocone40_key = std::string{"topoetcone40"} + (m_customName.empty() ? "" : "_") + m_customName;
28 m_corr_key = std::string{"etcore_correction"} + (m_customName.empty() ? "" : "_") + m_customName;
29 ATH_CHECK(m_topocone20_key.initialize());
30 ATH_CHECK(m_topocone30_key.initialize());
31 ATH_CHECK(m_topocone40_key.initialize());
32 ATH_CHECK(m_corr_key.initialize());
33 ATH_MSG_DEBUG("Decorate " << m_trk_key.fullKey() << " using '" << m_customName << "' as suffix.");
34 return StatusCode::SUCCESS;
35}
36
37//**********************************************************************
38
39StatusCode CaloIsolationDecorAlg::execute(const EventContext& ctx) const {
41 if (!tracks.isValid()) {
42 ATH_MSG_FATAL("Failed to retrieve track collection " << m_trk_key.fullKey());
43 return StatusCode::FAILURE;
44 }
45
46
49
50 std::vector<SelDecorator> selDecors;
52 selDecors.emplace_back(key, ctx);
53 }
54
55 FloatDecor topocone40_dec{makeHandle<float>(ctx, m_topocone40_key, -Gaudi::Units::GeV)};
56 FloatDecor topocone30_dec{makeHandle<float>(ctx, m_topocone30_key, -Gaudi::Units::GeV)};
57 FloatDecor topocone20_dec{makeHandle<float>(ctx, m_topocone20_key, -Gaudi::Units::GeV)};
58 FloatDecor corr_dec{makeHandle<float>(ctx, m_corr_key)};
59
60 for (const xAOD::TrackParticle* trk : *tracks) {
61 if (trk->pt() < m_pt_min) continue;
62 if (!selDecors.empty() && std::find_if(selDecors.begin(), selDecors.end(), [trk](const SelDecorator& dec){
63 return dec(*trk);
64 }) == selDecors.end()) continue;
65 ATH_MSG_DEBUG("Recomputing isolation by hand");
66 xAOD::CaloIsolation resultCalo;
67 if (!m_isoTool->caloTopoClusterIsolation(resultCalo, *trk, m_calo_isos, m_calo_corr)) {
68 ATH_MSG_ERROR("Failed to compute calorimeter isolation");
69 return StatusCode::FAILURE;
70 }
71 topocone40_dec(*trk) = resultCalo.etcones[0];
72 topocone30_dec(*trk) = resultCalo.etcones[1];
73 topocone20_dec(*trk) = resultCalo.etcones[2];
74 corr_dec(*trk) = resultCalo.coreCorrections[xAOD::Iso::coreCone][xAOD::Iso::coreEnergy];
75 }
76 return StatusCode::SUCCESS;
77}
78}
79//**********************************************************************
#define ATH_CHECK
Evaluate an expression and check for errors.
#define ATH_MSG_ERROR(x)
#define ATH_MSG_FATAL(x)
#define ATH_MSG_DEBUG(x)
Handle class for reading from StoreGate.
Handle class for adding a decoration to an object.
An algorithm that can be simultaneously executed in multiple threads.
Gaudi::Property< std::vector< std::string > > m_trkSel_Decors
Optional list of decorators to select only the good tracks for the isolation decoration.
Gaudi::Property< float > m_pt_min
pt threshold to apply
SG::ReadHandleKey< xAOD::TrackParticleContainer > m_trk_key
track collection to decorate
SG::WriteDecorHandleKey< xAOD::TrackParticleContainer > m_topocone20_key
SG::WriteDecorHandleKey< xAOD::TrackParticleContainer > m_corr_key
CaloIsolationDecorAlg(const std::string &name, ISvcLocator *pSvcLocator)
Constructor with parameters:
SG::WriteDecorHandleKey< xAOD::TrackParticleContainer > m_topocone30_key
SG::ReadDecorHandleKeyArray< xAOD::TrackParticleContainer > m_trkSel_keys
StatusCode initialize() override
Athena algorithm's Hooks.
std::vector< xAOD::Iso::IsolationType > m_calo_isos
ToolHandle< xAOD::ICaloTopoClusterIsolationTool > m_isoTool
Athena configured tools.
StatusCode execute(const EventContext &ctx) const override
SG::WriteDecorHandleKey< xAOD::TrackParticleContainer > m_topocone40_key
Property holding a SG store/key/clid/attr name from which a ReadDecorHandle is made.
Handle class for reading a decoration on an object.
virtual bool isValid() override final
Can the handle be successfully dereferenced?
Handle class for adding a decoration to an object.
THE reconstruction tool.
SG::WriteDecorHandle< ContType, dType > makeHandle(const EventContext &ctx, const SG::WriteDecorHandleKey< ContType > &key, const dType &defValue=dType{})
TrackParticle_v1 TrackParticle
Reference the current persistent version:
std::vector< float > etcones
std::map< Iso::IsolationCaloCorrection, std::map< Iso::IsolationCorrectionParameter, float > > coreCorrections