![]() |
ATLAS Offline Software
|
Algorithm to select ID / ITk track candidates which may be suitable for the combined muon reconstruction chain. More...
#include <InDetTrackSelectionAlg.h>
Public Member Functions | |
| virtual StatusCode | initialize () override final |
| virtual StatusCode | execute (const EventContext &ctx) const override final |
| 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 | |
| typedef ServiceHandle< StoreGateSvc > | StoreGateSvc_t |
Private Member Functions | |
| std::optional< Acts::BoundTrackParameters > | extrapolateToMsEntrance (const EventContext &ctx, const xAOD::TrackParticle &idTrack) const |
| Extrapolate the ID track to the MS entrance in order to match it later with spectrometer activity. | |
| bool | compatibleWithMsTrk (const Acts::BoundTrackParameters &caloExitPars, const MuonR4::MuonTagContainer &msTracks) const |
| Returns whether the ID track expressed on the calorimeter exit volume can be loosely matched with a reconsturcted MS track. | |
| bool | compatibleWithSegment (const EventContext &ctx, const Acts::BoundTrackParameters &caloExitPars, const std::span< const xAOD::MuonSegment * > candidateSegs) const |
| Checks whether the ID track is compatible with a reconstructed segment which is not part of a reconstructed MS track. | |
| 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::TrackParticleContainer > | m_idTrkKey {this, "IdTrackKey", "InDetTrackParticles"} |
| The input key for the ID / ITk track particles. | |
| SG::ReadHandleKey< MuonR4::MuonTagContainer > | m_msTrkKey {this, "MsTrackKey", "MuonTagsSA"} |
| Input key for the MS track particles. | |
| SG::ReadHandleKey< xAOD::MuonSegmentContainer > | m_segmentKey {this, "SegmentKey", "MuonSegmentsFromR4"} |
| To pass the selection criteria, ITk tracks can alternatively be matched to. | |
| SG::WriteHandleKey< MuonR4::MuonTagContainer > | m_writeKey {this, "writeKey", "MuonInDetCandidates"} |
| The output key for the selected track candidates. | |
| const MuonGMR4::MuonDetectorManager * | m_detMgr {nullptr} |
| Detector manager to retrieve the sector envelope surfaces. | |
| ToolHandle< InDet::IInDetTrackSelectionTool > | m_selectionTool {this, "TackSelectionTool" , ""} |
| Track quality selection tool (optional). | |
| PublicToolHandle< ActsTrk::ITrackingGeometryTool > | m_trackingGeometryTool {this, "TrackingGeometryTool", ""} |
| Tracking geometry tool. | |
| ToolHandle< ActsTrk::IExtrapolationTool > | m_extrapolationTool {this, "ExtrapolationTool" ,"" } |
| Track extrapolation tool. | |
| Gaudi::Property< float > | m_trackPt {this, "minPt", 2.5*Gaudi::Units::GeV} |
| The minimum momentum cut applied on the ID tracks to be considered. | |
| Gaudi::Property< float > | m_trackEta {this, "maxEta", 2.8} |
| Apply a maximum eta cut to stay within the MS acceptance. | |
| Gaudi::Property< float > | m_dEtaCutMsTrk {this, "dEtaMaxMsTrk", 0.2} |
| Selection cuts for the MS tracks. | |
| Gaudi::Property< float > | m_dPhiCutMsTrk {this, "dPhiMsTrk", 5*Gaudi::Units::deg} |
| Gaudi::Property< float > | m_dEtaCutMsSeg {this, "dEtaMaxMsSegment", 0.3} |
| Selection cuts for the Muon segments. | |
| Gaudi::Property< float > | m_dY0CutMsSeg {this, "dY0MaxMsSegment", 40 * Gaudi::Units::cm} |
| 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 |
Algorithm to select ID / ITk track candidates which may be suitable for the combined muon reconstruction chain.
Apart from basic kinematic requirements, the tracks need to be dR cones around MS tracks or can be loosely matched to a standalone segment which has not been yet associated with a muon track. Successfully matched candidates need
Definition at line 34 of file MuonSpectrometer/MuonPhaseII/MuonIdentification/MuonCombinedAlgsR4/src/InDetTrackSelectionAlg.h.
|
privateinherited |
Definition at line 388 of file AthCommonDataStore.h.
|
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.
|
private |
Returns whether the ID track expressed on the calorimeter exit volume can be loosely matched with a reconsturcted MS track.
The matching is based on the angular cone between the MS & the ID track + separations on the local parameters on the cylinder
| caloExitPars | The ID track expressed at the calo exit |
| msTrack | List of reconstructed MS track particles |
Definition at line 171 of file MuonSpectrometer/MuonPhaseII/MuonIdentification/MuonCombinedAlgsR4/src/InDetTrackSelectionAlg.cxx.
|
private |
Checks whether the ID track is compatible with a reconstructed segment which is not part of a reconstructed MS track.
Matching is based on straight line extrapolations and sector correspondence
Straight line extrapolation onto the surface
Segment parameters expressed on the envelope surface
Definition at line 189 of file MuonSpectrometer/MuonPhaseII/MuonIdentification/MuonCombinedAlgsR4/src/InDetTrackSelectionAlg.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.
|
finaloverridevirtual |
Tracks within the MS eta range are attempted to be extrapolated to the calo exit
Failed extrapolations to the calo exit -> track probably too low in momentum in order to be considered even for calo tagging
Store the parameters at the calorimeter exit if the association to a MS track or a segment is successful -> The tag is then available for the combined fit, STACO, MuTagIMO && inside-> out chain
Definition at line 65 of file MuonSpectrometer/MuonPhaseII/MuonIdentification/MuonCombinedAlgsR4/src/InDetTrackSelectionAlg.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 |
Extrapolate the ID track to the MS entrance in order to match it later with spectrometer activity.
| ctx | EventContext to retrieve the alignment and magnetic field or the calo extensions |
| idTrack | The track to be extrapolated |
Retrieve the last state of the track to extrapolate into the MS
Construct the track parameter from it
Definition at line 123 of file MuonSpectrometer/MuonPhaseII/MuonIdentification/MuonCombinedAlgsR4/src/InDetTrackSelectionAlg.cxx.
|
inlinevirtualinherited |
Definition at line 96 of file AthCommonReentrantAlgorithm.h.
|
finaloverridevirtual |
Definition at line 49 of file MuonSpectrometer/MuonPhaseII/MuonIdentification/MuonCombinedAlgsR4/src/InDetTrackSelectionAlg.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 HiveAlgBase, 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.
|
private |
Selection cuts for the Muon segments.
Definition at line 87 of file MuonSpectrometer/MuonPhaseII/MuonIdentification/MuonCombinedAlgsR4/src/InDetTrackSelectionAlg.h.
|
private |
Selection cuts for the MS tracks.
Definition at line 84 of file MuonSpectrometer/MuonPhaseII/MuonIdentification/MuonCombinedAlgsR4/src/InDetTrackSelectionAlg.h.
|
private |
Detector manager to retrieve the sector envelope surfaces.
Definition at line 72 of file MuonSpectrometer/MuonPhaseII/MuonIdentification/MuonCombinedAlgsR4/src/InDetTrackSelectionAlg.h.
|
privateinherited |
Pointer to StoreGate (detector store by default).
Definition at line 393 of file AthCommonDataStore.h.
|
private |
Definition at line 85 of file MuonSpectrometer/MuonPhaseII/MuonIdentification/MuonCombinedAlgsR4/src/InDetTrackSelectionAlg.h.
|
private |
Definition at line 88 of file MuonSpectrometer/MuonPhaseII/MuonIdentification/MuonCombinedAlgsR4/src/InDetTrackSelectionAlg.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 |
Track extrapolation tool.
Definition at line 78 of file MuonSpectrometer/MuonPhaseII/MuonIdentification/MuonCombinedAlgsR4/src/InDetTrackSelectionAlg.h.
|
private |
The input key for the ID / ITk track particles.
Definition at line 63 of file MuonSpectrometer/MuonPhaseII/MuonIdentification/MuonCombinedAlgsR4/src/InDetTrackSelectionAlg.h.
|
private |
Input key for the MS track particles.
ID tracks are only considered if they can be roughly matched to a MS track
Definition at line 66 of file MuonSpectrometer/MuonPhaseII/MuonIdentification/MuonCombinedAlgsR4/src/InDetTrackSelectionAlg.h.
|
private |
To pass the selection criteria, ITk tracks can alternatively be matched to.
Definition at line 68 of file MuonSpectrometer/MuonPhaseII/MuonIdentification/MuonCombinedAlgsR4/src/InDetTrackSelectionAlg.h.
|
private |
Track quality selection tool (optional).
Definition at line 74 of file MuonSpectrometer/MuonPhaseII/MuonIdentification/MuonCombinedAlgsR4/src/InDetTrackSelectionAlg.h.
|
private |
Apply a maximum eta cut to stay within the MS acceptance.
Definition at line 82 of file MuonSpectrometer/MuonPhaseII/MuonIdentification/MuonCombinedAlgsR4/src/InDetTrackSelectionAlg.h.
|
private |
Tracking geometry tool.
Definition at line 76 of file MuonSpectrometer/MuonPhaseII/MuonIdentification/MuonCombinedAlgsR4/src/InDetTrackSelectionAlg.h.
|
private |
The minimum momentum cut applied on the ID tracks to be considered.
Definition at line 80 of file MuonSpectrometer/MuonPhaseII/MuonIdentification/MuonCombinedAlgsR4/src/InDetTrackSelectionAlg.h.
|
privateinherited |
Definition at line 399 of file AthCommonDataStore.h.
|
privateinherited |
Definition at line 398 of file AthCommonDataStore.h.
|
private |
The output key for the selected track candidates.
Definition at line 70 of file MuonSpectrometer/MuonPhaseII/MuonIdentification/MuonCombinedAlgsR4/src/InDetTrackSelectionAlg.h.