ATLAS Offline Software
Loading...
Searching...
No Matches
MuonR4::SpacePointMakerAlg Class Reference

Data preparation algorithm that transforms the uncalibrated measurements into muon space points. More...

#include <SpacePointMakerAlg.h>

Inheritance diagram for MuonR4::SpacePointMakerAlg:

Classes

struct  BucketParameters
 Helper struct to define the bucket parameters for a given chamber. More...
struct  ResolvedParameter
 Helper struct to store the resolved bucket parameters for a given chamber. More...
class  SpacePointStatistics
 Helper class to keep track of how many eta+phi, eta and phi only space points are built in various detector regions. More...
struct  SpacePointsPerChamber
 : Helper struct to collect the space point per muon chamber, which are later sorted into the space point buckets. More...

Public Types

template<Acts::PointerConcept Prd_t>
using PrdVec_t = std::vector<Prd_t>
template<typename T>
using EtaPhi2DHits = std::array<PrdVec_t<T>, 3>
template<typename T>
using EtaPhi2DHitsVec = std::vector<EtaPhi2DHits<T>>

Public Member Functions

 ~SpacePointMakerAlg ()=default
StatusCode execute (const EventContext &ctx) const override
StatusCode initialize () override
StatusCode finalize () override
 ########################################## SpacePointMakerAlg #########################################
template<>
bool passOccupancy2D (const PrdVec_t< const xAOD::TgcStrip * > &etaHits, const PrdVec_t< const xAOD::TgcStrip * > &phiHits) const
template<>
bool passOccupancy2D (const PrdVec_t< const xAOD::RpcMeasurement * > &etaHits, const PrdVec_t< const xAOD::RpcMeasurement * > &phiHits) const
template<>
bool passOccupancy2D (const PrdVec_t< const xAOD::MMCluster * > &, const PrdVec_t< const xAOD::MMCluster * > &) const
template<>
StatusCode loadContainerAndSort (const EventContext &ctx, const SG::ReadHandleKey< xAOD::sTgcMeasContainer > &key, PreSortedSpacePointMap &fillContainer) const
virtual StatusCode sysInitialize () override
 Override sysInitialize.
virtual bool isClonable () const override
 Specify if the algorithm is clonable.
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
 Get filter decision:
virtual void setFilterPassed (bool state, const EventContext &ctx) const
 Set filter decision:
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 PreSortedSpacePointMap = std::unordered_map<const MuonGMR4::SpectrometerSector*, SpacePointsPerChamber>
 Container abrivation of the presorted space point container per MuonChambers.
using SpacePointBucketVec = std::vector<SpacePointBucket>
 Abrivation of a MuonSapcePoint bucket vector.
using BucketPatternMap = std::map<std::string, double, std::less<>>
typedef ServiceHandle< StoreGateSvcStoreGateSvc_t

Private Member Functions

template<typename ContType>
StatusCode loadContainerAndSort (const EventContext &ctx, const SG::ReadHandleKey< ContType > &key, PreSortedSpacePointMap &fillContainer) const
 Retrieve an uncalibrated measurement container <ContType> and fill the hits into the presorted space point map.
template<typename PrdType>
bool passOccupancy2D (const PrdVec_t< PrdType > &etaHits, const PrdVec_t< PrdType > &phiHits) const
 : Check whether the occupancy cuts of hits in a gasGap are surpassed.
template<typename ContType>
EtaPhi2DHitsVec< typename ContType::const_value_type > splitHitsPerGasGap (xAOD::ChamberViewer< ContType > &viewer) const
 Splits the chamber hits of the viewer per gas gap.
template<typename PrdType>
void fillUncombinedSpacePoints (const ActsTrk::GeometryContext &gctx, const Amg::Transform3D &sectorTrans, const PrdVec_t< const PrdType * > &prdsToFill, std::vector< SpacePoint > &outColl) const
 Transform the uncombined space prd measurements to space points.
void distributePointsAndStore (SpacePointsPerChamber &&hitsPerChamber, SpacePointContainer &finalContainer) const
 Distribute the premade spacepoints per chamber into their individual SpacePoint buckets.
void distributePrimaryPoints (std::vector< SpacePoint > &&spacePoints, SpacePointBucketVec &splittedContainer) const
 Distributes the vector of primary eta or eta + phi space points and fills them into the buckets.
void distributePhiPoints (std::vector< SpacePoint > &&spacePoints, SpacePointBucketVec &splittedContainer) const
 Distributs the vector phi space points into the buckets.
bool splitBucket (const SpacePoint &spacePoint, const double firstSpPos, const SpacePointBucketVec &sortedPoints, const BucketParameters &bucketParams) const
 Returns whether the space point is beyond the bucket boundary.
void newBucket (const SpacePoint &refSp, SpacePointBucketVec &sortedPoints, const BucketParameters &bucketParams) const
 Closes the current processed bucket and creates a new one.
std::string chamberConfigKey (const MuonGMR4::Chamber &chamber) const
 Returns a string key for a chamber, based on the space point identifier.
std::optional< BucketParametersresolveBucketParameters (const MuonGMR4::Chamber &chamber) const
 Resolves the bucket parameters for a given chamber, based on the chamber key and the configured patterns.
ResolvedParameter resolveParameter (const std::string_view chamberKey, const double defaultValue, const BucketPatternMap &patterns) const
 Resolves a specific parameter for a given chamber key, based on the configured patterns.
const BucketParametersgetBucketParameters (const SpacePoint &spacePoint) const
 Returns the bucket parameters for a given space point.
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::MdtDriftCircleContainerm_mdtKey
SG::ReadHandleKey< xAOD::RpcMeasurementContainerm_rpcKey
SG::ReadHandleKey< xAOD::TgcStripContainerm_tgcKey
SG::ReadHandleKey< xAOD::MMClusterContainerm_mmKey
SG::ReadHandleKey< xAOD::sTgcMeasContainerm_stgcKey {this, "sTgcKey", "xAODsTgcMeasurements"}
ActsTrk::GeoContextReadKey_t m_geoCtxKey {this, "AlignmentKey", "ActsAlignment", "cond handle key"}
const MuonGMR4::MuonDetectorManagerm_detMgr {nullptr}
ServiceHandle< Muon::IMuonIdHelperSvcm_idHelperSvc {this, "IdHelperSvc", "Muon::MuonIdHelperSvc/MuonIdHelperSvc"}
SG::WriteHandleKey< SpacePointContainerm_writeKey {this, "WriteKey", "MuonSpacePoints"}
Gaudi::Property< double > m_spacePointWindow
 Default space point window size (Max distance between the two eta hits).
Gaudi::Property< double > m_maxBucketLength
 Default maximum bucket length (the width of the bucket in local y coordinate).
Gaudi::Property< double > m_spacePointOverlap
 Default space point overlap (the margin around the edge of the bucket which is also coppied into another bucket).
Gaudi::Property< BucketPatternMapm_spacePointWindowPatterns
 Chamber-pattern dependent space point window.
Gaudi::Property< BucketPatternMapm_maxBucketLengthPatterns
 Chamber-pattern dependent maximum bucket length.
Gaudi::Property< BucketPatternMapm_spacePointOverlapPatterns
 Chamber-pattern dependent space point overlap.
std::unordered_map< const MuonGMR4::Chamber *, BucketParametersm_bucketParameters {}
 Map of bucket parameters for each chamber.
BucketParameters m_defaultBucketParameters {}
 Default bucket parameters used if no chamber-specific parameters are found, defaults into m_spacePointWindow, m_maxBucketLength, and m_spacePointOverlap.
Gaudi::Property< bool > m_doStat
Gaudi::Property< unsigned > m_capacityBucket {this,"CapacityBucket" , 50}
std::unique_ptr< SpacePointStatistics > m_statCounter ATLAS_THREAD_SAFE {}
Gaudi::Property< double > m_maxOccRpcEta
Gaudi::Property< double > m_maxOccRpcPhi
Gaudi::Property< double > m_maxOccTgcEta
Gaudi::Property< double > m_maxOccTgcPhi
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

Detailed Description

Data preparation algorithm that transforms the uncalibrated measurements into muon space points.

Mdt, Mm measurements are directly transformed. The remaining three technologies provide eta & phi measurements, each 1D. The measurements are sorted by gas gap and if the occupancy in the gas gap is low enough, then each eta measurement is combined with each phi measurement to a 2D space point. Otherwise, single 1D space points are produced. Space points in the same MS layer & phi-sector are expressed in the common sector frame.

Definition at line 34 of file SpacePointMakerAlg.h.

Member Typedef Documentation

◆ BucketPatternMap

using MuonR4::SpacePointMakerAlg::BucketPatternMap = std::map<std::string, double, std::less<>>
private

Definition at line 208 of file SpacePointMakerAlg.h.

◆ EtaPhi2DHits

template<typename T>
using MuonR4::SpacePointMakerAlg::EtaPhi2DHits = std::array<PrdVec_t<T>, 3>

Definition at line 39 of file SpacePointMakerAlg.h.

◆ EtaPhi2DHitsVec

template<typename T>
using MuonR4::SpacePointMakerAlg::EtaPhi2DHitsVec = std::vector<EtaPhi2DHits<T>>

Definition at line 41 of file SpacePointMakerAlg.h.

◆ PrdVec_t

template<Acts::PointerConcept Prd_t>
using MuonR4::SpacePointMakerAlg::PrdVec_t = std::vector<Prd_t>

Definition at line 37 of file SpacePointMakerAlg.h.

◆ PreSortedSpacePointMap

Container abrivation of the presorted space point container per MuonChambers.

Definition at line 119 of file SpacePointMakerAlg.h.

◆ SpacePointBucketVec

Abrivation of a MuonSapcePoint bucket vector.

Definition at line 122 of file SpacePointMakerAlg.h.

◆ StoreGateSvc_t

typedef ServiceHandle<StoreGateSvc> AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::StoreGateSvc_t
privateinherited

Definition at line 388 of file AthCommonDataStore.h.

Constructor & Destructor Documentation

◆ ~SpacePointMakerAlg()

MuonR4::SpacePointMakerAlg::~SpacePointMakerAlg ( )
default

Member Function Documentation

◆ chamberConfigKey()

std::string MuonR4::SpacePointMakerAlg::chamberConfigKey ( const MuonGMR4::Chamber & chamber) const
private

Returns a string key for a chamber, based on the space point identifier.

Parameters
chamberChamber for which to generate the key
Returns
A string representing the chamber key (e.g. EML_eta-1_phi3)

Definition at line 781 of file SpacePointMakerAlg.cxx.

781 {
782 return std::format("{:}_eta{:}_phi{:}", Muon::MuonStationIndex::chName(chamber.chamberIndex()), chamber.stationEta(), chamber.stationPhi());
783}
const std::string & chName(ChIndex index)
convert ChIndex into a string

◆ declareGaudiProperty()

Gaudi::Details::PropertyBase & AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::declareGaudiProperty ( Gaudi::Property< T, V, H > & hndl,
const SG::VarHandleKeyType &  )
inlineprivateinherited

specialization for handling Gaudi::Property<SG::VarHandleKey>

Definition at line 156 of file AthCommonDataStore.h.

158 {
160 hndl.value(),
161 hndl.documentation());
162
163 }
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T, V, H > &t)

◆ declareProperty()

Gaudi::Details::PropertyBase & AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::declareProperty ( Gaudi::Property< T, V, H > & t)
inlineinherited

Definition at line 145 of file AthCommonDataStore.h.

145 {
146 typedef typename SG::HandleClassifier<T>::type htype;
148 }
Gaudi::Details::PropertyBase & declareGaudiProperty(Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
specialization for handling Gaudi::Property<SG::VarHandleKey>

◆ detStore()

const ServiceHandle< StoreGateSvc > & AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::detStore ( ) const
inlineinherited

The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.

Definition at line 95 of file AthCommonDataStore.h.

◆ distributePhiPoints()

void MuonR4::SpacePointMakerAlg::distributePhiPoints ( std::vector< SpacePoint > && spacePoints,
SpacePointBucketVec & splittedContainer ) const
private

Distributs the vector phi space points into the buckets.

In contrast to the primary distribution no new buckets are created and the points are distributed into the existing ones instead.

Parameters
spacePointVecotr of phi space points to sort into the buckets
splittedContainerOutput vector containing all defined bucket

If maxY is smaller than the lower cov boundary or minY is bigger than the other boundary, there's definetely no overlap

Definition at line 669 of file SpacePointMakerAlg.cxx.

670 {
671 for (SpacePoint& sp : spacePoints) {
672 auto phiPoint = std::make_shared<SpacePoint>(std::move(sp));
673 const double dY = std::sqrt(phiPoint->covariance()[Acts::toUnderlying(CovIdx::etaCov)]);
674 const double minY = phiPoint->localPosition().y() - dY;
675 const double maxY = phiPoint->localPosition().y() + dY;
676 for (SpacePointBucket& bucket : splittedContainer){
679 if (! (maxY < bucket.coveredMin() || bucket.coveredMax() < minY) ) {
680 bucket.emplace_back(phiPoint);
681 }
682 }
683 }
684}
static Double_t sp

◆ distributePointsAndStore()

void MuonR4::SpacePointMakerAlg::distributePointsAndStore ( SpacePointsPerChamber && hitsPerChamber,
SpacePointContainer & finalContainer ) const
private

Distribute the premade spacepoints per chamber into their individual SpacePoint buckets.

A new bucket is created everytime if the hit to fill is along the z-axis farther away from the first point in the bucket than the <spacePointWindowSize>. Hit in the previous bucket which are <spacePointOverlap> away from the first hit in the new bucket are also mirrored. The bucket formation starts with the eta Muon space points and then consumes the phi hits.

Parameters
ctxEvent context of the current event
hitsPerChamberList of all premade space points which have to be sorted
finalContainerOutput SpacePoint bucket container.

Definition at line 637 of file SpacePointMakerAlg.cxx.

638 {
639 SpacePointBucketVec splittedHits{};
640 splittedHits.emplace_back();
641 if (m_statCounter){
642 m_statCounter->addToStat(hitsPerChamber.etaHits);
643 m_statCounter->addToStat(hitsPerChamber.phiHits);
644
645 }
646 distributePrimaryPoints(std::move(hitsPerChamber.etaHits), splittedHits);
647 splittedHits.erase(std::remove_if(splittedHits.begin(), splittedHits.end(),
648 [](const SpacePointBucket& bucket) {
649 return bucket.size() <= 1;
650 }), splittedHits.end());
651 distributePhiPoints(std::move(hitsPerChamber.phiHits), splittedHits);
652
653 for (SpacePointBucket& bucket : splittedHits) {
654
655 std::ranges::sort(bucket, MuonR4::SpacePointPerLayerSorter{});
656
657 if (msgLvl(MSG::VERBOSE)){
658 std::stringstream spStr{};
659 for (const std::shared_ptr<SpacePoint>& sp : bucket){
660 spStr<<"SpacePoint: PrimaryMeas: " <<(*sp)<<std::endl;
661 }
662 ATH_MSG_VERBOSE("Created a bucket, printing all spacepoints..."<<std::endl<<spStr.str());
663 }
664 bucket.populateChamberLocations();
665 finalContainer.push_back(std::make_unique<SpacePointBucket>(std::move(bucket)));
666 }
667
668}
#define ATH_MSG_VERBOSE(x)
bool msgLvl(const MSG::Level lvl) const
void distributePhiPoints(std::vector< SpacePoint > &&spacePoints, SpacePointBucketVec &splittedContainer) const
Distributs the vector phi space points into the buckets.
std::vector< SpacePointBucket > SpacePointBucketVec
Abrivation of a MuonSapcePoint bucket vector.
void distributePrimaryPoints(std::vector< SpacePoint > &&spacePoints, SpacePointBucketVec &splittedContainer) const
Distributes the vector of primary eta or eta + phi space points and fills them into the buckets.
DataModel_detail::iterator< DVL > remove_if(typename DataModel_detail::iterator< DVL > beg, typename DataModel_detail::iterator< DVL > end, Predicate pred)
Specialization of remove_if for DataVector/List.

◆ distributePrimaryPoints()

void MuonR4::SpacePointMakerAlg::distributePrimaryPoints ( std::vector< SpacePoint > && spacePoints,
SpacePointBucketVec & splittedContainer ) const
private

Distributes the vector of primary eta or eta + phi space points and fills them into the buckets.

The buckets are dynamically created based on the distance of the new space point to sort to the previous or the first space point in the bucket.

Parameters
spacePointsVector of space points to sort into the buckets
splittedContainerOutput vector containing all defined bucket

Order the space points by local chamber y which is along the tube-plane.

Definition at line 742 of file SpacePointMakerAlg.cxx.

743 {
744
745 if (spacePoints.empty()) return;
746
748 std::ranges::sort(spacePoints,
749 [] (const SpacePoint& a, const SpacePoint& b) {
750 return a.localPosition().y() < b.localPosition().y();
751 });
752
753 double firstPointPos = spacePoints.front().localPosition().y();
754
755 //Base the bucket parameters on the first space point in the chamber. This is a good approximation since all space points in the same chamber should have similar properties with the exception of the edge space points and overlapping chambers
756 const BucketParameters& bucketParams = getBucketParameters(spacePoints.front());
757
758 ATH_MSG_DEBUG("Distributing "<<spacePoints.size()<<" primary space points into buckets with parameters: "
759 << "maxBucketLength=" << bucketParams.maxBucketLength
760 << ", spacePointWindow=" << bucketParams.spacePointWindow
761 << ", spacePointOverlap=" << bucketParams.spacePointOverlap);
762
763 for (SpacePoint& toSort : spacePoints) {
764 ATH_MSG_VERBOSE("Add new primary space point "<<toSort);
765
766 if (splitBucket(toSort, firstPointPos, splittedHits, bucketParams)){
767 newBucket(toSort, splittedHits, bucketParams);
768 firstPointPos = splittedHits.back().empty() ? toSort.localPosition().y() : splittedHits.back().front()->localPosition().y();
769 ATH_MSG_VERBOSE("New bucket: id " << splittedHits.back().bucketId() << " Coverage: " << firstPointPos);
770 }
771 std::shared_ptr<SpacePoint> spacePoint = std::make_shared<SpacePoint>(std::move(toSort));
772 splittedHits.back().emplace_back(spacePoint);
773 }
774 SpacePointBucket& lastBucket{splittedHits.back()};
775 lastBucket.setCoveredRange(lastBucket.front()->localPosition().y(),
776 lastBucket.back()->localPosition().y());
777}
#define ATH_MSG_DEBUG(x)
static Double_t a
bool splitBucket(const SpacePoint &spacePoint, const double firstSpPos, const SpacePointBucketVec &sortedPoints, const BucketParameters &bucketParams) const
Returns whether the space point is beyond the bucket boundary.
void newBucket(const SpacePoint &refSp, SpacePointBucketVec &sortedPoints, const BucketParameters &bucketParams) const
Closes the current processed bucket and creates a new one.
const BucketParameters & getBucketParameters(const SpacePoint &spacePoint) const
Returns the bucket parameters for a given space point.
Helper struct to define the bucket parameters for a given chamber.

◆ evtStore()

ServiceHandle< StoreGateSvc > & AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::evtStore ( )
inlineinherited

The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.

Definition at line 85 of file AthCommonDataStore.h.

◆ execute()

StatusCode MuonR4::SpacePointMakerAlg::execute ( const EventContext & ctx) const
override

Definition at line 618 of file SpacePointMakerAlg.cxx.

618 {
619 PreSortedSpacePointMap preSortedContainer{};
620 ATH_CHECK(loadContainerAndSort(ctx, m_mdtKey, preSortedContainer));
621 ATH_CHECK(loadContainerAndSort(ctx, m_rpcKey, preSortedContainer));
622 ATH_CHECK(loadContainerAndSort(ctx, m_tgcKey, preSortedContainer));
623 ATH_CHECK(loadContainerAndSort(ctx, m_mmKey, preSortedContainer));
624 ATH_CHECK(loadContainerAndSort(ctx, m_stgcKey, preSortedContainer));
625 std::unique_ptr<SpacePointContainer> outContainer = std::make_unique<SpacePointContainer>();
626
627 for (auto &[chamber, hitsPerChamber] : preSortedContainer){
628 ATH_MSG_DEBUG("Fill space points for chamber "<<chamber->identString() << " with "<<hitsPerChamber.etaHits.size()
629 <<" primary and "<<hitsPerChamber.phiHits.size()<<" phi space points.");
630 distributePointsAndStore(std::move(hitsPerChamber), *outContainer);
631 }
632 SG::WriteHandle writeHandle{m_writeKey, ctx};
633 ATH_CHECK(writeHandle.record(std::move(outContainer)));
634 return StatusCode::SUCCESS;
635}
#define ATH_CHECK
Evaluate an expression and check for errors.
SG::ReadHandleKey< xAOD::TgcStripContainer > m_tgcKey
SG::ReadHandleKey< xAOD::MMClusterContainer > m_mmKey
SG::WriteHandleKey< SpacePointContainer > m_writeKey
StatusCode loadContainerAndSort(const EventContext &ctx, const SG::ReadHandleKey< ContType > &key, PreSortedSpacePointMap &fillContainer) const
Retrieve an uncalibrated measurement container <ContType> and fill the hits into the presorted space ...
SG::ReadHandleKey< xAOD::RpcMeasurementContainer > m_rpcKey
SG::ReadHandleKey< xAOD::sTgcMeasContainer > m_stgcKey
void distributePointsAndStore(SpacePointsPerChamber &&hitsPerChamber, SpacePointContainer &finalContainer) const
Distribute the premade spacepoints per chamber into their individual SpacePoint buckets.
std::unordered_map< const MuonGMR4::SpectrometerSector *, SpacePointsPerChamber > PreSortedSpacePointMap
Container abrivation of the presorted space point container per MuonChambers.
SG::ReadHandleKey< xAOD::MdtDriftCircleContainer > m_mdtKey
StatusCode record(std::unique_ptr< T > data)
Record a const object to the store.

◆ extraDeps_update_handler()

void AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::extraDeps_update_handler ( Gaudi::Details::PropertyBase & ExtraDeps)
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

◆ extraOutputDeps()

const DataObjIDColl & AthCommonAlgorithm< Gaudi::Algorithm >::extraOutputDeps ( ) const
overridevirtualinherited

Return the list of extra output dependencies.

This list is extended to include symlinks implied by inheritance relations.

Definition at line 89 of file AthCommonAlgorithm.cxx.

54{
55 // If we didn't find any symlinks to add, just return the collection
56 // from the base class. Otherwise, return the extended collection.
57 if (!m_extendedExtraObjects.empty()) {
59 }
61}
Common base class for algorithms.

◆ fillUncombinedSpacePoints()

template<typename PrdType>
void MuonR4::SpacePointMakerAlg::fillUncombinedSpacePoints ( const ActsTrk::GeometryContext & gctx,
const Amg::Transform3D & sectorTrans,
const PrdVec_t< const PrdType * > & prdsToFill,
std::vector< SpacePoint > & outColl ) const
private

Transform the uncombined space prd measurements to space points.

Parameters
gctxGeometry context to fetch the transformation of the measurements
sectorTransTransformation to go from the global -> sector frame
prdsToFillList of uncombined measurements to transform
outCollReference to the mutable output collection to which the 1D space points are appended.

Local coordinate system aligned such that the strips point along local y

The measurement is a phi measurement

Definition at line 231 of file SpacePointMakerAlg.cxx.

234 {
235 if (prdsToFill.empty()) {
236 return;
237 }
238 const PrdType* refMeas = prdsToFill.front();
239 bool allSpArePhi{false};
240
241 const Amg::Transform3D toSectorTrans = toChamberTransform(gctx, sectorTrans, *refMeas);
243 Amg::Vector3D sensorDir{Amg::Vector3D::Zero()}, toNextSen{Amg::Vector3D::Zero()};
245 if constexpr(std::is_same_v<PrdType, xAOD::RpcMeasurement> ||
246 std::is_same_v<PrdType, xAOD::TgcStrip>) {
247 allSpArePhi = refMeas->measuresPhi();
248 const auto& stripLayout = refMeas->readoutElement()->sensorLayout(refMeas->layerHash());
249 const auto& design = stripLayout->design(allSpArePhi);
250 sensorDir = toSectorTrans.linear() * stripLayout->to3D(design.stripDir(), allSpArePhi);
251 toNextSen = toSectorTrans.linear() * stripLayout->to3D(design.stripNormal(), allSpArePhi);
252 ATH_MSG_VERBOSE("Fill space points for "<<m_idHelperSvc->toString(refMeas->identify())
253 <<" -> sensor: "<<Amg::toString(sensorDir)<<", "<<Amg::toString(toNextSen));
254 } else if constexpr (std::is_same_v<PrdType, xAOD::sTgcMeasurement>){
255 allSpArePhi = refMeas->channelType() == xAOD::sTgcMeasurement::sTgcChannelTypes::Wire;
256 const auto& stripLayout = refMeas->readoutElement()->stripLayer(refMeas->measurementHash());
257 const auto& design = stripLayout.design(allSpArePhi);
258 sensorDir = toSectorTrans.linear() * stripLayout.to3D(design.stripDir(), allSpArePhi);
259 toNextSen = toSectorTrans.linear() * stripLayout.to3D(design.stripNormal(), allSpArePhi);
260 } else {
261 sensorDir = toSectorTrans.linear().col(Amg::y);
262 toNextSen = toSectorTrans.linear().col(Amg::x);
263 }
264 outColl.reserve(outColl.size() + prdsToFill.size());
265 for (const PrdType* prd: prdsToFill) {
266 SpacePoint& newSp = outColl.emplace_back(prd);
267 if constexpr (std::is_same_v<PrdType, xAOD::TgcStrip>) {
268 if (allSpArePhi) {
269 const auto& stripLayout = refMeas->readoutElement()->sensorLayout(refMeas->layerHash());
270 const auto& radialDesign = static_cast<const MuonGMR4::RadialStripDesign&>(stripLayout->design(allSpArePhi));
271 toNextSen = toSectorTrans.linear() * stripLayout->to3D(radialDesign.stripNormal(prd->channelNumber()), allSpArePhi);
272 sensorDir = toSectorTrans.linear() * stripLayout->to3D(radialDesign.stripDir(prd->channelNumber()), allSpArePhi);
273 }
274 }
275 newSp.setPosition(toSectorTrans * prd->localMeasurementPos());
276 newSp.setDirection(sensorDir, toNextSen);
277 auto cov = Acts::filledArray<double,3>(0.);
278 if (prd->numDimensions() == 2) {
279 cov[Acts::toUnderlying(CovIdx::etaCov)] = prd->template localCovariance<2>()(0,0);
280 cov[Acts::toUnderlying(CovIdx::phiCov)] = prd->template localCovariance<2>()(1,1);
281 } else {
283 auto covIdx{Acts::toUnderlying(CovIdx::etaCov)},
284 lenIdx{Acts::toUnderlying(CovIdx::phiCov)};
285 if (!newSp.measuresEta()) {
286 std::swap(covIdx, lenIdx);
287 }
288 cov[covIdx] = prd->template localCovariance<1>()[0];
289 cov[lenIdx] = Acts::square(sensorHalfLength(*prd));
290 }
291 newSp.setCovariance(std::move(cov));
292 }
293}
ServiceHandle< Muon::IMuonIdHelperSvc > m_idHelperSvc
std::string toString(const Translation3D &translation, int precision=4)
GeoPrimitvesToStringConverter.
Eigen::Affine3d Transform3D
Eigen::Matrix< double, 3, 1 > Vector3D
void swap(ElementLinkVector< DOBJ > &lhs, ElementLinkVector< DOBJ > &rhs)

◆ filterPassed()

virtual bool AthCommonAlgorithm< Gaudi::Algorithm >::filterPassed ( const EventContext & ctx) const
inlinevirtualinherited

Get filter decision:

Definition at line 93 of file AthCommonAlgorithm.h.

93 {
94 return execState( ctx ).filterPassed();
95 }
virtual bool filterPassed(const EventContext &ctx) const
Get filter decision:

◆ finalize()

StatusCode MuonR4::SpacePointMakerAlg::finalize ( )
override

########################################## SpacePointMakerAlg #########################################

Definition at line 154 of file SpacePointMakerAlg.cxx.

154 {
155 if (m_statCounter) {
156 m_statCounter->dumpStatisics(msgStream());
157 }
158 return StatusCode::SUCCESS;
159}

◆ getBucketParameters()

const SpacePointMakerAlg::BucketParameters & MuonR4::SpacePointMakerAlg::getBucketParameters ( const SpacePoint & spacePoint) const
private

Returns the bucket parameters for a given space point.

Parameters
spacePointSpace point for which to get the bucket parameters
Returns
A reference to the BucketParameters struct for the space point

Definition at line 785 of file SpacePointMakerAlg.cxx.

785 {
786 const MuonGMR4::Chamber* chamber = spacePoint.chamber();
787
788 ATH_MSG_DEBUG("Resolving bucket parameters for chamber "<<chamber->identString());
789
790 if (const auto itr = m_bucketParameters.find(chamber);
791 itr != m_bucketParameters.end()) {
792 ATH_MSG_DEBUG("FOUNDPARAMS!" );
793 return itr->second;
794 }
795
797}
BucketParameters m_defaultBucketParameters
Default bucket parameters used if no chamber-specific parameters are found, defaults into m_spacePoin...
std::unordered_map< const MuonGMR4::Chamber *, BucketParameters > m_bucketParameters
Map of bucket parameters for each chamber.

◆ initialize()

StatusCode MuonR4::SpacePointMakerAlg::initialize ( )
override

Definition at line 160 of file SpacePointMakerAlg.cxx.

160 {
161 ATH_CHECK(m_geoCtxKey.initialize());
162 ATH_CHECK(m_mdtKey.initialize(!m_mdtKey.empty()));
163 ATH_CHECK(m_rpcKey.initialize(!m_rpcKey.empty()));
164 ATH_CHECK(m_tgcKey.initialize(!m_tgcKey.empty()));
165 ATH_CHECK(m_mmKey.initialize(!m_mmKey.empty()));
166 ATH_CHECK(m_stgcKey.initialize(!m_stgcKey.empty()));
167 ATH_CHECK(m_idHelperSvc.retrieve());
168 ATH_CHECK(m_writeKey.initialize());
169 if (m_doStat) {
170 m_statCounter = std::make_unique<SpacePointStatistics>(m_idHelperSvc.get());
171 }
172
173
174 //Initialize the chamber-based bucket windows and max bucket lengths
176 .spacePointWindow = m_spacePointWindow.value(),
177 .maxBucketLength = m_maxBucketLength.value(),
178 .spacePointOverlap= m_spacePointOverlap.value()
179 };
180
181 ATH_CHECK(detStore()->retrieve(m_detMgr));
182 const auto chambers = m_detMgr->getAllChambers();
183
184 m_bucketParameters.reserve(chambers.size());
185 for (const MuonGMR4::Chamber* chamber : chambers) {
186 const std::optional<BucketParameters> parameters = resolveBucketParameters(*chamber);
187
188 //Fill only the chambers for which we have at least one match, the rest will be filled with the default parameters on demand
189 if (!parameters) {
190 continue;
191 }
192
193 m_bucketParameters.emplace( chamber, *parameters);
194 }
195
196 ATH_MSG_DEBUG( "Configured chamber-dependent bucket parameters for " << m_bucketParameters.size() << " chambers out of " << chambers.size());
197
198
199 return StatusCode::SUCCESS;
200}
const ServiceHandle< StoreGateSvc > & detStore() const
const MuonGMR4::MuonDetectorManager * m_detMgr
Gaudi::Property< double > m_spacePointWindow
Default space point window size (Max distance between the two eta hits).
Gaudi::Property< bool > m_doStat
Gaudi::Property< double > m_maxBucketLength
Default maximum bucket length (the width of the bucket in local y coordinate).
Gaudi::Property< double > m_spacePointOverlap
Default space point overlap (the margin around the edge of the bucket which is also coppied into anot...
std::optional< BucketParameters > resolveBucketParameters(const MuonGMR4::Chamber &chamber) const
Resolves the bucket parameters for a given chamber, based on the chamber key and the configured patte...
ActsTrk::GeoContextReadKey_t m_geoCtxKey

◆ inputHandles()

virtual std::vector< Gaudi::DataHandle * > AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::inputHandles ( ) const
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.

◆ isClonable()

virtual bool AthCommonAlgorithm< Gaudi::Algorithm >::isClonable ( ) const
inlineoverridevirtualinherited

Specify if the algorithm is clonable.

Only relevant for non-reentrant algorithms. Actual number of clones needs to be set via the "Cardinality" property.

Reimplemented in AFP_DigiTop, AlgB, AlgT, BCM_Digitization, CscDigitBuilder, CscDigitToCscRDO, G4AtlasAlg, G4RunAlg, HGTD_Digitization, HiveAlgBase, InDet::GNNSeedingTrackMaker, InDet::SCT_Clusterization, InDet::SiSPGNNTrackMaker, InDet::SiSPSeededTrackFinder, InDet::SiTrackerSpacePointFinder, ISF::SimKernelMT, ITk::StripDigitization, ITkPixelCablingAlg, ITkStripCablingAlg, LArHitEMapMaker, LArTTL1Maker, LUCID_DigiTop, LVL1::L1TopoSimulation, MergeCalibHits, MergeGenericMuonSimHitColl, MergeHijingPars, MergeMcEventCollection, MergeTrackRecordCollection, MergeTruthJets, MergeTruthParticles, MuonDigitizer, PileUpMTAlg, PixelDigitization, RoIBResultToxAOD, SCT_ByteStreamErrorsTestAlg, SCT_CablingCondAlgFromCoraCool, SCT_CablingCondAlgFromText, SCT_ConditionsParameterTestAlg, SCT_ConditionsSummaryTestAlg, SCT_ConfigurationConditionsTestAlg, SCT_Digitization, 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, SGInputLoader, Simulation::BeamEffectsAlg, TileHitVecToCnt, TileMuonFitter, TilePulseForTileMuonReceiver, TileRawChannelMaker, TRTDigitization, and ZDC_DigiTop.

Definition at line 68 of file AthCommonAlgorithm.h.

68 {
69 return true;
70 }

◆ loadContainerAndSort() [1/2]

template<typename ContType>
StatusCode MuonR4::SpacePointMakerAlg::loadContainerAndSort ( const EventContext & ctx,
const SG::ReadHandleKey< ContType > & key,
PreSortedSpacePointMap & fillContainer ) const
private

Retrieve an uncalibrated measurement container <ContType> and fill the hits into the presorted space point map.

Per associated MuonChamber, hits from Tgc, Rpc, sTgcs are grouped by their gasGap location and then divided into eta & phi measurements. If both are found, each eta measurement is combined with phi measurement into a SpacePoint. In any other case, the measurements are just transformed into a SpacePoint.

Parameters
ctxEvent context of the current event
keyReadHandleKey to access the container of data type <ContType>
fillContainerGlobal container into which all space points are filled.

Loop over the chamber hits to split the hits per gasGap

Fill in the 2D measurements BIL Rpc

Only one dimensional space points can be built

Simple combination by taking the cross-product

There's no valid combination with another phi hit

Tgc measurements with different bunch crossing tags cannot be combined

Definition at line 335 of file SpacePointMakerAlg.cxx.

337 {
338 const ContType* measurementCont{nullptr};
339 ATH_CHECK(SG::get(measurementCont, key, ctx));
340 if (!measurementCont || measurementCont->empty()){
341 ATH_MSG_DEBUG("nothing to do");
342 return StatusCode::SUCCESS;
343 }
344 const ActsTrk::GeometryContext* gctx{nullptr};
345 ATH_CHECK(SG::get(gctx, m_geoCtxKey, ctx));
346
347 xAOD::ChamberViewer viewer{*measurementCont};
348
349 do {
350 SpacePointsPerChamber& pointsInChamb = fillContainer[viewer.at(0)->readoutElement()->msSector()];
351 const Amg::Transform3D sectorTrans = viewer.at(0)->readoutElement()->msSector()->globalToLocalTransform(*gctx);
352 ATH_MSG_DEBUG("Fill space points for chamber "<<m_idHelperSvc->toStringDetEl(viewer.at(0)->identify()));
353 if constexpr( std::is_same_v<ContType, xAOD::MdtDriftCircleContainer>) {
354 pointsInChamb.etaHits.reserve(pointsInChamb.etaHits.capacity() + viewer.size());
355 for (const auto& prd : viewer) {
356 Amg::Transform3D toChamberTrans{toChamberTransform(*gctx, sectorTrans, *prd)};
357 SpacePoint& sp{pointsInChamb.etaHits.emplace_back(prd)};
358 sp.setPosition(toChamberTrans*prd->localMeasurementPos());
359 sp.setDirection(toChamberTrans.linear().col(Amg::z),
360 toChamberTrans.linear().col(Amg::y));
361 std::array<double, 3> cov{Acts::filledArray<double,3>(0.)};
362 cov[Acts::toUnderlying(CovIdx::etaCov)] = prd->driftRadiusCov();
363 cov[Acts::toUnderlying(CovIdx::phiCov)] = Acts::square(sensorHalfLength(*prd));
364 if (ATH_UNLIKELY(prd->numDimensions() == 2)){
365 cov[Acts::toUnderlying(CovIdx::phiCov)] = static_cast<const xAOD::MdtTwinDriftCircle*>(prd)->posAlongWireCov();
366 }
367 sp.setCovariance(std::move(cov));
368 }
369 } else {
371 for (auto& [etaHits, phiHits, two2DHits] : splitHitsPerGasGap(viewer)) {
372 ATH_MSG_DEBUG("Found "<<etaHits.size()<<"/"<<phiHits.size()
373 <<" 1D and "<<two2DHits.size()<<" 2D hits in chamber "
374 <<m_idHelperSvc->toStringDetEl(viewer.at(0)->identify()));
376 fillUncombinedSpacePoints(*gctx, sectorTrans, two2DHits, pointsInChamb.etaHits);
378 // Check if we do not have 2D occupancy (missing phi or eta hits)
379 if (!passOccupancy2D(etaHits, phiHits)) {
380 fillUncombinedSpacePoints(*gctx, sectorTrans, etaHits, pointsInChamb.etaHits);
381 fillUncombinedSpacePoints(*gctx, sectorTrans, phiHits, pointsInChamb.phiHits);
382 continue;
383 }
384
385 std::vector<std::shared_ptr<unsigned>> etaCounts{matchCountVec(etaHits.size())},
386 phiCounts{matchCountVec(phiHits.size())};
387
388 pointsInChamb.etaHits.reserve(pointsInChamb.etaHits.size() + etaHits.size()*phiHits.size());
390 const auto& firstEta{etaHits.front()};
391 const Amg::Transform3D toSectorTrans = toChamberTransform(*gctx, sectorTrans, *firstEta);
392
393 Amg::Vector3D toNextDir{Amg::Vector3D::Zero()}, sensorDir{Amg::Vector3D::Zero()};
394 if constexpr (std::is_same_v<xAOD::RpcMeasurementContainer, ContType> ||
395 std::is_same_v<xAOD::TgcStripContainer, ContType>) {
396 const auto& stripLayout = firstEta->readoutElement()->sensorLayout(firstEta->layerHash());
397 const auto& design = stripLayout->design();
398 sensorDir = toSectorTrans.linear() * stripLayout->to3D(design.stripDir(), false);
399 toNextDir = toSectorTrans.linear() * stripLayout->to3D(design.stripNormal(), false);
400 } else if constexpr (std::is_same_v<xAOD::sTgcMeasContainer, ContType>){
401 const auto& stripLayout = firstEta->readoutElement()->stripLayer(firstEta->measurementHash());
402 const auto& design = stripLayout.design(false);
403 sensorDir = toSectorTrans.linear() * stripLayout.to3D(design.stripDir(), false);
404 toNextDir = toSectorTrans.linear() * stripLayout.to3D(design.stripNormal(), false);
405 } else {
406 ATH_MSG_ERROR("Unsupported container type");
407 return StatusCode::FAILURE;
408 }
409
410 using namespace Acts::detail::LineHelper;
411 for (unsigned etaP = 0; etaP < etaHits.size(); ++etaP) {
413 for (unsigned phiP = 0; phiP < phiHits.size(); ++ phiP) {
415 if constexpr(std::is_same_v<xAOD::TgcStripContainer, ContType>) {
416 if (!(etaHits[etaP]->bcBitMap() & phiHits[phiP]->bcBitMap())){
417 continue;
418 }
419 const auto& stripLay = phiHits[phiP]->readoutElement()->sensorLayout(phiHits[phiP]->layerHash());
420 const auto& radialDesign = static_cast<const MuonGMR4::RadialStripDesign&>(stripLay->design(true));
421 toNextDir = toSectorTrans.linear() * stripLay->to3D(radialDesign.stripDir(phiHits[phiP]->channelNumber()), true);
422 }
423
424 SpacePoint& newSp = pointsInChamb.etaHits.emplace_back(etaHits[etaP], phiHits[phiP]);
425 newSp.setInstanceCounts(etaCounts[etaP], phiCounts[phiP]);
426
427 auto spIsect = lineIntersect(toSectorTrans*etaHits[etaP]->localMeasurementPos(), sensorDir,
428 toSectorTrans*phiHits[phiP]->localMeasurementPos(), toNextDir);
429 newSp.setPosition(spIsect.position());
430 newSp.setDirection(sensorDir, toNextDir);
431 auto cov = Acts::filledArray<double, 3>(0.);
432 cov[Acts::toUnderlying(CovIdx::etaCov)] = etaHits[etaP]->template localCovariance<1>()[0];
433 cov[Acts::toUnderlying(CovIdx::phiCov)] = phiHits[phiP]->template localCovariance<1>()[0];
435 if constexpr(std::is_same_v<xAOD::TgcStripContainer, ContType>) {
436 const auto& stripLay = phiHits[phiP]->readoutElement()->sensorLayout(phiHits[phiP]->layerHash());
437 const auto& radialDesign = static_cast<const MuonGMR4::RadialStripDesign&>(stripLay->design(true));
438 const Amg::Vector2D planePos = stripLay->to2D(toSectorTrans.inverse()*spIsect.position(), true);
439 cov[Acts::toUnderlying(CovIdx::phiCov)] =
440 Acts::square(radialDesign.stripPitch(phiHits[phiP]->channelNumber(), planePos)) / 12.;
441 }
442
443 newSp.setCovariance(std::move(cov));
444 ATH_MSG_VERBOSE("Created new space point "<<newSp);
445 }
446 }
447 }
448 }
449 } while (viewer.next());
450 return StatusCode::SUCCESS;
451}
#define ATH_MSG_ERROR(x)
#define ATH_UNLIKELY(x)
bool passOccupancy2D(const PrdVec_t< PrdType > &etaHits, const PrdVec_t< PrdType > &phiHits) const
: Check whether the occupancy cuts of hits in a gasGap are surpassed.
void fillUncombinedSpacePoints(const ActsTrk::GeometryContext &gctx, const Amg::Transform3D &sectorTrans, const PrdVec_t< const PrdType * > &prdsToFill, std::vector< SpacePoint > &outColl) const
Transform the uncombined space prd measurements to space points.
EtaPhi2DHitsVec< typename ContType::const_value_type > splitHitsPerGasGap(xAOD::ChamberViewer< ContType > &viewer) const
Splits the chamber hits of the viewer per gas gap.
const_ref at(const std::size_t idx) const
Returns the i-the measurement from the current chamber.
std::size_t size() const noexcept
Returns how many hits are in the current chamber.
Eigen::Matrix< double, 2, 1 > Vector2D
const T * get(const ReadCondHandleKey< T > &key, const EventContext &ctx)
Convenience function to retrieve an object given a ReadCondHandleKey.
MdtTwinDriftCircle_v1 MdtTwinDriftCircle
: Helper struct to collect the space point per muon chamber, which are later sorted into the space po...

◆ loadContainerAndSort() [2/2]

template<>
StatusCode MuonR4::SpacePointMakerAlg::loadContainerAndSort ( const EventContext & ctx,
const SG::ReadHandleKey< xAOD::sTgcMeasContainer > & key,
PreSortedSpacePointMap & fillContainer ) const

Helper function combine an eta and a phi collection. The function takes two indices referrring to the indices of the hit vector inside HitColls

Parameters
collIdxAIndex of the collection to put as phi
collIdxBIndex of the collection to put as eta
combFuncLambda function that rejects hits which cannot be combined due to geometry reasons.

Skip if one of collections are empty

Get first hit from the first collection

The hit in the collection has already been used

Definition at line 454 of file SpacePointMakerAlg.cxx.

456 {
457
458 const xAOD::sTgcMeasContainer* measurementCont{nullptr};
459 ATH_CHECK(SG::get(measurementCont, key, ctx));
460 if (!measurementCont || measurementCont->empty()){
461 ATH_MSG_DEBUG("nothing to do");
462 return StatusCode::SUCCESS;
463 }
464 const ActsTrk::GeometryContext* gctx{nullptr};
465 ATH_CHECK(SG::get(gctx, m_geoCtxKey, ctx));
466 xAOD::ChamberViewer viewer{*measurementCont};
467 using namespace Acts::detail::LineHelper;
468 do {
469 SpacePointsPerChamber& pointsInChamb = fillContainer[viewer.at(0)->readoutElement()->msSector()];
470 const Amg::Transform3D sectorTrans = viewer.at(0)->readoutElement()->msSector()->globalToLocalTransform(*gctx);
471 ATH_MSG_DEBUG(__func__<<"() "<<__LINE__<<" - Fill space points for multiplet "<<m_idHelperSvc->toStringDetEl(viewer.at(0)->identify()));
472 for(auto& HitColls: splitHitsPerGasGap(viewer)){
473 auto& [etaHits, phiHits, two2DHits] = HitColls;
474 std::array<std::vector<std::shared_ptr<unsigned>>, 3> instanceCounts{matchCountVec(etaHits.size()),
475 matchCountVec(phiHits.size()),
476 matchCountVec(two2DHits.size())};
477
478 //loop through the Prds and try to combine according` to the hierarchy
479 // Strip+Wire
480 // Strip+Pad
481 // Wire+Pad
482 // Pad
490 auto combineMe = [&](const std::size_t collIdxA,
491 const std::size_t collIdxB,
492 const std::function<bool(const xAOD::sTgcMeasurement*,
493 const xAOD::sTgcMeasurement*)>& combFunc) {
494 std::vector<char> combinedFlagsA{}, combinedFlagsB{};
495 std::ranges::transform(instanceCounts[collIdxA], std::back_inserter(combinedFlagsA),
496 [](const std::shared_ptr<unsigned>& countPtr){
497 return (*countPtr) == 0;
498 });
499 std::ranges::transform(instanceCounts[collIdxB], std::back_inserter(combinedFlagsB),
500 [](const std::shared_ptr<unsigned>& countPtr){
501 return (*countPtr) == 0;
502 });
503
504 const auto& collA = HitColls[collIdxA];
505 const auto& collB = HitColls[collIdxB];
506
508 if(collA.empty() || collB.empty()) {
509 ATH_MSG_DEBUG(__func__<<"() "<<__LINE__<<" - Skipping combination: both collections empty");
510 return;
511 }
512
514 const xAOD::sTgcMeasurement* firstHit = collB.front();
515 const Amg::Transform3D toSectorTrans = toChamberTransform(*gctx, sectorTrans, *firstHit);
516
517 for(std::size_t idxA = 0; idxA < collA.size(); ++idxA) {
519 if(!combinedFlagsA[idxA]) {
520 ATH_MSG_VERBOSE(__func__<<"() "<<__LINE__<<" - Hit "<<m_idHelperSvc->toString(collA[idxA]->identify())
521 <<" has been used in previous iteration");
522 continue;
523 }
524 for(std::size_t idxB = 0; idxB < collB.size(); ++idxB) {
525 if(!combinedFlagsB[idxB] || !combFunc(collA[idxA], collB[idxB])){
526 ATH_MSG_VERBOSE(__func__<<"() "<<__LINE__<<" - Hit "<<m_idHelperSvc->toString(collB[idxB]->identify())
527 <<" has been used in previous iteration. Or is incompatible with "
528 <<m_idHelperSvc->toString(collA[idxA]->identify()));
529 continue;
530 }
531 //create space point
532 ATH_MSG_VERBOSE(__func__<<"() "<<__LINE__<<" - Combine sTgc measurements "
533 <<m_idHelperSvc->toString(collA[idxA]->identify())<<" and "
534 <<m_idHelperSvc->toString(collB[idxB]->identify())<< "with local positions"
535 << Amg::toString(collA[idxA]->localMeasurementPos()) << " and "
536 << Amg::toString(collB[idxB]->localMeasurementPos())
537 <<" to new space point");
538
539 SpacePoint& newSp = pointsInChamb.etaHits.emplace_back(collB[idxB], collA[idxA]);
540 auto crossPoint = lineIntersect<3>(collA[idxA]->localMeasurementPos(),
541 Amg::Vector3D::UnitX(),
542 collB[idxB]->localMeasurementPos(),
543 Amg::Vector3D::UnitY());
544
545 newSp.setPosition(toSectorTrans*crossPoint.position());
546 newSp.setDirection(Amg::Vector3D::UnitX(), Amg::Vector3D::UnitY());
547 auto cov = Acts::filledArray<double, 3>(0.);
548 cov[Acts::toUnderlying(CovIdx::phiCov)] = covElement(*collA[idxA], CovIdx::phiCov);
549 cov[Acts::toUnderlying(CovIdx::etaCov)] = covElement(*collB[idxB], CovIdx::etaCov);
550 newSp.setCovariance(std::move(cov));
551 newSp.setInstanceCounts(instanceCounts[collIdxB][idxB], instanceCounts[collIdxA][idxA]);
552 ATH_MSG_VERBOSE("Created new space point "<<newSp);
553 }
554 }
555 };
556
557 //try to combine strip with wire measurements first
558 combineMe(1, 0, [&](const xAOD::sTgcMeasurement* wire,
560 // do not combine the strips with the wire that are in the etaZero region
561 const MuonGMR4::sTgcReadoutElement* readoutElement = strip->readoutElement();
562 if(readoutElement->isEtaZero(strip->measurementHash(),
563 strip->localMeasurementPos().block<2,1>(0,0))){
564 return false;
565 }
566 //ignore combinations where the wire and the strip are not crossing
567 //check if the projection of the crossing point is within the bounds of the layer
568 Amg::Vector3D crossPoint = strip->localMeasurementPos() + wire->localMeasurementPos();
569 const Acts::Surface& surf = readoutElement->surface(strip->layerHash());
570 return surf.insideBounds(crossPoint.block<2,1>(0,0));
571 });
572
573 //combine strip and pad measurements
574 combineMe(2, 0, [&](const xAOD::sTgcMeasurement* pad,
576 // do not combine the strips with the pads that are not overlayed
577 const MuonGMR4::sTgcReadoutElement* readoutElement = pad ->readoutElement();
578 const MuonGMR4::PadDesign& padDesign = readoutElement->padDesign(pad->measurementHash());
579 double padHeight = padDesign.padHeight();
580 const Amg::Vector3D padCenter = pad->localMeasurementPos();
581
582 return std::abs(strip->localMeasurementPos().x() - padCenter.x()) < 0.5*padHeight;
583 });
584
585 //finally combine wire and pad measurements
586 combineMe(1, 2, [&](const xAOD::sTgcMeasurement* wire,
587 const xAOD::sTgcMeasurement* pad){
588 // do not combine the wires with the pads that are not overlayed
589 const MuonGMR4::sTgcReadoutElement* readoutElement = pad ->readoutElement();
590 const std::array<Amg::Vector2D, 4> localPadCorners = readoutElement->localPadCorners(pad->measurementHash());
591 auto [min,max] = std::ranges::minmax_element(localPadCorners.begin(), localPadCorners.end(),
592 [](const Amg::Vector2D& a, const Amg::Vector2D& b){
593 return a.y() < b.y();
594 });
595 return (wire->localMeasurementPos().y() > min->y() || wire->localMeasurementPos().y() < max->y());
596
597 });
598
599 //fill uncombined strip, wire and pad measurements that have not been used in combination
600 for(std::size_t collIdx = 0; collIdx < HitColls.size(); ++collIdx){
601 const auto& hits = HitColls[collIdx];
602 std::vector<const xAOD::sTgcMeasurement*> unusedHits{};
603 unusedHits.reserve(hits.size());
604
605 for(std::size_t idx = 0; idx < hits.size(); ++idx){
606 if((*instanceCounts[collIdx][idx]) == 0){
607 unusedHits.push_back(hits[idx]);
608 }
609 }
610 fillUncombinedSpacePoints(*gctx, sectorTrans, unusedHits, pointsInChamb.etaHits);
611 }
612 }
613 } while (viewer.next());
614 return StatusCode::SUCCESS;
615}
#define min(a, b)
Definition cfImp.cxx:40
#define max(a, b)
Definition cfImp.cxx:41
bool empty() const noexcept
Returns true if the collection is empty.
const Acts::Surface & surface() const override final
Returns the surface associated with the readout element.
double padHeight() const
Returns the height of all the pads that are not adjacent to the bottom edge of the trapezoid active a...
const PadDesign & padDesign(const IdentifierHash &measHash) const
Retrieves the readoutElement Layer given the Identifier/Hash.
localCornerArray localPadCorners(const IdentifierHash &measHash) const
bool isEtaZero(const IdentifierHash &measurementHash, const Amg::Vector2D &localPosition) const
bool next()
Loads the hits from the next chamber.
const MuonGMR4::sTgcReadoutElement * readoutElement() const override final
Retrieve the associated sTgcReadoutElement.
IdentifierHash measurementHash() const override final
Returns the hash of the measurement channel w.r.t ReadoutElement.
Amg::Vector3D localMeasurementPos() const override final
Returns the local measurement position as 3-vector.
sTgcMeasContainer_v1 sTgcMeasContainer
setBGCode setTAP setLVL2ErrorBits bool
sTgcMeasurement_v1 sTgcMeasurement

◆ msg()

MsgStream & AthCommonMsg< Gaudi::Algorithm >::msg ( ) const
inlineinherited

Definition at line 24 of file AthCommonMsg.h.

24 {
25 return this->msgStream();
26 }

◆ msgLvl()

bool AthCommonMsg< Gaudi::Algorithm >::msgLvl ( const MSG::Level lvl) const
inlineinherited

Definition at line 30 of file AthCommonMsg.h.

30 {
31 return this->msgLevel(lvl);
32 }

◆ newBucket()

void MuonR4::SpacePointMakerAlg::newBucket ( const SpacePoint & refSp,
SpacePointBucketVec & sortedPoints,
const BucketParameters & bucketParams ) const
private

Closes the current processed bucket and creates a new one.

Space points of the previous bucket within the overlap region to the first space point of the new bucket are copied over

Parameters
refSpFirst new space point which will be added to the new bucket.
sortedPointsList of all processed buckets in the chamber. The list is augmented by 1 element
bucketParamsParameters defining the bucket properties

Set the boundaries from the previous bucket

Copy space points that could be within the overlap region to the next bucket

Definition at line 715 of file SpacePointMakerAlg.cxx.

717 {
718 SpacePointBucket& newContainer = sortedPoints.emplace_back();
719 newContainer.setBucketId(sortedPoints.size() -1);
720
722 SpacePointBucket& overlap{sortedPoints[sortedPoints.size() - 2]};
723 overlap.setCoveredRange(overlap.front()->localPosition().y(),
724 overlap.back()->localPosition().y());
725
726 const double refBound = refSpacePoint.localPosition().y();
727
728
730 for (const std::shared_ptr<SpacePoint>& pointInBucket : overlap | std::views::reverse) {
731 const double overlapPos = pointInBucket->localPosition().y() +
732 std::sqrt(pointInBucket->covariance()[Acts::toUnderlying(CovIdx::etaCov)]);
733 if (refBound - overlapPos < bucketParams.spacePointOverlap) {
734 newContainer.insert(newContainer.begin(), pointInBucket);
735 } else {
736 break;
737 }
738 }
739
740}

◆ outputHandles()

virtual std::vector< Gaudi::DataHandle * > AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::outputHandles ( ) const
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.

◆ passOccupancy2D() [1/4]

template<>
bool MuonR4::SpacePointMakerAlg::passOccupancy2D ( const PrdVec_t< const xAOD::MMCluster * > & ,
const PrdVec_t< const xAOD::MMCluster * > &  ) const

Definition at line 226 of file SpacePointMakerAlg.cxx.

227 {
228 return false;
229 }

◆ passOccupancy2D() [2/4]

template<>
bool MuonR4::SpacePointMakerAlg::passOccupancy2D ( const PrdVec_t< const xAOD::RpcMeasurement * > & etaHits,
const PrdVec_t< const xAOD::RpcMeasurement * > & phiHits ) const

Definition at line 214 of file SpacePointMakerAlg.cxx.

215 {
216 if (etaHits.empty() || phiHits.empty()) {
217 return false;
218 }
219 const MuonGMR4::RpcReadoutElement* re = etaHits[0]->readoutElement();
220 ATH_MSG_VERBOSE("Collected "<<etaHits.size()<<"/"<<phiHits.size()<<" hits in "<<m_idHelperSvc->toStringGasGap(etaHits[0]->identify()));
221 return ((1.*etaHits.size()) / (1.*re->nEtaStrips())) < m_maxOccRpcEta &&
222 ((1.*phiHits.size()) / (1.*re->nPhiStrips())) < m_maxOccRpcPhi;
223 }
const std::regex re(r_e)
Gaudi::Property< double > m_maxOccRpcEta
Gaudi::Property< double > m_maxOccRpcPhi

◆ passOccupancy2D() [3/4]

template<>
bool MuonR4::SpacePointMakerAlg::passOccupancy2D ( const PrdVec_t< const xAOD::TgcStrip * > & etaHits,
const PrdVec_t< const xAOD::TgcStrip * > & phiHits ) const

Definition at line 203 of file SpacePointMakerAlg.cxx.

204 {
205 if (etaHits.empty() || phiHits.empty()) {
206 return false;
207 }
208 const MuonGMR4::TgcReadoutElement* re = etaHits[0]->readoutElement();
209 ATH_MSG_VERBOSE("Collected "<<etaHits.size()<<"/"<<phiHits.size()<<" hits in "<<m_idHelperSvc->toStringGasGap(etaHits[0]->identify()));
210 return ((1.*etaHits.size()) / ((1.*re->numChannels(etaHits[0]->measurementHash())))) < m_maxOccTgcEta &&
211 ((1.*phiHits.size()) / ((1.*re->numChannels(phiHits[0]->measurementHash())))) < m_maxOccTgcPhi;
212 }
Gaudi::Property< double > m_maxOccTgcEta
Gaudi::Property< double > m_maxOccTgcPhi

◆ passOccupancy2D() [4/4]

template<typename PrdType>
bool MuonR4::SpacePointMakerAlg::passOccupancy2D ( const PrdVec_t< PrdType > & etaHits,
const PrdVec_t< PrdType > & phiHits ) const
private

: Check whether the occupancy cuts of hits in a gasGap are surpassed.

The method is specified for each of the 3 strip technologies, Rpc, Tgc, sTgc and applies a technology-dependent upper bound on the number of phi & eta hits. If the threshold is surpassed, only 1D space points are built intsead of 2D ones

Parameters
etaHitsList of all presorted eta measurements in a gas gap
phiHitsList of all presorted phi measurements in a gas gap

◆ renounce()

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 > AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::renounce ( T & h)
inlineprotectedinherited

Definition at line 380 of file AthCommonDataStore.h.

381 {
382 h.renounce();
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()

void AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::renounceArray ( SG::VarHandleKeyArray & handlesArray)
inlineprotectedinherited

remove all handles from I/O resolution

Definition at line 364 of file AthCommonDataStore.h.

364 {
366 }

◆ resolveBucketParameters()

std::optional< SpacePointMakerAlg::BucketParameters > MuonR4::SpacePointMakerAlg::resolveBucketParameters ( const MuonGMR4::Chamber & chamber) const
private

Resolves the bucket parameters for a given chamber, based on the chamber key and the configured patterns.

Parameters
chamberChamber for which to resolve the bucket parameters
Returns
A BucketParameters struct containing the resolved parameters for the chamber

Definition at line 842 of file SpacePointMakerAlg.cxx.

843 {
844
845 const std::string chamberKey = chamberConfigKey(chamber);
846
847 const ResolvedParameter maxLength = resolveParameter(
848 chamberKey,
849 m_maxBucketLength.value(),
851
852 const ResolvedParameter hitWindow = resolveParameter(
853 chamberKey,
854 m_spacePointWindow.value(),
856
857 const ResolvedParameter overlap = resolveParameter(
858 chamberKey,
859 m_spacePointOverlap.value(),
861
862 // No chamber-dependent setting matched.
863 if (!maxLength.matched &&
864 !hitWindow.matched &&
865 !overlap.matched) {
866 return std::nullopt;
867 }
868
870 .spacePointWindow = hitWindow.value,
871 .maxBucketLength = maxLength.value,
872 .spacePointOverlap = overlap.value
873 };
874
876 "Resolved bucket override for " << chamberKey
877 << ": maxBucketLength=" << parameters.maxBucketLength
878 << (maxLength.matched ? " [override]" : " [default]")
879 << ", spacePointWindow=" << parameters.spacePointWindow
880 << (hitWindow.matched ? " [override]" : " [default]")
881 << ", spacePointOverlap=" << parameters.spacePointOverlap
882 << (overlap.matched ? " [override]" : " [default]"));
883
884 return parameters;
885}
ResolvedParameter resolveParameter(const std::string_view chamberKey, const double defaultValue, const BucketPatternMap &patterns) const
Resolves a specific parameter for a given chamber key, based on the configured patterns.
Gaudi::Property< BucketPatternMap > m_spacePointOverlapPatterns
Chamber-pattern dependent space point overlap.
Gaudi::Property< BucketPatternMap > m_maxBucketLengthPatterns
Chamber-pattern dependent maximum bucket length.
std::string chamberConfigKey(const MuonGMR4::Chamber &chamber) const
Returns a string key for a chamber, based on the space point identifier.
Gaudi::Property< BucketPatternMap > m_spacePointWindowPatterns
Chamber-pattern dependent space point window.
Helper struct to store the resolved bucket parameters for a given chamber.

◆ resolveParameter()

SpacePointMakerAlg::ResolvedParameter MuonR4::SpacePointMakerAlg::resolveParameter ( const std::string_view chamberKey,
const double defaultValue,
const BucketPatternMap & patterns ) const
private

Resolves a specific parameter for a given chamber key, based on the configured patterns.

Parameters
chamberKeyKey (e.g. EML_eta-1_phi3) of the chamber
defaultValueDefault value to use if no match is found
patternsMap of patterns to values
Returns
The resolved parameter value

Definition at line 799 of file SpacePointMakerAlg.cxx.

802 {
803
804 // Exact match (e.g. BIL_eta-3_phi3) has the highest priority.
805 if (const auto exactItr = patterns.find(chamberKey);
806 exactItr != patterns.end()) {
807 return {
808 .value = exactItr->second,
809 .matched = true
810 };
811 }
812
813 double resolvedValue = defaultValue;
814 std::size_t bestPrefixLength = 0;
815 bool matched = false;
816
817 // Otherwise select the most-specific matching prefix wildcard (e.g. BIL_eta-3* or BIL*).
818 for (const auto& [pattern, value] : patterns) {
819 if (pattern.empty() || pattern.back() != '*') {
820 continue;
821 }
822
823 const std::string_view prefix{
824 pattern.data(),
825 pattern.size() - 1
826 };
827
828 if (chamberKey.starts_with(prefix) &&
829 prefix.size() > bestPrefixLength) {
830 bestPrefixLength = prefix.size();
831 resolvedValue = value;
832 matched = true;
833 }
834 }
835
836 return {
837 .value = resolvedValue,
838 .matched = matched
839 };
840}
std::vector< std::string > patterns
Definition listroot.cxx:187

◆ setFilterPassed()

virtual void AthCommonAlgorithm< Gaudi::Algorithm >::setFilterPassed ( bool state,
const EventContext & ctx ) const
inlinevirtualinherited

Set filter decision:

Reimplemented in AthFilterAlgorithm.

Definition at line 99 of file AthCommonAlgorithm.h.

99 {
101 }
virtual void setFilterPassed(bool state, const EventContext &ctx) const
Set filter decision:

◆ splitBucket()

bool MuonR4::SpacePointMakerAlg::splitBucket ( const SpacePoint & spacePoint,
const double firstSpPos,
const SpacePointBucketVec & sortedPoints,
const BucketParameters & bucketParams ) const
private

Returns whether the space point is beyond the bucket boundary.

Parameters
spacePointSpace point candidate to add to the bucket
sortedPointsContainer of all defined buckets in the chamber
bucketParamsParameters defining the bucket properties
Returns
True if the space point should start a new bucket, false otherwise

Distance between this point and the first one exceeds the maximum length

Definition at line 685 of file SpacePointMakerAlg.cxx.

687 {
688
690 const double spY = spacePoint.localPosition().y();
691
692 if (spY - firstSpPos > bucketParams.maxBucketLength){
693 ATH_MSG_DEBUG("Splitting bucket based on maxLength. First space point Y=" << firstSpPos
694 << " current space point Y =" << spY
695 << " m_maxBucketLength=" << bucketParams.maxBucketLength );
696 return true;
697 }
698
699 if (sortedPoints.empty() || sortedPoints.back().empty()) {
700 return false;
701 }
702
703 const double gap = spY - sortedPoints.back().back()->localPosition().y();
704
705
706 if (gap > bucketParams.spacePointWindow){
707 ATH_MSG_DEBUG("Splitting bucket based on gap. Last space point Y=" << sortedPoints.back().back()->localPosition().y()
708 << " current space point Y =" << spY
709 << " gap=" << gap
710 << " window=" << bucketParams.spacePointWindow);
711 }
712
713 return gap > bucketParams.spacePointWindow;
714}
gap(flags, cells_name, *args, **kw)

◆ splitHitsPerGasGap()

template<typename ContType>
SpacePointMakerAlg::EtaPhi2DHitsVec< typename ContType::const_value_type > MuonR4::SpacePointMakerAlg::splitHitsPerGasGap ( xAOD::ChamberViewer< ContType > & viewer) const
private

Splits the chamber hits of the viewer per gas gap.

Parameters
viewerChamber viewer containing all hits in the chamber
Returns
Vector of gas gap hit collections. Each entry contains 3 vectors:
  • eta hits
  • phi hits
  • 2D hits

Wires measure the phi coordinate

Tgc & Rpcs have the measuresPhi property

Sort in the hit

Definition at line 298 of file SpacePointMakerAlg.cxx.

298 {
299 std::vector<EtaPhi2DHits<typename ContType::const_value_type>> hitsPerGasGap{};
300 for (const auto& prd : viewer) {
301 ATH_MSG_VERBOSE("Create space point from "<<m_idHelperSvc->toString(prd->identify())
302 <<", hash: "<<prd->identifierHash());
303
304 unsigned gapIdx = prd->gasGap() -1;
305 if constexpr (std::is_same_v<ContType, xAOD::RpcMeasurementContainer>) {
306 gapIdx = prd->readoutElement()->createHash(0, prd->gasGap(), prd->doubletPhi(), false);
307 }
308 if (hitsPerGasGap.size() <= gapIdx) {
309 hitsPerGasGap.resize(gapIdx + 1);
310 }
311 bool measPhi{false};
312 if constexpr(std::is_same_v<ContType, xAOD::sTgcMeasContainer>) {
314 measPhi = prd->channelType() == sTgcIdHelper::sTgcChannelTypes::Wire;
315 } else if constexpr(!std::is_same_v<ContType, xAOD::MMClusterContainer>) {
317 measPhi = prd->measuresPhi();
318 }
319
320 if (prd->numDimensions() == 2) {
321 hitsPerGasGap[gapIdx][2].push_back(prd);
322 continue;
323 }
325 auto& toPush = hitsPerGasGap[gapIdx][measPhi];
326 if (toPush.capacity() == toPush.size()) {
327 toPush.reserve(toPush.size() + m_capacityBucket);
328 }
329 toPush.push_back(prd);
330 }
331 return hitsPerGasGap;
332}
Gaudi::Property< unsigned > m_capacityBucket

◆ sysExecute()

StatusCode AthCommonAlgorithm< Gaudi::Algorithm >::sysExecute ( const EventContext & ctx)
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.

Reimplemented in AthAnalysisAlgorithm.

Definition at line 80 of file AthCommonAlgorithm.cxx.

41{
42 return BaseAlg::sysExecute (ctx);
43}

◆ sysInitialize()

StatusCode AthCommonAlgorithm< Gaudi::Algorithm >::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< Gaudi::Algorithm > >.

Reimplemented in AthAnalysisAlgorithm, AthFilterAlgorithm, AthHistogramAlgorithm, HypoBase, InputMakerBase, and PyAthena::Alg.

Definition at line 60 of file AthCommonAlgorithm.cxx.

71 {
73
74 if (sc.isFailure()) {
75 return sc;
76 }
77
78 ServiceHandle<ICondSvc> cs("CondSvc",name());
79 for (auto h : outputHandles()) {
80 if (h->isCondition() && h->mode() == Gaudi::DataHandle::Writer) {
81 // do this inside the loop so we don't create the CondSvc until needed
82 if ( cs.retrieve().isFailure() ) {
83 ATH_MSG_WARNING("no CondSvc found: won't autoreg WriteCondHandles");
85 }
86 if (cs->regHandle(this,*h).isFailure()) {
88 ATH_MSG_ERROR("unable to register WriteCondHandle " << h->fullKey()
89 << " with CondSvc");
90 }
91 }
92 }
93 return sc;
94}
#define ATH_MSG_WARNING(x)
virtual StatusCode sysInitialize() override
virtual std::vector< Gaudi::DataHandle * > outputHandles() const override

◆ sysStart()

virtual StatusCode AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::sysStart ( )
overridevirtualinherited

Handle START transition.

We override this in order to make sure that conditions handle keys can cache a pointer to the conditions container.

◆ updateVHKA()

void AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::updateVHKA ( Gaudi::Details::PropertyBase & )
inlineinherited

Definition at line 308 of file AthCommonDataStore.h.

308 {
309 // debug() << "updateVHKA for property " << p.name() << " " << p.toString()
310 // << " size: " << m_vhka.size() << endmsg;
311 for (auto &a : m_vhka) {
313 for (auto k : keys) {
314 k->setOwner(this);
315 }
316 }
317 }

Member Data Documentation

◆ ATLAS_THREAD_SAFE

std::unique_ptr<SpacePointStatistics> m_statCounter MuonR4::SpacePointMakerAlg::ATLAS_THREAD_SAFE {}
private

Definition at line 289 of file SpacePointMakerAlg.h.

289{};

◆ m_bucketParameters

std::unordered_map<const MuonGMR4::Chamber*, BucketParameters> MuonR4::SpacePointMakerAlg::m_bucketParameters {}
private

Map of bucket parameters for each chamber.

Definition at line 281 of file SpacePointMakerAlg.h.

281{};

◆ m_capacityBucket

Gaudi::Property<unsigned> MuonR4::SpacePointMakerAlg::m_capacityBucket {this,"CapacityBucket" , 50}
private

Definition at line 288 of file SpacePointMakerAlg.h.

288{this,"CapacityBucket" , 50};

◆ m_defaultBucketParameters

BucketParameters MuonR4::SpacePointMakerAlg::m_defaultBucketParameters {}
private

Default bucket parameters used if no chamber-specific parameters are found, defaults into m_spacePointWindow, m_maxBucketLength, and m_spacePointOverlap.

Definition at line 283 of file SpacePointMakerAlg.h.

283{};

◆ m_detMgr

const MuonGMR4::MuonDetectorManager* MuonR4::SpacePointMakerAlg::m_detMgr {nullptr}
private

Definition at line 247 of file SpacePointMakerAlg.h.

247{nullptr};

◆ m_detStore

StoreGateSvc_t AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::m_detStore
privateinherited

Pointer to StoreGate (detector store by default).

Definition at line 393 of file AthCommonDataStore.h.

◆ m_doStat

Gaudi::Property<bool> MuonR4::SpacePointMakerAlg::m_doStat
private
Initial value:
{this, "doStats", false,
"If enabled the algorithm keeps track how many hits have been made" }

Definition at line 285 of file SpacePointMakerAlg.h.

285 {this, "doStats", false,
286 "If enabled the algorithm keeps track how many hits have been made" };

◆ m_evtStore

StoreGateSvc_t AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::m_evtStore
privateinherited

Pointer to StoreGate (event store by default).

Definition at line 390 of file AthCommonDataStore.h.

◆ m_extendedExtraObjects

DataObjIDColl AthCommonAlgorithm< Gaudi::Algorithm >::m_extendedExtraObjects
privateinherited

Extra output dependency collection, extended by AthAlgorithmDHUpdate to add symlinks.

Empty if no symlinks were found.

Definition at line 108 of file AthCommonAlgorithm.h.

◆ m_geoCtxKey

ActsTrk::GeoContextReadKey_t MuonR4::SpacePointMakerAlg::m_geoCtxKey {this, "AlignmentKey", "ActsAlignment", "cond handle key"}
private

Definition at line 245 of file SpacePointMakerAlg.h.

245{this, "AlignmentKey", "ActsAlignment", "cond handle key"};

◆ m_idHelperSvc

ServiceHandle<Muon::IMuonIdHelperSvc> MuonR4::SpacePointMakerAlg::m_idHelperSvc {this, "IdHelperSvc", "Muon::MuonIdHelperSvc/MuonIdHelperSvc"}
private

Definition at line 249 of file SpacePointMakerAlg.h.

249{this, "IdHelperSvc", "Muon::MuonIdHelperSvc/MuonIdHelperSvc"};

◆ m_maxBucketLength

Gaudi::Property<double> MuonR4::SpacePointMakerAlg::m_maxBucketLength
private
Initial value:
{this, "maxBucketLength", 2.*Gaudi::Units::m,
"Maximal size of a space point bucket"}

Default maximum bucket length (the width of the bucket in local y coordinate).

Can be overridden by chamber-specific patterns

Parameters
maxBucketLengthDefault maximum bucket length in meters

Definition at line 259 of file SpacePointMakerAlg.h.

259 {this, "maxBucketLength", 2.*Gaudi::Units::m,
260 "Maximal size of a space point bucket"};

◆ m_maxBucketLengthPatterns

Gaudi::Property<BucketPatternMap> MuonR4::SpacePointMakerAlg::m_maxBucketLengthPatterns
private
Initial value:
{ this, "maxBucketLengthPatterns", {},
"Chamber-pattern dependent max bucket length. " "Examples: BML*=0.5, BIL_eta3_phi3=0.2"}

Chamber-pattern dependent maximum bucket length.

Example: cfg.getEventAlgo("MuonSpacePointMakerAlg").maxBucketLengthPatterns = {"BIL_eta3_phi3": 0.2 * m, "BML*": 0.5 * m}

Definition at line 273 of file SpacePointMakerAlg.h.

273 { this, "maxBucketLengthPatterns", {},
274 "Chamber-pattern dependent max bucket length. " "Examples: BML*=0.5, BIL_eta3_phi3=0.2"};

◆ m_maxOccRpcEta

Gaudi::Property<double> MuonR4::SpacePointMakerAlg::m_maxOccRpcEta
private
Initial value:
{this, "maxRpcEtaOccupancy", 0.1,
"Maximum occpancy of Rpc eta hits in a gasGap"}

Definition at line 291 of file SpacePointMakerAlg.h.

291 {this, "maxRpcEtaOccupancy", 0.1,
292 "Maximum occpancy of Rpc eta hits in a gasGap"};

◆ m_maxOccRpcPhi

Gaudi::Property<double> MuonR4::SpacePointMakerAlg::m_maxOccRpcPhi
private
Initial value:
{this, "maxRpcPhiOccupancy", 0.1,
"Maximum occpancy of Rpc phi hits in a gasGap"}

Definition at line 293 of file SpacePointMakerAlg.h.

293 {this, "maxRpcPhiOccupancy", 0.1,
294 "Maximum occpancy of Rpc phi hits in a gasGap"};

◆ m_maxOccTgcEta

Gaudi::Property<double> MuonR4::SpacePointMakerAlg::m_maxOccTgcEta
private
Initial value:
{this, "maxTgcEtaOccupancy", 0.1,
"Maximum occpancy of Tgc eta hits in a gasGap"}

Definition at line 296 of file SpacePointMakerAlg.h.

296 {this, "maxTgcEtaOccupancy", 0.1,
297 "Maximum occpancy of Tgc eta hits in a gasGap"};

◆ m_maxOccTgcPhi

Gaudi::Property<double> MuonR4::SpacePointMakerAlg::m_maxOccTgcPhi
private
Initial value:
{this, "maxTgcPhiOccupancy", 0.1,
"Maximum occpancy of Tgc phi hits in a gasGap"}

Definition at line 298 of file SpacePointMakerAlg.h.

298 {this, "maxTgcPhiOccupancy", 0.1,
299 "Maximum occpancy of Tgc phi hits in a gasGap"};

◆ m_mdtKey

SG::ReadHandleKey<xAOD::MdtDriftCircleContainer> MuonR4::SpacePointMakerAlg::m_mdtKey
private
Initial value:
{this, "MdtKey", "xMdtMeasurements",
"Key to the uncalibrated Drift circle measurements"}

Definition at line 230 of file SpacePointMakerAlg.h.

230 {this, "MdtKey", "xMdtMeasurements",
231 "Key to the uncalibrated Drift circle measurements"};

◆ m_mmKey

SG::ReadHandleKey<xAOD::MMClusterContainer> MuonR4::SpacePointMakerAlg::m_mmKey
private
Initial value:
{this, "MmKey", "xAODMMClusters",
"Key to the uncalibrated 1D Mm hits"}

Definition at line 239 of file SpacePointMakerAlg.h.

239 {this, "MmKey", "xAODMMClusters",
240 "Key to the uncalibrated 1D Mm hits"};

◆ m_rpcKey

SG::ReadHandleKey<xAOD::RpcMeasurementContainer> MuonR4::SpacePointMakerAlg::m_rpcKey
private
Initial value:
{this, "RpcKey", "xRpcMeasurements",
"Key to the uncalibrated 1D rpc hits"}

Definition at line 233 of file SpacePointMakerAlg.h.

233 {this, "RpcKey", "xRpcMeasurements",
234 "Key to the uncalibrated 1D rpc hits"};

◆ m_spacePointOverlap

Gaudi::Property<double> MuonR4::SpacePointMakerAlg::m_spacePointOverlap
private
Initial value:
{this, "spacePointOverlap", 25.*Gaudi::Units::cm,
"Hits that are within <spacePointOverlap> of the bucket margin. "
"Are copied to the next bucket"}

Default space point overlap (the margin around the edge of the bucket which is also coppied into another bucket).

Can be overridden by chamber-specific patterns

Parameters
spacePointOverlapDefault space point overlap in meters

Definition at line 264 of file SpacePointMakerAlg.h.

264 {this, "spacePointOverlap", 25.*Gaudi::Units::cm,
265 "Hits that are within <spacePointOverlap> of the bucket margin. "
266 "Are copied to the next bucket"};

◆ m_spacePointOverlapPatterns

Gaudi::Property<BucketPatternMap> MuonR4::SpacePointMakerAlg::m_spacePointOverlapPatterns
private
Initial value:
{ this, "spacePointOverlapPatterns", {},
"Chamber-dependent overrides of spacePointOverlap" }

Chamber-pattern dependent space point overlap.

Example: cfg.getEventAlgo("MuonSpacePointMakerAlg").spacePointOverlapPatterns = {"BIL_eta3_phi3": 0.2 * m, "BML*": 0.5 * m}

Definition at line 277 of file SpacePointMakerAlg.h.

277 { this, "spacePointOverlapPatterns", {},
278 "Chamber-dependent overrides of spacePointOverlap" };

◆ m_spacePointWindow

Gaudi::Property<double> MuonR4::SpacePointMakerAlg::m_spacePointWindow
private
Initial value:
{this, "spacePointWindowSize", 0.8*Gaudi::Units::m,
"Maximal distance between consecutive hits in a bucket"}

Default space point window size (Max distance between the two eta hits).

Can be overridden by chamber-specific patterns

Parameters
spacePointWindowSizeDefault space point window size in meters

Definition at line 255 of file SpacePointMakerAlg.h.

255 {this, "spacePointWindowSize", 0.8*Gaudi::Units::m,
256 "Maximal distance between consecutive hits in a bucket"};

◆ m_spacePointWindowPatterns

Gaudi::Property<BucketPatternMap> MuonR4::SpacePointMakerAlg::m_spacePointWindowPatterns
private
Initial value:
{ this, "spacePointWindowPatterns", {},
"Chamber-pattern dependent space point window. " "Examples: BML*=0.5, BIL_eta3_phi3=0.2"}

Chamber-pattern dependent space point window.

Example: cfg.getEventAlgo("MuonSpacePointMakerAlg").spacePointWindowPatterns = {"BIL_eta3_phi3": 0.2 * m, "BML*": 0.5 * m, "BOL_eta3*": 0.7 * m}

Definition at line 269 of file SpacePointMakerAlg.h.

269 { this, "spacePointWindowPatterns", {},
270 "Chamber-pattern dependent space point window. " "Examples: BML*=0.5, BIL_eta3_phi3=0.2"};

◆ m_stgcKey

SG::ReadHandleKey<xAOD::sTgcMeasContainer> MuonR4::SpacePointMakerAlg::m_stgcKey {this, "sTgcKey", "xAODsTgcMeasurements"}
private

Definition at line 242 of file SpacePointMakerAlg.h.

242{this, "sTgcKey", "xAODsTgcMeasurements"};

◆ m_tgcKey

SG::ReadHandleKey<xAOD::TgcStripContainer> MuonR4::SpacePointMakerAlg::m_tgcKey
private
Initial value:
{this, "TgcKey", "xTgcStrips",
"Key to the uncalibrated 1D tgc hits"}

Definition at line 236 of file SpacePointMakerAlg.h.

236 {this, "TgcKey", "xTgcStrips",
237 "Key to the uncalibrated 1D tgc hits"};

◆ m_varHandleArraysDeclared

bool AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::m_varHandleArraysDeclared
privateinherited

Definition at line 399 of file AthCommonDataStore.h.

◆ m_vhka

std::vector<SG::VarHandleKeyArray*> AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::m_vhka
privateinherited

Definition at line 398 of file AthCommonDataStore.h.

◆ m_writeKey

SG::WriteHandleKey<SpacePointContainer> MuonR4::SpacePointMakerAlg::m_writeKey {this, "WriteKey", "MuonSpacePoints"}
private

Definition at line 251 of file SpacePointMakerAlg.h.

251{this, "WriteKey", "MuonSpacePoints"};

The documentation for this class was generated from the following files: