4#ifndef MUONR4_MUONFASTRECOALGS_MUONFASTRECONSTRUCTIONALG__H
5#define MUONR4_MUONFASTRECOALGS_MUONFASTRECONSTRUCTIONALG__H
31 using AthReentrantAlgorithm::AthReentrantAlgorithm;
35 virtual StatusCode
execute(
const EventContext& ctx)
const override;
48 StringProperty
m_outSpacePointSuffix{
this,
"OutSpacePointSuffix",
"FastReco",
"Suffix to add to input space point container names to create the output ones, when not provided"};
56 ToolHandle<MuonValR4::IFastRecoVisualizationTool>
m_visionTool{
this,
"VisualizationTool",
""};
60 BooleanProperty
m_useMdtHits {
this,
"UseMdtHits",
true,
"Activate the utilization of MDT hits to build patterns"};
62 BooleanProperty
m_seedFromMdt {
this,
"SeedFromMdt",
false,
"Activate the seeding from MDT hits"};
64 BooleanProperty
m_seedFromInner {
this,
"SeedFromInner",
false,
"Activate the seeding from Inner station"};
66 DoubleProperty
m_thetaSearchWindow {
this,
"ThetaWindowSearch", 0.06,
"Size of the search window in theta to link hits to a pattern"};
69 DoubleProperty
m_baseRWindow {
this,
"BaseRWindow", 60,
"Çonstant term [mm] of the acceptance window for the residual between a test hit and the pattern line"};
71 DoubleProperty
m_phiTolerance {
this,
"PhiTolerance", 0.05,
"Maximum allowed phi difference between two hits to be considered compatible"};
73 UnsignedIntegerProperty
m_minTriggerLayers {
this,
"MinBendingTriggerLayers", 2,
"Minimum number of trigger layers in the bending direction required to accept a pattern"};
75 UnsignedIntegerProperty
m_minPrecisionLayers {
this,
"MinBendingPrecisionLayers", 8,
"Minimum number of precision layers in the bending direction required to accept a pattern"};
77 UnsignedIntegerProperty
m_minPhiLayers {
this,
"MinPhiLayers", 1,
"Minimum number of phi layers required to accept a pattern"};
79 UnsignedIntegerProperty
m_minStationLayers {
this,
"MinStationLayers", 5,
"Minimum number of layers in a station to be considered a good station"};
81 DoubleProperty
m_meanNormRes2Cut {
this,
"meanNormRes2Cut", 0.18,
"Quality cut on pattern'mean squared normalized residual"};
83 UnsignedIntegerProperty
m_maxSeedAttempts {
this,
"MaxSeedAttempts", 3,
" Maximum number of attempts to build a pattern from hits already used in existing patterns"};
85 UnsignedIntegerProperty
m_maxMissLayersInStation {
this,
"MaxMissedLayerHits", 3,
"Maximum number of missed candidate hits in different measurement layers during pattern building allowed for a pattern branch before it is discarded"};
87 DoubleProperty
m_minLayerSeparation {
this,
"MinLayerSeparation",40,
"Minimum separation (in mm) between the measurement layers of two hits for being used to compute a reliable pattern line. Use the beamspot otherwise."};
Property holding a SG store/key/clid from which a WriteHandle is made.
An algorithm that can be simultaneously executed in multiple threads.
std::vector< const SpacePointContainer * > SpacePointContainerVec
Abrivation for a vector of space-point containers.
std::vector< GlobalPattern > PatternVec
Abrivation for a vector of global patterns.
Algorithm executing Phase-2 fast reconstruction.
DoubleProperty m_phiTolerance
Maximum phi difference [rad] allowed between two hits belonging to the same pattern.
virtual StatusCode execute(const EventContext &ctx) const override
SG::WriteHandleKeyArray< SpacePointContainer > m_outSpacePoints
Write handle key for the output buckets.
ToolHandle< MuonValR4::IFastRecoVisualizationTool > m_visionTool
Handle to the visualization tool.
virtual ~FastReconstructionAlg()=default
DoubleProperty m_baseRWindow
Çonstant term [mm] of the acceptance window for the residual between a test hit and the pattern line.
ActsTrk::GeoContextReadKey_t m_geoCtxKey
Geometry context key.
UnsignedIntegerProperty m_maxMissLayersInStation
Maximum number of missed candidate hits in different measurement layers during pattern building allow...
BooleanProperty m_seedFromMdt
Toggle the seeding from MDT hits.
UnsignedIntegerProperty m_minTriggerLayers
Requirement on trigger layers in the bending direction to accept a pattern.
SG::ReadHandleKeyArray< SpacePointContainer > m_inSpacePoints
Keys of SpacePoint containers to read.
DoubleProperty m_meanNormRes2Cut
Quality cut on pattern'mean squared normalized residual.
BooleanProperty m_useMdtHits
--------------— Configuration options for the global pattern finder --------------—
std::unique_ptr< FastReco::GlobalPatternFinder > m_globPatFinder
Pointer to the actual global pattern finder.
UnsignedIntegerProperty m_minStationLayers
Minimum number of layers in a station to be considered a good station.
StringProperty m_outSpacePointSuffix
Suffix to add to the input space point container names to create the output container names,...
ServiceHandle< Muon::IMuonIdHelperSvc > m_idHelperSvc
Handle to the MuonIdHelper service.
BooleanProperty m_seedFromInner
Activate the seeding from Inner station.
UnsignedIntegerProperty m_maxSeedAttempts
Maximum number of attempts to build a pattern from hits already used in existing patterns.
DoubleProperty m_minLayerSeparation
Minimum separation [mm] between the measurement layers of two hits for being used to compute a reliab...
SG::WriteHandleKey< GlobalPatternContainer > m_outPatterns
Write handle key for the output global patterns.
UnsignedIntegerProperty m_minPhiLayers
Minimum number of phi layers required to accept a pattern.
UnsignedIntegerProperty m_minPrecisionLayers
Requirement on precision layers in the bending direction to accept a pattern.
FastReco::GlobalPatternFinder::SpacePointContainerVec SpacePointContainerVec
Abrivation for a vector of space-point containers.
virtual StatusCode initialize() override
FastReco::GlobalPatternFinder::PatternVec PatternVec
Abrivation for a vector of global patterns.
DoubleProperty m_thetaSearchWindow
Size of theta window [rad] to search for compatible hits with a seed, tailored to the target pt cutof...
Property holding a SG store/key/clid from which a WriteHandle is made.
SG::ReadHandleKey< GeometryContext > GeoContextReadKey_t
Abrivate the ReadHandleKey to declare the data dependency on the Geometry context.
This header ties the generic definitions in this package.
HandleKeyArray< ReadHandle< T >, ReadHandleKey< T >, Gaudi::DataHandle::Reader > ReadHandleKeyArray
HandleKeyArray< WriteHandle< T >, WriteHandleKey< T >, Gaudi::DataHandle::Writer > WriteHandleKeyArray