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

The TrkSegmentCnvAlg converts the SegmentSeeds produced by the R4 pattern recognition chain into the segment seeds that can be consumed by the legacy muon segment maker. More...

#include <TrkSegmentCnvAlg.h>

Inheritance diagram for MuonR4::TrkSegmentCnvAlg:
Collaboration diagram for MuonR4::TrkSegmentCnvAlg:

Public Member Functions

StatusCode initialize () override final
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

using RotVec = std::vector<std::unique_ptr<Trk::RIO_OnTrack>>
typedef ServiceHandle< StoreGateSvcStoreGateSvc_t

Private Member Functions

StatusCode convert (const EventContext &ctx, const MuonR4::Segment &segment, Trk::SegmentCollection &outContainer) const
 Convert the R4 segment and fill the converted segment into the SegmentCollection.
template<class PrdType>
const PrdType * fetchPrd (const Identifier &prdId, const Muon::MuonPrepDataContainerT< PrdType > *prdContainer) const
template<class PrdType>
StatusCode convertMeasurement (const MuonR4::Segment &segment, const CalibratedSpacePoint &spacePoint, const Muon::MuonPrepDataContainerT< PrdType > *prdContainer, RotVec &convMeasVec) const
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
 specialization for handling Gaudi::Property<SG::VarHandleKey>

Private Attributes

ServiceHandle< Muon::IMuonIdHelperSvcm_idHelperSvc
PublicToolHandle< Muon::MuonEDMPrinterToolm_printer {this, "printerTool", "Muon::MuonEDMPrinterTool/MuonEDMPrinterTool"}
SG::ReadHandleKey< Muon::TgcPrepDataContainerm_keyTgc {this, "TgcKey", "TGC_MeasurementsAllBCs"}
 Prep data container keys.
SG::ReadHandleKey< Muon::RpcPrepDataContainerm_keyRpc {this, "RpcKey", "RPC_Measurements"}
SG::ReadHandleKey< Muon::MdtPrepDataContainerm_keyMdt {this, "MdtKey", "MDT_DriftCircles"}
SG::ReadHandleKey< Muon::sTgcPrepDataContainerm_keysTgc {this, "sTgcKey", "STGC_Measurements"}
SG::ReadHandleKey< Muon::MMPrepDataContainerm_keyMM {this, "MmKey", "MM_Measurements"}
SG::ReadHandleKey< ActsTrk::GeometryContextm_geoCtxKey {this, "AlignmentKey", "ActsAlignment", "cond handle key"}
SG::ReadHandleKeyArray< SegmentContainerm_readKeys {this, "ReadSegments", {"R4MuonSegments"}}
SG::WriteHandleKey< Trk::SegmentCollectionm_writeKey {this, "WriteKey", "TrackMuonSegmentsR4"}
ToolHandle< Muon::IMdtDriftCircleOnTrackCreatorm_mdtCreator {this,"MdtRotCreator",""}
ToolHandle< Muon::IMuonClusterOnTrackCreatorm_clusterCreator {this,"ClusterRotCreator",""}
ToolHandle< Muon::IMuonCompetingClustersOnTrackCreatorm_compClusterCreator {this, "CompetingRotCreator", ""}
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

The TrkSegmentCnvAlg converts the SegmentSeeds produced by the R4 pattern recognition chain into the segment seeds that can be consumed by the legacy muon segment maker.

Definition at line 25 of file TrkSegmentCnvAlg.h.

Member Typedef Documentation

◆ RotVec

using MuonR4::TrkSegmentCnvAlg::RotVec = std::vector<std::unique_ptr<Trk::RIO_OnTrack>>
private

Definition at line 49 of file TrkSegmentCnvAlg.h.

◆ StoreGateSvc_t

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

Definition at line 388 of file AthCommonDataStore.h.

Member Function Documentation

◆ cardinality()

unsigned int AthCommonReentrantAlgorithm< Gaudi::Algorithm >::cardinality ( ) const
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.

64{
65 return 0;
66}

◆ convert()

StatusCode MuonR4::TrkSegmentCnvAlg::convert ( const EventContext & ctx,
const MuonR4::Segment & segment,
Trk::SegmentCollection & outContainer ) const
private

Convert the R4 segment and fill the converted segment into the SegmentCollection.

Parameters
ctxEventContext to access the alignment & calibration constants
segmentReference to the segment to convert
outContainerReference to the output container to parse

Next build a surface

Definition at line 134 of file TrkSegmentCnvAlg.cxx.

136 {
137
138 const Muon::RpcPrepDataContainer* rpcPrds{nullptr};
139 const Muon::MdtPrepDataContainer* mdtPrds{nullptr};
140 const Muon::TgcPrepDataContainer* tgcPrds{nullptr};
141 const Muon::sTgcPrepDataContainer* stgcPrds{nullptr};
142 const Muon::MMPrepDataContainer* mmPrds{nullptr};
143
144 ATH_CHECK(SG::get(mdtPrds, m_keyMdt, ctx));
145 ATH_CHECK(SG::get(rpcPrds, m_keyRpc, ctx));
146 ATH_CHECK(SG::get(tgcPrds, m_keyTgc, ctx));
147 ATH_CHECK(SG::get(stgcPrds, m_keysTgc, ctx));
148 ATH_CHECK(SG::get(mmPrds, m_keyMM, ctx));
149
150 const ActsTrk::GeometryContext* gctx{nullptr};
151 ATH_CHECK(SG::get(gctx, m_geoCtxKey, ctx));
152
153 std::vector<std::unique_ptr<Trk::RIO_OnTrack>> rots{};
154 unsigned int nPrec{0};
155 for (const Segment::MeasType& spacePoint : segment.measurements()){
156 if (spacePoint->fitState() != CalibratedSpacePoint::State::Valid) {
157 ATH_MSG_VERBOSE("'Reject invalid measurement'");
158 continue;
159 }
160 switch (spacePoint->type()) {
162 ATH_CHECK(convertMeasurement(segment, *spacePoint, mdtPrds, rots));
163 ++nPrec;
164 break;
165 }
167 ATH_CHECK(convertMeasurement(segment,*spacePoint, rpcPrds, rots));
168 break;
169 }
171 ATH_CHECK(convertMeasurement(segment,*spacePoint, tgcPrds, rots));
172 break;
173 }
175 ATH_CHECK(convertMeasurement(segment,*spacePoint, mmPrds, rots));
176 ++nPrec;
177 break;
178 }
180 ATH_CHECK(convertMeasurement(segment,*spacePoint, stgcPrds, rots));
181 ++nPrec;
182 break;
183 }
185 break;
186 default:
187 ATH_MSG_WARNING("Unsupported measurement type ");
188 }
189 }
190
191 DataVector<const Trk::MeasurementBase> measurements{};
192 auto makeCompetingROT = [this, &measurements](RotVec& rots) {
193 if (rots.empty()){
194 return;
195 }
196 std::list<const Trk::PrepRawData*> prds{};
197 for (const std::unique_ptr<Trk::RIO_OnTrack>& rot : rots) {
198 prds.push_back(rot->prepRawData());
199 }
200 measurements.push_back(m_compClusterCreator->createBroadCluster(std::move(prds),0.));
201 rots.clear();
202 };
203
204 RotVec etaPrds{}, phiPrds{};
205 for (std::unique_ptr<Trk::RIO_OnTrack>& rot : rots) {
206 const Trk::PrepRawData* prd = rot->prepRawData();
208 std::vector<std::unique_ptr<Trk::RIO_OnTrack>>& pushMe{m_idHelperSvc->measuresPhi(rot->identify())? phiPrds : etaPrds};
209 if (pushMe.size() && pushMe.back()->detectorElement() != rot->detectorElement()){
210 makeCompetingROT(pushMe);
211 } else {
212 pushMe.push_back(std::move(rot));
213 }
214
215 } else {
216 makeCompetingROT(etaPrds);
217 makeCompetingROT(phiPrds);
218 measurements.push_back(std::move(rot));
219 }
220 }
221 makeCompetingROT(etaPrds);
222 makeCompetingROT(phiPrds);
223 if (!nPrec) {
224 ATH_MSG_WARNING("No precision hit on "<<std::endl<<m_printer->print(measurements.stdcont())
225 <<". Do not convert segment due to potential puff.");
226 return StatusCode::SUCCESS;
227 }
228 ATH_MSG_DEBUG("Fetched in total "<<measurements.size()<<" measurements. "<<std::endl<<
229 m_printer->print(measurements.stdcont()));
231 const Amg::Transform3D& locToGlob{segment.msSector()->localToGlobalTrans(*gctx)};
232 auto segSurf = std::make_unique<Trk::PlaneSurface>(Amg::getTransformFromRotTransl(locToGlob.linear(), segment.position()));
233 Trk::LocalDirection segDir{};
234 segSurf->globalToLocalDirection(segment.direction(), segDir);
235 std::vector<Identifier> holes{};
236 auto fitQuality = std::make_unique<Muon::MuonSegmentQuality>(segment.chi2(),
237 static_cast<double>(segment.nDoF()),
238 std::move(holes));
239
241 covMatrix.setIdentity();
242 using namespace MuonR4::SegmentFit;
243 covMatrix(Trk::locX, Trk::locX) = segment.covariance()(Acts::toUnderlying(ParamDefs::x0), Acts::toUnderlying(ParamDefs::x0));
244 covMatrix(Trk::locY, Trk::locY) = segment.covariance()(Acts::toUnderlying(ParamDefs::y0), Acts::toUnderlying(ParamDefs::y0));
245
246 covMatrix(Trk::phi0, Trk::phi0) = segment.covariance()(Acts::toUnderlying(ParamDefs::phi), Acts::toUnderlying(ParamDefs::phi));
247 covMatrix(Trk::theta, Trk::theta) = segment.covariance()(Acts::toUnderlying(ParamDefs::theta), Acts::toUnderlying(ParamDefs::theta));
248
249 auto legacySeg = std::make_unique<Muon::MuonSegment>(Amg::Vector2D::Zero(), std::move(segDir),
250 std::move(covMatrix), segSurf.release(),
251 std::move(measurements), fitQuality.release());
252
253 ATH_MSG_VERBOSE(m_printer->print(*legacySeg)<<", pos: "<<Amg::toString(legacySeg->globalPosition())<<" "
254 <<Amg::toString(legacySeg->globalDirection())<<std::endl<<m_printer->print(legacySeg->containedMeasurements()));
255 outContainer.push_back(std::move(legacySeg));
256 return StatusCode::SUCCESS;
257 }
#define ATH_CHECK
Evaluate an expression and check for errors.
#define ATH_MSG_VERBOSE(x)
#define ATH_MSG_WARNING(x)
#define ATH_MSG_DEBUG(x)
value_type push_back(value_type pElem)
Add an element to the end of the collection.
const PtrVector & stdcont() const
Return the underlying std::vector of the container.
size_type size() const noexcept
Returns the number of elements in the collection.
const Amg::Transform3D & localToGlobalTrans(const ActsTrk::GeometryContext &gctx) const
Returns the local -> global tarnsformation from the sector.
unsigned int nDoF() const
Returns the number of degrees of freedom.
const SegmentFit::Covariance & covariance() const
Returns the uncertainties of the defining parameters.
const MuonGMR4::SpectrometerSector * msSector() const
Returns the associated MS sector.
std::unique_ptr< CalibratedSpacePoint > MeasType
Calibrated space point type.
const MeasVec & measurements() const
Returns the associated measurements.
const Amg::Vector3D & position() const
Returns the global segment position.
const Amg::Vector3D & direction() const
Returns the global segment direction.
StatusCode convertMeasurement(const MuonR4::Segment &segment, const CalibratedSpacePoint &spacePoint, const Muon::MuonPrepDataContainerT< PrdType > *prdContainer, RotVec &convMeasVec) const
SG::ReadHandleKey< Muon::RpcPrepDataContainer > m_keyRpc
std::vector< std::unique_ptr< Trk::RIO_OnTrack > > RotVec
SG::ReadHandleKey< ActsTrk::GeometryContext > m_geoCtxKey
SG::ReadHandleKey< Muon::MdtPrepDataContainer > m_keyMdt
ServiceHandle< Muon::IMuonIdHelperSvc > m_idHelperSvc
PublicToolHandle< Muon::MuonEDMPrinterTool > m_printer
SG::ReadHandleKey< Muon::TgcPrepDataContainer > m_keyTgc
Prep data container keys.
ToolHandle< Muon::IMuonCompetingClustersOnTrackCreator > m_compClusterCreator
SG::ReadHandleKey< Muon::MMPrepDataContainer > m_keyMM
SG::ReadHandleKey< Muon::sTgcPrepDataContainer > m_keysTgc
virtual bool type(PrepRawDataType type) const
Interface method checking the type.
std::string toString(const Translation3D &translation, int precision=4)
GeoPrimitvesToStringConverter.
Eigen::Matrix< double, Eigen::Dynamic, Eigen::Dynamic > MatrixX
Dynamic Matrix - dynamic allocation.
Amg::Transform3D getTransformFromRotTransl(Amg::RotationMatrix3D rot, Amg::Vector3D transl_vec)
Eigen::Affine3d Transform3D
MuonPrepDataContainerT< RpcPrepData > RpcPrepDataContainer
MuonPrepDataContainerT< TgcPrepData > TgcPrepDataContainer
MuonPrepDataContainerT< MdtPrepData > MdtPrepDataContainer
MuonPrepDataContainerT< sTgcPrepData > sTgcPrepDataContainer
MuonPrepDataContainerT< MMPrepData > MMPrepDataContainer
const T * get(const ReadCondHandleKey< T > &key, const EventContext &ctx)
Convenience function to retrieve an object given a ReadCondHandleKey.
FitQualityOnSurface fitQuality(const MultiComponentState &, const MeasurementBase &)
Method for determining the chi2 of the multi-component state and the number of degrees of freedom.
@ locY
local cartesian
Definition ParamDefs.h:38
@ locX
Definition ParamDefs.h:37
@ phi0
Definition ParamDefs.h:65
@ theta
Definition ParamDefs.h:66

◆ convertMeasurement()

template<class PrdType>
StatusCode MuonR4::TrkSegmentCnvAlg::convertMeasurement ( const MuonR4::Segment & segment,
const CalibratedSpacePoint & spacePoint,
const Muon::MuonPrepDataContainerT< PrdType > * prdContainer,
RotVec & convMeasVec ) const
private

Definition at line 74 of file TrkSegmentCnvAlg.cxx.

77 {
78 bool added{false};
79
80 for (const xAOD::UncalibratedMeasurement* uncalib: {spacePoint.spacePoint()->primaryMeasurement(),
81 spacePoint.spacePoint()->secondaryMeasurement()}){
82 if (!uncalib) continue;
83 added = true;
84
85 const PrdType* prd = fetchPrd(xAOD::identify(uncalib), prdContainer);
86 if (!prd) {
87 ATH_MSG_FATAL("Failed to retrieve segment from "<<m_idHelperSvc->toString(xAOD::identify(uncalib)));
88 return StatusCode::FAILURE;
89 }
90 const Trk::Surface& surf{prd->detectorElement()->surface(prd->identify())};
91 Trk::Intersection isect = surf.straightLineIntersection(segment.position(), segment.direction());
92
93 std::unique_ptr<Trk::RIO_OnTrack> rot{};
94 if constexpr(std::is_same_v<PrdType, Muon::MdtPrepData>) {
95 rot = std::unique_ptr<Trk::RIO_OnTrack>{m_mdtCreator->createRIO_OnTrack(*prd,
96 isect.position,
97 &segment.direction())};
98 } else {
99 rot = std::unique_ptr<Trk::RIO_OnTrack>{m_clusterCreator->createRIO_OnTrack(*prd,
100 isect.position,
101 segment.direction())};
102 if constexpr (std::is_same_v<PrdType, Muon::sTgcPrepData>) {
103 const sTgcIdHelper& idHelper{m_idHelperSvc->stgcIdHelper()};
104 if (!rot && idHelper.channelType(prd->identify()) == sTgcIdHelper::sTgcChannelTypes::Wire) {
105 const Amg::Vector3D locPos = prd->detectorElement()->transform(prd->identify()).inverse() *
106 isect.position;
107 if (prd->detectorElement()->isEtaZero(prd->identify(), locPos.block<2,1>(0,0))){
108 ATH_MSG_WARNING("Hit from inactive region "<<m_idHelperSvc->toString(prd->identify())
109 <<", "<<Amg::toString(locPos)<<" cannot be translated.");
110 continue;
111 }
112 }
113 }
114 }
115 if(!rot && m_idHelperSvc->issTgc(prd->identify())) {
116 ATH_MSG_WARNING("sTGC ROT creation failed for "<<m_idHelperSvc->toString(prd->identify()));
117 continue;
118 }
119
120 if (!rot) {
121 ATH_MSG_ERROR("Failed to create rot from "<<m_idHelperSvc->toString(prd->identify()));
122 return StatusCode::FAILURE;
123 }
124 ATH_MSG_VERBOSE("Created ROT "<<m_printer->print(*rot));
125 convMeasVec.push_back(std::move(rot));
126 }
127 if (!added) {
128 ATH_MSG_ERROR("Could not translate space point "<<m_idHelperSvc->toString(spacePoint.spacePoint()->identify()));
129 return StatusCode::FAILURE;
130 }
131 return StatusCode::SUCCESS;
132 }
#define ATH_MSG_ERROR(x)
#define ATH_MSG_FATAL(x)
ToolHandle< Muon::IMuonClusterOnTrackCreator > m_clusterCreator
ToolHandle< Muon::IMdtDriftCircleOnTrackCreator > m_mdtCreator
const PrdType * fetchPrd(const Identifier &prdId, const Muon::MuonPrepDataContainerT< PrdType > *prdContainer) const
Intersection straightLineIntersection(const T &pars, bool forceDir=false, const Trk::BoundaryCheck &bchk=false) const
fst straight line intersection schema - templated for charged and neutral parameters
int channelType(const Identifier &id) const
Eigen::Matrix< double, 3, 1 > Vector3D
const Identifier & identify(const UncalibratedMeasurement *meas)
Returns the associated identifier from the muon measurement.
UncalibratedMeasurement_v1 UncalibratedMeasurement
Define the version of the uncalibrated measurement class.
Amg::Vector3D position

◆ 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.

◆ 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::TrkSegmentCnvAlg::execute ( const EventContext & ctx) const
finaloverride

Definition at line 34 of file TrkSegmentCnvAlg.cxx.

34 {
35
36 auto translatedSegments = std::make_unique<Trk::SegmentCollection>();
37 for (const SG::ReadHandleKey<SegmentContainer>& key : m_readKeys) {
38 const SegmentContainer* translateMe{nullptr};
39 ATH_CHECK(SG::get(translateMe, key, ctx));
40 for (const Segment* segment : *translateMe) {
41 ATH_CHECK(convert(ctx, *segment, *translatedSegments));
42 }
43
44 }
45 ATH_MSG_VERBOSE("Translated in total "<<translatedSegments->size()<<" segments.");
46
47 SG::WriteHandle writeHandle{m_writeKey, ctx};
48 ATH_CHECK(writeHandle.record(std::move(translatedSegments)));
49 return StatusCode::SUCCESS;
50 }
SG::WriteHandleKey< Trk::SegmentCollection > m_writeKey
StatusCode convert(const EventContext &ctx, const MuonR4::Segment &segment, Trk::SegmentCollection &outContainer) const
Convert the R4 segment and fill the converted segment into the SegmentCollection.
SG::ReadHandleKeyArray< SegmentContainer > m_readKeys
StatusCode record(std::unique_ptr< T > data)
Record a const object to the store.
DataVector< Segment > SegmentContainer

◆ 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 & AthCommonReentrantAlgorithm< 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 94 of file AthCommonReentrantAlgorithm.cxx.

90{
91 // If we didn't find any symlinks to add, just return the collection
92 // from the base class. Otherwise, return the extended collection.
93 if (!m_extendedExtraObjects.empty()) {
95 }
97}
An algorithm that can be simultaneously executed in multiple threads.

◆ fetchPrd()

template<class PrdType>
const PrdType * MuonR4::TrkSegmentCnvAlg::fetchPrd ( const Identifier & prdId,
const Muon::MuonPrepDataContainerT< PrdType > * prdContainer ) const
private

Definition at line 52 of file TrkSegmentCnvAlg.cxx.

53 {
54 if (!prdContainer) {
55 ATH_MSG_ERROR("Cannot fetch a prep data object as the container given for "<<
56 m_idHelperSvc->toString(prdId)<<" is a nullptr");
57 return nullptr;
58 }
59 const Muon::MuonPrepDataCollection<PrdType>* coll = prdContainer->indexFindPtr(m_idHelperSvc->moduleHash(prdId));
60 if (!coll) {
61 ATH_MSG_ERROR("No prep data collection where "<<m_idHelperSvc->toString(prdId)<<" can reside in.");
62 return nullptr;
63 }
64 for (const PrdType* prd : *coll) {
65 if (prd->identify() == prdId){
66 return prd;
67 }
68 }
69 ATH_MSG_ERROR("There is no measurement "<<m_idHelperSvc->toString(prdId));
70
71 return nullptr;
72 }
virtual const T * indexFindPtr(IdentifierHash hashId) const override final
return pointer on the found entry or null if out of range using hashed index - fast version,...

◆ filterPassed()

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

Definition at line 96 of file AthCommonReentrantAlgorithm.h.

96 {
97 return execState( ctx ).filterPassed();
98 }
virtual bool filterPassed(const EventContext &ctx) const

◆ initialize()

StatusCode MuonR4::TrkSegmentCnvAlg::initialize ( )
finaloverride

Definition at line 17 of file TrkSegmentCnvAlg.cxx.

17 {
18 ATH_CHECK(m_idHelperSvc.retrieve());
19
20 ATH_CHECK(m_keyTgc.initialize(!m_keyTgc.empty()));
21 ATH_CHECK(m_keyRpc.initialize(!m_keyRpc.empty()));
22 ATH_CHECK(m_keyMdt.initialize(!m_keyMdt.empty()));
23 ATH_CHECK(m_keysTgc.initialize(!m_keysTgc.empty()));
24 ATH_CHECK(m_keyMM.initialize(!m_keyMM.empty()));
25 ATH_CHECK(m_readKeys.initialize());
26 ATH_CHECK(m_writeKey.initialize());
27 ATH_CHECK(m_mdtCreator.retrieve());
28 ATH_CHECK(m_clusterCreator.retrieve());
29 ATH_CHECK(m_compClusterCreator.retrieve(EnableTool{!m_keyTgc.empty() || !m_keyRpc.empty()}));
30 ATH_CHECK(m_geoCtxKey.initialize());
31 return StatusCode::SUCCESS;
32 }

◆ 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()

◆ 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 }

◆ 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.

◆ 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 }

◆ setFilterPassed()

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

Definition at line 100 of file AthCommonReentrantAlgorithm.h.

100 {
102 }
virtual void setFilterPassed(bool state, const EventContext &ctx) const

◆ sysExecute()

StatusCode AthCommonReentrantAlgorithm< 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.

Definition at line 85 of file AthCommonReentrantAlgorithm.cxx.

77{
78 return BaseAlg::sysExecute (ctx);
79}

◆ sysInitialize()

StatusCode AthCommonReentrantAlgorithm< 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 HypoBase, and InputMakerBase.

Definition at line 61 of file AthCommonReentrantAlgorithm.cxx.

107 {
109
110 if (sc.isFailure()) {
111 return sc;
112 }
113
114 ServiceHandle<ICondSvc> cs("CondSvc",name());
115 for (auto h : outputHandles()) {
116 if (h->isCondition() && h->mode() == Gaudi::DataHandle::Writer) {
117 // do this inside the loop so we don't create the CondSvc until needed
118 if ( cs.retrieve().isFailure() ) {
119 ATH_MSG_WARNING("no CondSvc found: won't autoreg WriteCondHandles");
120 return StatusCode::SUCCESS;
121 }
122 if (cs->regHandle(this,*h).isFailure()) {
124 ATH_MSG_ERROR("unable to register WriteCondHandle " << h->fullKey()
125 << " with CondSvc");
126 }
127 }
128 }
129 return sc;
130}
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

◆ m_clusterCreator

ToolHandle<Muon::IMuonClusterOnTrackCreator> MuonR4::TrkSegmentCnvAlg::m_clusterCreator {this,"ClusterRotCreator",""}
private

Definition at line 77 of file TrkSegmentCnvAlg.h.

77{this,"ClusterRotCreator",""};

◆ m_compClusterCreator

ToolHandle<Muon::IMuonCompetingClustersOnTrackCreator> MuonR4::TrkSegmentCnvAlg::m_compClusterCreator {this, "CompetingRotCreator", ""}
private

Definition at line 79 of file TrkSegmentCnvAlg.h.

79{this, "CompetingRotCreator", ""}; //<! competing clusters rio ontrack creator

◆ 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_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 AthCommonReentrantAlgorithm< Gaudi::Algorithm >::m_extendedExtraObjects
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.

◆ m_geoCtxKey

SG::ReadHandleKey<ActsTrk::GeometryContext> MuonR4::TrkSegmentCnvAlg::m_geoCtxKey {this, "AlignmentKey", "ActsAlignment", "cond handle key"}
private

Definition at line 68 of file TrkSegmentCnvAlg.h.

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

◆ m_idHelperSvc

ServiceHandle<Muon::IMuonIdHelperSvc> MuonR4::TrkSegmentCnvAlg::m_idHelperSvc
private
Initial value:
{this, "MuonIdHelperSvc",
"Muon::MuonIdHelperSvc/MuonIdHelperSvc"}

Definition at line 56 of file TrkSegmentCnvAlg.h.

56 {this, "MuonIdHelperSvc",
57 "Muon::MuonIdHelperSvc/MuonIdHelperSvc"};

◆ m_keyMdt

SG::ReadHandleKey<Muon::MdtPrepDataContainer> MuonR4::TrkSegmentCnvAlg::m_keyMdt {this, "MdtKey", "MDT_DriftCircles"}
private

Definition at line 63 of file TrkSegmentCnvAlg.h.

63{this, "MdtKey", "MDT_DriftCircles"};

◆ m_keyMM

SG::ReadHandleKey<Muon::MMPrepDataContainer> MuonR4::TrkSegmentCnvAlg::m_keyMM {this, "MmKey", "MM_Measurements"}
private

Definition at line 65 of file TrkSegmentCnvAlg.h.

65{this, "MmKey", "MM_Measurements"};

◆ m_keyRpc

SG::ReadHandleKey<Muon::RpcPrepDataContainer> MuonR4::TrkSegmentCnvAlg::m_keyRpc {this, "RpcKey", "RPC_Measurements"}
private

Definition at line 62 of file TrkSegmentCnvAlg.h.

62{this, "RpcKey", "RPC_Measurements"};

◆ m_keysTgc

SG::ReadHandleKey<Muon::sTgcPrepDataContainer> MuonR4::TrkSegmentCnvAlg::m_keysTgc {this, "sTgcKey", "STGC_Measurements"}
private

Definition at line 64 of file TrkSegmentCnvAlg.h.

64{this, "sTgcKey", "STGC_Measurements"};

◆ m_keyTgc

SG::ReadHandleKey<Muon::TgcPrepDataContainer> MuonR4::TrkSegmentCnvAlg::m_keyTgc {this, "TgcKey", "TGC_MeasurementsAllBCs"}
private

Prep data container keys.

Definition at line 61 of file TrkSegmentCnvAlg.h.

61{this, "TgcKey", "TGC_MeasurementsAllBCs"};

◆ m_mdtCreator

ToolHandle<Muon::IMdtDriftCircleOnTrackCreator> MuonR4::TrkSegmentCnvAlg::m_mdtCreator {this,"MdtRotCreator",""}
private

Definition at line 76 of file TrkSegmentCnvAlg.h.

76{this,"MdtRotCreator",""}; //<! pointer to mdt rio ontrack creator

◆ m_printer

PublicToolHandle<Muon::MuonEDMPrinterTool> MuonR4::TrkSegmentCnvAlg::m_printer {this, "printerTool", "Muon::MuonEDMPrinterTool/MuonEDMPrinterTool"}
private

Definition at line 59 of file TrkSegmentCnvAlg.h.

59{this, "printerTool", "Muon::MuonEDMPrinterTool/MuonEDMPrinterTool"};

◆ m_readKeys

SG::ReadHandleKeyArray<SegmentContainer> MuonR4::TrkSegmentCnvAlg::m_readKeys {this, "ReadSegments", {"R4MuonSegments"}}
private

Definition at line 71 of file TrkSegmentCnvAlg.h.

71{this, "ReadSegments", {"R4MuonSegments"}};

◆ 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<Trk::SegmentCollection> MuonR4::TrkSegmentCnvAlg::m_writeKey {this, "WriteKey", "TrackMuonSegmentsR4"}
private

Definition at line 73 of file TrkSegmentCnvAlg.h.

73{this, "WriteKey", "TrackMuonSegmentsR4"};

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