![]() |
ATLAS Offline Software
|
#include <TruthTrackRecordsAlg.h>
Classes | |
| struct | SummaryDecors |
Public Member Functions | |
| virtual StatusCode | initialize () override |
| virtual StatusCode | execute (const EventContext &ctx) const override |
| virtual StatusCode | sysInitialize () override |
| Override sysInitialize. | |
| virtual bool | isClonable () const override |
| Specify if the algorithm is clonable. | |
| virtual unsigned int | cardinality () const override |
| Cardinality (Maximum number of clones that can exist) special value 0 means that algorithm is reentrant. | |
| virtual StatusCode | sysExecute (const EventContext &ctx) override |
| Execute an algorithm. | |
| virtual const DataObjIDColl & | extraOutputDeps () const override |
| Return the list of extra output dependencies. | |
| virtual bool | filterPassed (const EventContext &ctx) const |
| virtual void | setFilterPassed (bool state, const EventContext &ctx) const |
| ServiceHandle< StoreGateSvc > & | evtStore () |
The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc. | |
| const ServiceHandle< StoreGateSvc > & | detStore () const |
The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc. | |
| virtual StatusCode | sysStart () override |
| Handle START transition. | |
| virtual std::vector< Gaudi::DataHandle * > | inputHandles () const override |
| Return this algorithm's input handles. | |
| virtual std::vector< Gaudi::DataHandle * > | outputHandles () const override |
| Return this algorithm's output handles. | |
| Gaudi::Details::PropertyBase & | declareProperty (Gaudi::Property< T, V, H > &t) |
| void | updateVHKA (Gaudi::Details::PropertyBase &) |
| MsgStream & | msg () const |
| bool | msgLvl (const MSG::Level lvl) const |
Protected Member Functions | |
| void | renounceArray (SG::VarHandleKeyArray &handlesArray) |
| remove all handles from I/O resolution | |
| 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) |
| void | extraDeps_update_handler (Gaudi::Details::PropertyBase &ExtraDeps) |
| Add StoreName to extra input/output deps as needed. | |
Private Types | |
| using | WriteDecorArray_f = DecorHandlePtrVec_t<xAOD::TruthParticleContainer, float> |
| Struct object encapsulating all write-decorators. | |
| using | WriteDecorArray_b = DecorHandlePtrVec_t<xAOD::TruthParticleContainer, char> |
| using | WriteDecorArray_fvec = DecorHandlePtrVec_t<xAOD::TruthParticleContainer, std::vector<float>> |
| using | DecorKey_t = SG::WriteDecorHandleKeyArray<xAOD::TruthParticleContainer> |
| Declaration of the key arrays, which are all initialized as empty (they will be filled up by @fillWriteDecorator). | |
| typedef ServiceHandle< StoreGateSvc > | StoreGateSvc_t |
Private Member Functions | |
| StatusCode | addTrackRecords (const EventContext &ctx, const xAOD::TruthParticle &truthParticle, SummaryDecors &myDecors) const |
| addTrackRecords is the actual function that decorates muons with track records. | |
| template<typename T> | |
| StatusCode | fillWriteDecorator (SG::WriteDecorHandleKeyArray< xAOD::TruthParticleContainer, T > &writeKey, const std::string &keyName) const |
| This function fills the arrays of write-decorator keys and initializes them. | |
| Gaudi::Details::PropertyBase & | declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &) |
| specialization for handling Gaudi::Property<SG::VarHandleKey> | |
Private Attributes | |
| SG::ReadHandleKey< xAOD::TruthParticleContainer > | m_muonTruth {this, "muonTruth", "MuonTruthParticles"} |
| Key of the container of truth muons that will be decorated. | |
| SG::ReadHandleKeyArray< TrackRecordCollection > | m_trackRecords |
| Keys of the containers of track records in different detector positions. | |
| DecorKey_t | m_muonSnapShotX {this, "SnapShotX", { }, "Position decoration..."} |
| DecorKey_t | m_muonSnapShotY {this, "SnapShotY", { }, "Position decoration..."} |
| DecorKey_t | m_muonSnapShotZ {this, "SnapShotZ", { }, "Position decoration..."} |
| DecorKey_t | m_muonSnapShotPx {this, "SnapShotPx", { }, "Momentum decoration..."} |
| DecorKey_t | m_muonSnapShotPy {this, "SnapShotPy", { }, "Momentum decoration..."} |
| DecorKey_t | m_muonSnapShotPz {this, "SnapShotPz", { }, "Momentum decoration..."} |
| DecorKey_t | m_muonSnapShotMtc {this, "SnapShotMtc", { }, "is matched decoration..."} |
| DecorKey_t | m_muonSnapShotEX {this, "SnapShotEX", { }, "Position decoration..."} |
| DecorKey_t | m_muonSnapShotEY {this, "SnapShotEY", { }, "Position decoration..."} |
| DecorKey_t | m_muonSnapShotEZ {this, "SnapShotEZ", { }, "Position decoration..."} |
| DecorKey_t | m_muonSnapShotEPx {this, "SnapShotEPx", { }, "Momentum decoration..."} |
| DecorKey_t | m_muonSnapShotEPy {this, "SnapShotEPy", { }, "Momentum decoration..."} |
| DecorKey_t | m_muonSnapShotEPz {this, "SnapShotEPz", { }, "Momentum decoration..."} |
| DecorKey_t | m_muonSnapShotEcov {this, "SnapShotEcov", { }, "Covariance decoration"} |
| DecorKey_t | m_muonSnapShotEis {this, "SnapShotEis", { }, "Flag decoration whether the extrapolation worked"} |
| ToolHandle< Trk::IExtrapolator > | m_extrapolator {this, "Extrapolator", "Trk::Extrapolator/AtlasExtrapolator"} |
| Extrapolation tool handle. | |
| DataObjIDColl | m_extendedExtraObjects |
| Extra output dependency collection, extended by AthAlgorithmDHUpdate to add symlinks. | |
| StoreGateSvc_t | m_evtStore |
| Pointer to StoreGate (event store by default) | |
| StoreGateSvc_t | m_detStore |
| Pointer to StoreGate (detector store by default) | |
| std::vector< SG::VarHandleKeyArray * > | m_vhka |
| bool | m_varHandleArraysDeclared |
Definition at line 26 of file TruthTrackRecordsAlg.h.
|
private |
Declaration of the key arrays, which are all initialized as empty (they will be filled up by @fillWriteDecorator).
Each decorKeyArray, which is an array of keys, represents a property, and its elements represents that property evaluated at different detector positions. List of properties: x,y,x,px,py,pz are position and momentum in a given layer; matchedDecor is a flag saying if a record has been recorded in that layer; ex,ey,ez,epx,epy,epz are extrapolated position and momentum; ecov is a vector encapsulating the covariance matrix from extrapolation; eis is a flag representing if the extrapolation has been successful.
Definition at line 106 of file TruthTrackRecordsAlg.h.
|
privateinherited |
Definition at line 388 of file AthCommonDataStore.h.
|
private |
Definition at line 46 of file TruthTrackRecordsAlg.h.
|
private |
Struct object encapsulating all write-decorators.
Each decorArray represents a property, and its elements represents that property evaluated at different detector positions. List of properties: x,y,x,px,py,pz are position and momentum in a given layer; matchedDecor is a flag saying if a record has been recorded in that layer; ex,ey,ez,epx,epy,epz are extrapolated position and momentum; ecov is a vector encapsulating the covariance matrix from extrapolation; eis is a flag representing if the extrapolation has been successful. We can decouple declaration and population of this object because vectors can be initialized empty.
Definition at line 45 of file TruthTrackRecordsAlg.h.
|
private |
Definition at line 47 of file TruthTrackRecordsAlg.h.
|
private |
addTrackRecords is the actual function that decorates muons with track records.
Firstly, if production vertex is available, we save position and momentum at production. Then we loop over snapshot positions (e.g. calo entry level) and, in each position, we loop over track records. If the record is descendand of the muon, we save position and momentum in that position, as well as the tracking volume and record name (= snapshot position). Then, by means of another loop over all records of a truth muon, we extrapolate each record to the next shapshot position. Specifically, we save the extrapolated position and momentum, the extrapolation's covariance matrix, and a flag representing the extrapolation outcome.
| ctx | tells in which event we are |
| truthParticle | a pointer to the truth muon |
| myDecors | reference to the decorator summary object |
loop over collection and find trackRecord with the same bar code. If we find a record, we save position and momentum
Make sure that the parameter vector has the same size
Save record name
Save tracking volume
Second loop, extrapolate between the points
If the track record is named, then we should have a volume
Definition at line 105 of file TruthTrackRecordsAlg.cxx.
|
overridevirtualinherited |
Cardinality (Maximum number of clones that can exist) special value 0 means that algorithm is reentrant.
Override this to return 0 for reentrant algorithms.
Definition at line 75 of file AthCommonReentrantAlgorithm.cxx.
|
inlineprivateinherited |
specialization for handling Gaudi::Property<SG::VarHandleKey>
Definition at line 156 of file AthCommonDataStore.h.
|
inlineinherited |
Definition at line 145 of file AthCommonDataStore.h.
|
inlineinherited |
The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.
Definition at line 95 of file AthCommonDataStore.h.
|
inlineinherited |
The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.
Definition at line 85 of file AthCommonDataStore.h.
|
overridevirtual |
Definition at line 76 of file TruthTrackRecordsAlg.cxx.
|
protectedinherited |
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
|
overridevirtualinherited |
Return the list of extra output dependencies.
This list is extended to include symlinks implied by inheritance relations.
Definition at line 94 of file AthCommonReentrantAlgorithm.cxx.
|
private |
This function fills the arrays of write-decorator keys and initializes them.
Specifically, the key that will be written at i-th position is <property_name>_<detector_position(i)>, where property_name = writeKey, and detector_position(i) is retrieved from (= is an element of) m_trackRecords
| writeKey | reference to the (empty) array of write-decor keys that is going to be populated |
| keyName | reference to the property name (e.g. x, x_extr, ...) |
Definition at line 41 of file TruthTrackRecordsAlg.cxx.
|
inlinevirtualinherited |
Definition at line 96 of file AthCommonReentrantAlgorithm.h.
|
overridevirtual |
Definition at line 51 of file TruthTrackRecordsAlg.cxx.
|
overridevirtualinherited |
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.
|
overridevirtualinherited |
Specify if the algorithm is clonable.
Reentrant algorithms are clonable.
Reimplemented in InDet::GNNSeedingTrackMaker, InDet::SCT_Clusterization, InDet::SiSPGNNTrackMaker, InDet::SiSPSeededTrackFinder, InDet::SiTrackerSpacePointFinder, ITkPixelCablingAlg, ITkStripCablingAlg, RoIBResultToxAOD, SCT_ByteStreamErrorsTestAlg, SCT_CablingCondAlgFromCoraCool, SCT_CablingCondAlgFromText, SCT_ConditionsParameterTestAlg, SCT_ConditionsSummaryTestAlg, SCT_ConfigurationConditionsTestAlg, SCT_FlaggedConditionTestAlg, SCT_LinkMaskingTestAlg, SCT_MajorityConditionsTestAlg, SCT_ModuleVetoTestAlg, SCT_MonitorConditionsTestAlg, SCT_PrepDataToxAOD, SCT_RawDataToxAOD, SCT_ReadCalibChipDataTestAlg, SCT_ReadCalibDataTestAlg, SCT_RODVetoTestAlg, SCT_SensorsTestAlg, SCT_SiliconConditionsTestAlg, SCT_StripVetoTestAlg, SCT_TdaqEnabledTestAlg, SCT_TestCablingAlg, SCTEventFlagWriter, SCTRawDataProvider, SCTSiLorentzAngleTestAlg, SCTSiPropertiesTestAlg, and Simulation::BeamEffectsAlg.
Definition at line 68 of file AthCommonReentrantAlgorithm.cxx.
|
inlineinherited |
Definition at line 24 of file AthCommonMsg.h.
|
inlineinherited |
Definition at line 30 of file AthCommonMsg.h.
|
overridevirtualinherited |
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.
|
inlineprotectedinherited |
Definition at line 380 of file AthCommonDataStore.h.
|
inlineprotectedinherited |
remove all handles from I/O resolution
Definition at line 364 of file AthCommonDataStore.h.
|
inlinevirtualinherited |
Definition at line 100 of file AthCommonReentrantAlgorithm.h.
|
overridevirtualinherited |
Execute an algorithm.
We override this in order to work around an issue with the Algorithm base class storing the event context in a member variable that can cause crashes in MT jobs.
Definition at line 85 of file AthCommonReentrantAlgorithm.cxx.
|
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< Gaudi::Algorithm > >.
Reimplemented in HypoBase, and InputMakerBase.
Definition at line 61 of file AthCommonReentrantAlgorithm.cxx.
|
overridevirtualinherited |
Handle START transition.
We override this in order to make sure that conditions handle keys can cache a pointer to the conditions container.
|
inlineinherited |
Definition at line 308 of file AthCommonDataStore.h.
|
privateinherited |
Pointer to StoreGate (detector store by default)
Definition at line 393 of file AthCommonDataStore.h.
|
privateinherited |
Pointer to StoreGate (event store by default)
Definition at line 390 of file AthCommonDataStore.h.
|
privateinherited |
Extra output dependency collection, extended by AthAlgorithmDHUpdate to add symlinks.
Empty if no symlinks were found.
Definition at line 114 of file AthCommonReentrantAlgorithm.h.
|
private |
Extrapolation tool handle.
Definition at line 124 of file TruthTrackRecordsAlg.h.
|
private |
Definition at line 120 of file TruthTrackRecordsAlg.h.
|
private |
Definition at line 121 of file TruthTrackRecordsAlg.h.
|
private |
Definition at line 117 of file TruthTrackRecordsAlg.h.
|
private |
Definition at line 118 of file TruthTrackRecordsAlg.h.
|
private |
Definition at line 119 of file TruthTrackRecordsAlg.h.
|
private |
Definition at line 114 of file TruthTrackRecordsAlg.h.
|
private |
Definition at line 115 of file TruthTrackRecordsAlg.h.
|
private |
Definition at line 116 of file TruthTrackRecordsAlg.h.
|
private |
Definition at line 113 of file TruthTrackRecordsAlg.h.
|
private |
Definition at line 110 of file TruthTrackRecordsAlg.h.
|
private |
Definition at line 111 of file TruthTrackRecordsAlg.h.
|
private |
Definition at line 112 of file TruthTrackRecordsAlg.h.
|
private |
Definition at line 107 of file TruthTrackRecordsAlg.h.
|
private |
Definition at line 108 of file TruthTrackRecordsAlg.h.
|
private |
Definition at line 109 of file TruthTrackRecordsAlg.h.
|
private |
Key of the container of truth muons that will be decorated.
Definition at line 92 of file TruthTrackRecordsAlg.h.
|
private |
Keys of the containers of track records in different detector positions.
Definition at line 96 of file TruthTrackRecordsAlg.h.
|
privateinherited |
Definition at line 399 of file AthCommonDataStore.h.
|
privateinherited |
Definition at line 398 of file AthCommonDataStore.h.