Algorithm to fix AOD muons.
More...
#include <MuonAODFixAlg.h>
Algorithm to fix AOD muons.
- Author
- Edward Moyse Edwar.nosp@m.d.Mo.nosp@m.yse@c.nosp@m.ern..nosp@m.ch
Definition at line 30 of file MuonAODFixAlg.h.
◆ StoreGateSvc_t
◆ MuonAODFixAlg()
| xAOD::MuonAODFixAlg::MuonAODFixAlg |
( |
const std::string & | name, |
|
|
ISvcLocator * | svcLoc ) |
Regular algorithm constructor.
Definition at line 23 of file MuonAODFixAlg.cxx.
26 {
27
29 }
AthAlgorithm()
Default constructor:
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T, V, H > &t)
std::string m_containerName
The key for the output xAOD::CaloClusterContainer.
◆ declareGaudiProperty()
specialization for handling Gaudi::Property<SG::VarHandleKey>
Definition at line 156 of file AthCommonDataStore.h.
158 {
161 hndl.documentation());
162
163 }
◆ declareProperty()
Definition at line 145 of file AthCommonDataStore.h.
145 {
148 }
Gaudi::Details::PropertyBase & declareGaudiProperty(Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
specialization for handling Gaudi::Property<SG::VarHandleKey>
◆ detStore()
◆ evtStore()
◆ execute()
| StatusCode xAOD::MuonAODFixAlg::execute |
( |
| ) |
|
|
virtual |
Function executing the algorithm.
Definition at line 37 of file MuonAODFixAlg.cxx.
37 {
38
39
40 const SG::DataProxy*
proxy =
43 if (!proxy) {
46 return StatusCode::SUCCESS;
47 }
48
50
51 if (
proxy->isConst()) {
55
57 auto store = std::make_unique<xAOD::MuonAuxContainer>();
58 muons->setStore (
store.get());
59 for (
const xAOD::Muon* oldMuon : *originalMuons) {
62 *muons->
back() = *oldMuon;
64 }
67 true, false) );
70 true, false) );
71 } else {
74 for (
auto muon: *muons){
76 }
77 }
78
79 return StatusCode::SUCCESS;
80 }
#define ATH_CHECK
Evaluate an expression and check for errors.
#define ATH_MSG_WARNING(x)
ServiceHandle< StoreGateSvc > & evtStore()
const T * back() const
Access the last element in the collection as an rvalue.
value_type push_back(value_type pElem)
Add an element to the end of the collection.
void fixMuon(xAOD::Muon &muon) const
Muon_v1 Muon
Reference the current persistent version:
MuonContainer_v1 MuonContainer
Definition of the current "Muon container version".
◆ extraDeps_update_handler()
Add StoreName to extra input/output deps as needed.
use the logic of the VarHandleKey to parse the DataObjID keys supplied via the ExtraInputs and ExtraOuputs Properties to add the StoreName if it's not explicitly given
◆ extraOutputDeps()
| const DataObjIDColl & AthAlgorithm::extraOutputDeps |
( |
| ) |
const |
|
overridevirtualinherited |
Return the list of extra output dependencies.
This list is extended to include symlinks implied by inheritance relations.
Definition at line 50 of file AthAlgorithm.cxx.
51{
52
53
56 }
57 return Algorithm::extraOutputDeps();
58}
DataObjIDColl m_extendedExtraObjects
◆ fixMuon()
| void xAOD::MuonAODFixAlg::fixMuon |
( |
xAOD::Muon & | muon | ) |
const |
Definition at line 82 of file MuonAODFixAlg.cxx.
82 {
83
85 if (!tp) {
87 return;
88 }
90 static const SG::Accessor<ElementLink<xAOD::TruthParticleContainer> > truthParticleLinkAcc ("truthParticleLink");
91 static const SG::Accessor<int> truthTypeAcc ("truthType");
92 static const SG::Accessor<int> truthOriginAcc ("truthOrigin");
93 if (truthParticleLinkAcc.isAvailable (*tp)) {
94 truthParticleLinkAcc (
muon) = truthParticleLinkAcc (*tp);
95 truthTypeAcc (
muon) = truthTypeAcc (*tp);
96 truthOriginAcc (
muon) = truthOriginAcc (*tp);
97 }
98 }
TrackParticle_v1 TrackParticle
Reference the current persistent version:
◆ initialize()
| StatusCode xAOD::MuonAODFixAlg::initialize |
( |
| ) |
|
|
virtual |
Function initialising the algorithm.
Definition at line 31 of file MuonAODFixAlg.cxx.
31 {
32
33 return StatusCode::SUCCESS;
34
35 }
◆ inputHandles()
Return this algorithm's input handles.
We override this to include handle instances from key arrays if they have not yet been declared. See comments on updateVHKA.
◆ msg()
◆ msgLvl()
◆ outputHandles()
Return this algorithm's output handles.
We override this to include handle instances from key arrays if they have not yet been declared. See comments on updateVHKA.
◆ renounce()
Definition at line 380 of file AthCommonDataStore.h.
381 {
384 }
std::enable_if_t< std::is_void_v< std::result_of_t< decltype(&T::renounce)(T)> > &&!std::is_base_of_v< SG::VarHandleKeyArray, T > &&std::is_base_of_v< Gaudi::DataHandle, T >, void > renounce(T &h)
◆ renounceArray()
◆ sysInitialize()
| StatusCode AthAlgorithm::sysInitialize |
( |
| ) |
|
|
overridevirtualinherited |
Override sysInitialize.
Override sysInitialize from the base class.
Loop through all output handles, and if they're WriteCondHandles, automatically register them and this Algorithm with the CondSvc
Scan through all outputHandles, and if they're WriteCondHandles, register them with the CondSvc
Reimplemented from AthCommonDataStore< AthCommonMsg< Algorithm > >.
Reimplemented in AthAnalysisAlgorithm, AthFilterAlgorithm, AthHistogramAlgorithm, and PyAthena::Alg.
Definition at line 66 of file AthAlgorithm.cxx.
66 {
68
71 }
72 ServiceHandle<ICondSvc> cs(
"CondSvc",
name());
74 if (
h->isCondition() &&
h->mode() == Gaudi::DataHandle::Writer) {
75
76 if ( cs.retrieve().isFailure() ) {
78 return StatusCode::SUCCESS;
79 }
80 if (cs->regHandle(this,*h).isFailure()) {
81 sc = StatusCode::FAILURE;
82 ATH_MSG_ERROR(
"unable to register WriteCondHandle " <<
h->fullKey()
83 << " with CondSvc");
84 }
85 }
86 }
88}
virtual StatusCode sysInitialize() override
Override sysInitialize.
AthCommonDataStore(const std::string &name, T... args)
virtual std::vector< Gaudi::DataHandle * > outputHandles() const override
::StatusCode StatusCode
StatusCode definition for legacy code.
◆ sysStart()
Handle START transition.
We override this in order to make sure that conditions handle keys can cache a pointer to the conditions container.
◆ updateVHKA()
Definition at line 308 of file AthCommonDataStore.h.
308 {
309
310
313 for (
auto k :
keys) {
315 }
316 }
317 }
std::vector< SG::VarHandleKeyArray * > m_vhka
◆ m_containerName
| std::string xAOD::MuonAODFixAlg::m_containerName |
|
private |
◆ m_detStore
◆ m_evtStore
◆ m_extendedExtraObjects
| DataObjIDColl AthAlgorithm::m_extendedExtraObjects |
|
privateinherited |
◆ m_varHandleArraysDeclared
◆ m_vhka
The documentation for this class was generated from the following files: