ATLAS Offline Software
Loading...
Searching...
No Matches
ActsTrk::PixelClusterTruthDecoratorAlg Class Reference

#include <PixelClusterTruthDecoratorAlg.h>

Inheritance diagram for ActsTrk::PixelClusterTruthDecoratorAlg:
Collaboration diagram for ActsTrk::PixelClusterTruthDecoratorAlg:

Public Member Functions

 PixelClusterTruthDecoratorAlg (const std::string &name, ISvcLocator *pSvcLocator)
virtual ~PixelClusterTruthDecoratorAlg ()=default
virtual StatusCode initialize () override
virtual StatusCode execute (const EventContext &ctx) const override
virtual StatusCode sysInitialize () override
 Override sysInitialize.
virtual bool isClonable () const override
 Specify if the algorithm is clonable.
virtual unsigned int cardinality () const override
 Cardinality (Maximum number of clones that can exist) special value 0 means that algorithm is reentrant.
virtual StatusCode sysExecute (const EventContext &ctx) override
 Execute an algorithm.
virtual const DataObjIDColl & extraOutputDeps () const override
 Return the list of extra output dependencies.
virtual bool filterPassed (const EventContext &ctx) const
virtual void setFilterPassed (bool state, const EventContext &ctx) const
ServiceHandle< StoreGateSvc > & evtStore ()
 The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.
const ServiceHandle< StoreGateSvc > & detStore () const
 The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.
virtual StatusCode sysStart () override
 Handle START transition.
virtual std::vector< Gaudi::DataHandle * > inputHandles () const override
 Return this algorithm's input handles.
virtual std::vector< Gaudi::DataHandle * > outputHandles () const override
 Return this algorithm's output handles.
Gaudi::Details::PropertyBase & declareProperty (Gaudi::Property< T, V, H > &t)
void updateVHKA (Gaudi::Details::PropertyBase &)
MsgStream & msg () const
bool msgLvl (const MSG::Level lvl) const

Protected Member Functions

void renounceArray (SG::VarHandleKeyArray &handlesArray)
 remove all handles from I/O resolution
std::enable_if_t< std::is_void_v< std::result_of_t< decltype(&T::renounce)(T)> > &&!std::is_base_of_v< SG::VarHandleKeyArray, T > &&std::is_base_of_v< Gaudi::DataHandle, T >, void > renounce (T &h)
void extraDeps_update_handler (Gaudi::Details::PropertyBase &ExtraDeps)
 Add StoreName to extra input/output deps as needed.

Private Types

typedef ServiceHandle< StoreGateSvcStoreGateSvc_t

Private Member Functions

StatusCode labelMeasurementToKeep (const EventContext &ctx, const xAOD::PixelClusterContainer &clusters, std::vector< bool > &labels) const
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
 specialization for handling Gaudi::Property<SG::VarHandleKey>

Private Attributes

ToolHandle< ISiLorentzAngleToolm_lorentzAngleTool {this, "LorentzAngleTool", ""}
SG::ReadHandleKey< xAOD::PixelClusterContainerm_clustercontainer_key {this,"ClusterContainer", "","Input Pixel Cluster container"}
SG::ReadHandleKey< ActsTrk::MeasurementToTruthParticleAssociationm_associationMap_key {this,"AssociationMapOut","", "Association map between measurements and truth particles"}
SG::ReadHandleKeyArray< xAOD::TrackParticleContainerm_trackParticlesKey {this, "TrackParticles", {}, "Input xAOD::TrackParticles"}
SG::ReadCondHandleKey< InDetDD::SiDetectorElementCollectionm_pixelDetEleCollKey {this, "PixelDetEleCollKey", "ITkPixelDetectorElementCollection"}
SG::WriteHandleKey< xAOD::TrackMeasurementValidationContainerm_write_xaod_key {this,"MeasurementContainer","", "Output Pixel Validation Clusters"}
SG::WriteDecorHandleKey< xAOD::PixelClusterContainerm_trackMeasurement_link {this, "MeasurementLink", m_clustercontainer_key, "validationMeasurementLink"}
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainerm_measurement_truth_indices {this, "MeasurementTruthIndices", m_write_xaod_key, "truth_index"}
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainerm_measurement_truth_barcodes {this, "MeasurementTruthBarcode", m_write_xaod_key, "truth_barcode"}
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainerm_measurement_detectorElementID {this, "MeasurementDetectorElementID", m_write_xaod_key, "detectorElementID"}
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainerm_measurement_waferID {this, "MeasurementWaferID", m_write_xaod_key, "waferID"}
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainerm_measurement_bec {this, "MeasurementBEC", m_write_xaod_key, "bec"}
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainerm_measurement_layer {this, "MeasurementLayer", m_write_xaod_key, "layer"}
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainerm_measurement_sizePhi {this, "MeasurementSizePhi", m_write_xaod_key, "sizePhi"}
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainerm_measurement_sizeZ {this, "MeasurementSizeZ", m_write_xaod_key, "sizeZ"}
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainerm_measurement_SiWidth {this, "MeasurementSiWidth", m_write_xaod_key, "SiWidth"}
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainerm_measurement_eta_module {this, "MeasurementEtaModule", m_write_xaod_key, "eta_module"}
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainerm_measurement_phi_module {this, "MeasurementPhiModule", m_write_xaod_key, "phi_module"}
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainerm_measurement_omegax {this, "MeasurementOmegaX", m_write_xaod_key, "omegax"}
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainerm_measurement_omegay {this, "MeasurementOmegaY", m_write_xaod_key, "omegay"}
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainerm_measurement_LorentzShift {this, "MeasurementLorentzShift", m_write_xaod_key, "LorentzShift"}
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainerm_measurement_centroid_xphi {this, "MeasurementCentroidXphi", m_write_xaod_key, "centroid_xphi"}
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainerm_measurement_centroid_xeta {this, "MeasurementCentroidXeta", m_write_xaod_key, "centroid_xeta"}
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainerm_measurement_side {this, "MeasurementSide", m_write_xaod_key, "side"}
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainerm_measurement_tots {this, "MeasurementToT", m_write_xaod_key, "tots"}
Gaudi::Property< bool > m_useTruthInfo {this, "UseTruthInfo", true}
Gaudi::Property< bool > m_keepOnlyOnTrackMeasurements {this, "KeepOnlyOnTrackMeasurements", false, "Keep on on-track measurements instead of the full collection"}
const PixelIDm_PixelHelper {nullptr}
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

Definition at line 39 of file PixelClusterTruthDecoratorAlg.h.

Member Typedef Documentation

◆ StoreGateSvc_t

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

Definition at line 388 of file AthCommonDataStore.h.

Constructor & Destructor Documentation

◆ PixelClusterTruthDecoratorAlg()

ActsTrk::PixelClusterTruthDecoratorAlg::PixelClusterTruthDecoratorAlg ( const std::string & name,
ISvcLocator * pSvcLocator )

Definition at line 16 of file PixelClusterTruthDecoratorAlg.cxx.

17 :
18 AthReentrantAlgorithm(name, pSvcLocator)
19 {}

◆ ~PixelClusterTruthDecoratorAlg()

virtual ActsTrk::PixelClusterTruthDecoratorAlg::~PixelClusterTruthDecoratorAlg ( )
virtualdefault

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.

62{
63 return 0;
64}

◆ 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 ActsTrk::PixelClusterTruthDecoratorAlg::execute ( const EventContext & ctx) const
overridevirtual

Definition at line 65 of file PixelClusterTruthDecoratorAlg.cxx.

65 {
66
67 //Mandatory. Require if the algorithm is scheduled.
68 SG::ReadHandle<xAOD::PixelClusterContainer> PixelClusterContainer = SG::makeHandle(m_clustercontainer_key,ctx);
71
72 SG::ReadCondHandle<InDetDD::SiDetectorElementCollection> pixelDetEleHandle = SG::makeHandle( m_pixelDetEleCollKey, ctx );
73 ATH_CHECK(pixelDetEleHandle.isValid());
74 const InDetDD::SiDetectorElementCollection* pixelDetEle = pixelDetEleHandle.cptr();
75
76 // Get the truth association map
77 const MeasurementToTruthParticleAssociation* measToTruth(nullptr);
78 if (m_useTruthInfo) {
79 SG::ReadHandle<MeasurementToTruthParticleAssociation> measToTruthHandle = SG::makeHandle(m_associationMap_key,ctx);
80 ATH_CHECK(measToTruthHandle.isValid());
81 measToTruth = measToTruthHandle.cptr();
82 }
83
84 // Setup outputs
85 // Create the xAOD container and its auxiliary store:
86 SG::WriteHandle<xAOD::TrackMeasurementValidationContainer> xaod = SG::makeHandle(m_write_xaod_key,ctx);
87 ATH_CHECK(xaod.record(std::make_unique<xAOD::TrackMeasurementValidationContainer>(),
88 std::make_unique<xAOD::TrackMeasurementValidationAuxContainer>()));
89
90 // Decorations
91 SG::WriteDecorHandle<xAOD::PixelClusterContainer,
93
94 SG::WriteDecorHandle<xAOD::TrackMeasurementValidationContainer, std::uint64_t> decor_detectorElementID ( m_measurement_detectorElementID, ctx );
95 SG::WriteDecorHandle<xAOD::TrackMeasurementValidationContainer, int> decor_waferID ( m_measurement_waferID, ctx );
96 SG::WriteDecorHandle<xAOD::TrackMeasurementValidationContainer, int> decor_bec ( m_measurement_bec, ctx );
97 SG::WriteDecorHandle<xAOD::TrackMeasurementValidationContainer, int> decor_layer ( m_measurement_layer, ctx );
98 SG::WriteDecorHandle<xAOD::TrackMeasurementValidationContainer, int> decor_sizePhi ( m_measurement_sizePhi, ctx );
99 SG::WriteDecorHandle<xAOD::TrackMeasurementValidationContainer, int> decor_sizeZ ( m_measurement_sizeZ, ctx );
100 SG::WriteDecorHandle<xAOD::TrackMeasurementValidationContainer, int> decor_SiWidth( m_measurement_SiWidth, ctx );
101 SG::WriteDecorHandle<xAOD::TrackMeasurementValidationContainer, int> decor_eta_module ( m_measurement_eta_module, ctx );
102 SG::WriteDecorHandle<xAOD::TrackMeasurementValidationContainer, int> decor_phi_module ( m_measurement_phi_module, ctx );
103 SG::WriteDecorHandle<xAOD::TrackMeasurementValidationContainer, float> decor_omegax ( m_measurement_omegax, ctx );
104 SG::WriteDecorHandle<xAOD::TrackMeasurementValidationContainer, float> decor_omegay ( m_measurement_omegay, ctx );
105 SG::WriteDecorHandle<xAOD::TrackMeasurementValidationContainer, float> decor_LorentzShift ( m_measurement_LorentzShift, ctx );
106 SG::WriteDecorHandle<xAOD::TrackMeasurementValidationContainer, float> decor_centroid_xphi ( m_measurement_centroid_xphi, ctx );
107 SG::WriteDecorHandle<xAOD::TrackMeasurementValidationContainer, float> decor_centroid_xeta ( m_measurement_centroid_xeta, ctx );
108 SG::WriteDecorHandle<xAOD::TrackMeasurementValidationContainer, int> decor_side ( m_measurement_side, ctx );
109
110 SG::WriteDecorHandle<xAOD::TrackMeasurementValidationContainer, std::vector<int>> decor_tots ( m_measurement_tots, ctx );
111
112 // Create output collection
113 std::vector<bool> keepClusterCollection {};
114 ATH_CHECK( labelMeasurementToKeep(ctx, *clusters, keepClusterCollection) );
115 xAOD::TrackMeasurementValidationContainer *measurements = xaod.ptr();
116
117 // loop over collection and convert to xAOD::TrackMeasurementValidation
118 for (std::size_t i(0); i<clusters->size(); ++i) {
119 if (not keepClusterCollection[i]) continue;
120 const xAOD::PixelCluster* cluster = clusters->at(i);
121
122 measurements->push_back( new xAOD::TrackMeasurementValidation() );
123 xAOD::TrackMeasurementValidation* measurement = measurements->back();
125 measurements->back()->index() );
126
127 ATH_CHECK( mlink.isValid() );
128 decorator_measurement_link(*cluster) = std::move(mlink);
129
130 xAOD::DetectorIdentType clusterId = cluster->identifier();
131 xAOD::DetectorIDHashType hashId = cluster->identifierHash();
132
133 const InDetDD::SiDetectorElement *element = pixelDetEle->getDetectorElement(hashId);
134 if ( not element ) {
135 ATH_MSG_FATAL( "Invalid pixel detector element for hash " << hashId );
136 return StatusCode::FAILURE;
137 }
138
140 rdoList = cluster->rdoList();
141 std::vector< std::uint64_t > rdoIdentifierList;
142 rdoIdentifierList.reserve(rdoList.size());
143 int rowmin = std::numeric_limits<int>::max();
144 int rowmax = std::numeric_limits<int>::min();
145 int colmin = std::numeric_limits<int>::max();
146 int colmax = std::numeric_limits<int>::min();
147 for( const Identifier::value_type& hitIdentifierValue : rdoList ){
148 Identifier hitIdentifier(hitIdentifierValue);
149 rdoIdentifierList.push_back( hitIdentifier.get_compact() );
150 //May want to addinformation about the individual hits here
151 int row = m_PixelHelper->phi_index(hitIdentifier);
152 int col = m_PixelHelper->eta_index(hitIdentifier);
153 rowmin = std::min(rowmin, row);
154 rowmax = std::max(rowmax, row);
155 colmin = std::min(colmin, col);
156 colmax = std::max(colmax, col);
157 }
158
159 // compute centroid
160 const InDetDD::PixelModuleDesign* design = dynamic_cast<const InDetDD::PixelModuleDesign*>(&element->design());
161 if (not design) {
162 ATH_MSG_ERROR("Cannot retrieve detector design");
163 return StatusCode::FAILURE;
164 }
165 InDetDD::SiLocalPosition pos1 = design->positionFromColumnRow(colmin,rowmin);
166 InDetDD::SiLocalPosition pos2 = design->positionFromColumnRow(colmax,rowmin);
167 InDetDD::SiLocalPosition pos3 = design->positionFromColumnRow(colmin,rowmax);
168 InDetDD::SiLocalPosition pos4 = design->positionFromColumnRow(colmax,rowmax);
169 InDetDD::SiLocalPosition centroid = 0.25 * (pos1 + pos2 + pos3 + pos4);
170
171 //Set Identifier
172 measurement->setIdentifier( clusterId );
173 measurement->setRdoIdentifierList(std::move(rdoIdentifierList));
174
175 //Set Global Position
176 auto gpos = cluster->globalPosition();
177 measurement->setGlobalPosition(gpos.x(), gpos.y(), gpos.z());
178
179 // Set local position and error matrix
180 auto locpos = cluster->localPosition<2>();
181 measurement->setLocalPosition(locpos[0], locpos[1]);
182
183 auto localCov = cluster->localCovariance<2>();
184 measurement->setLocalPositionError( localCov(0,0), localCov(1,1), localCov(0,1) );
185
186 const auto& [omegax, omegay] = TrackingUtilities::computeOmegas(*cluster,
188
189 const Identifier waferId = m_PixelHelper->wafer_id(hashId);
190 decor_detectorElementID(*measurement) = hashId;
191 decor_waferID(*measurement) = waferId.get_compact();
192 decor_bec(*measurement) = m_PixelHelper->barrel_ec(waferId);
193 decor_layer(*measurement) = m_PixelHelper->layer_disk(waferId);
194 decor_sizePhi(*measurement) = cluster->channelsInPhi();
195 decor_sizeZ(*measurement) = cluster->channelsInEta();
196 decor_SiWidth(*measurement) = cluster->channelsInPhi();
197 decor_eta_module(*measurement) = m_PixelHelper->eta_module(waferId);
198 decor_phi_module(*measurement) = m_PixelHelper->phi_module(waferId);
199 decor_omegax(*measurement) = omegax;
200 decor_omegay(*measurement) = omegay;
201 decor_LorentzShift(*measurement) = static_cast<float>( m_lorentzAngleTool->getLorentzShift(cluster->identifierHash(), ctx) );
202 decor_centroid_xphi(*measurement) = centroid.xPhi();
203 decor_centroid_xeta(*measurement) = centroid.xEta();
204 decor_side(*measurement) = 0;
205 decor_tots(*measurement) = cluster->totList();
206 }
207
208
209 // handle the truth
210 if (m_useTruthInfo) {
211 SG::WriteDecorHandle<xAOD::TrackMeasurementValidationContainer, std::vector<unsigned int>> decor_truth_indices( m_measurement_truth_indices, ctx );
212 SG::WriteDecorHandle<xAOD::TrackMeasurementValidationContainer, std::vector<unsigned int>> decor_truth_barcode( m_measurement_truth_barcodes, ctx );
213
214 // reset measurement counter
215 std::size_t measurementIndex = 0;
216 for (std::size_t i(0); i<clusters->size(); ++i) {
217 if (not keepClusterCollection[i]) continue;
218 const xAOD::PixelCluster* cluster = clusters->at(i);
219 xAOD::TrackMeasurementValidation* measurement = measurements->at(measurementIndex);
220
221 // check the two match
222 if (cluster->identifier() != measurement->identifier()) {
223 ATH_MSG_ERROR("Cluster and Measurement are not matching!");
224 return StatusCode::FAILURE;
225 }
226
227 // Use the MultiTruth Collection
228 // to get a list of all true particle contributing to the cluster
229 if (cluster->index() >= measToTruth->size()) {
230 ATH_MSG_ERROR( "PRD index "<< cluster->index() << " not present in the measurement to truth vector with size " << measToTruth->size() );
231 return StatusCode::FAILURE;
232 }
233
234 auto tps = measToTruth->at(cluster->index());
235
236 std::vector<unsigned int> tp_indices;
237 std::vector<unsigned int> tp_barcodes;
238 for (const auto& tp : tps) {
239 tp_indices.push_back(tp->index());
240 tp_barcodes.push_back(HepMC::uniqueID(tp));
241 }
242
243 // decorate
244 decor_truth_indices(*measurement) = std::move(tp_indices);
245 decor_truth_barcode(*measurement) = std::move(tp_barcodes);
246 ++measurementIndex;
247 } // loop on clusters/measurements
248 } // if do truth
249
250 ATH_MSG_DEBUG( " recorded PixelPrepData objects: size " << measurements->size() );
251 return StatusCode::SUCCESS;
252}
#define ATH_CHECK
Evaluate an expression and check for errors.
#define ATH_MSG_ERROR(x)
#define ATH_MSG_FATAL(x)
#define ATH_MSG_DEBUG(x)
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainer > m_measurement_centroid_xphi
SG::ReadHandleKey< xAOD::PixelClusterContainer > m_clustercontainer_key
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainer > m_measurement_LorentzShift
SG::ReadHandleKey< ActsTrk::MeasurementToTruthParticleAssociation > m_associationMap_key
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainer > m_measurement_sizeZ
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainer > m_measurement_centroid_xeta
SG::WriteHandleKey< xAOD::TrackMeasurementValidationContainer > m_write_xaod_key
SG::ReadCondHandleKey< InDetDD::SiDetectorElementCollection > m_pixelDetEleCollKey
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainer > m_measurement_omegay
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainer > m_measurement_truth_barcodes
StatusCode labelMeasurementToKeep(const EventContext &ctx, const xAOD::PixelClusterContainer &clusters, std::vector< bool > &labels) const
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainer > m_measurement_omegax
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainer > m_measurement_side
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainer > m_measurement_detectorElementID
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainer > m_measurement_truth_indices
ToolHandle< ISiLorentzAngleTool > m_lorentzAngleTool
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainer > m_measurement_phi_module
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainer > m_measurement_sizePhi
SG::WriteDecorHandleKey< xAOD::PixelClusterContainer > m_trackMeasurement_link
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainer > m_measurement_eta_module
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainer > m_measurement_layer
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainer > m_measurement_waferID
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainer > m_measurement_tots
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainer > m_measurement_bec
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainer > m_measurement_SiWidth
const T * back() const
Access the last element in the collection as an rvalue.
const T * at(size_type n) const
Access an element, as an rvalue.
value_type push_back(value_type pElem)
Add an element to the end of the collection.
size_type size() const noexcept
Returns the number of elements in the collection.
value_type get_compact() const
Get the compact id.
const SiDetectorElement * getDetectorElement(const IdentifierHash &hash) const
double xPhi() const
position along phi direction:
double xEta() const
position along eta direction:
const_pointer_type cptr()
virtual bool isValid() override final
Can the handle be successfully dereferenced?
const_pointer_type cptr()
Dereference the pointer.
StatusCode record(std::unique_ptr< T > data)
Record a const object to the store.
pointer_type ptr()
Dereference the pointer.
SG::ConstAccessor< SG::JaggedVecElt< Identifier::value_type > >::element_type rdoList() const
Returns the list of identifiers of the channels building the cluster.
int channelsInPhi() const
Returns the dimensions of the cluster in numbers of channels in phi (x) and eta (y) directions,...
ConstVectorMap< 3 > globalPosition() const
Returns the global position of the pixel cluster.
SG::ConstAccessor< SG::JaggedVecElt< int > >::element_type totList() const
Returns the list of ToT of the channels building the cluster.
int channelsInEta() const
void setRdoIdentifierList(const std::vector< uint64_t > &rdoIdentifierList)
Sets the list of RDO identifiers.
void setLocalPositionError(float localXError, float localYError, float localXYCorrelation)
Sets the local position error.
void setLocalPosition(float localX, float localY)
Sets the local position.
void setIdentifier(uint64_t identifier)
Sets the identifier.
void setGlobalPosition(float globalX, float globalY, float globalZ)
Sets the global position.
ConstMatrixMap< N > localCovariance() const
Returns the local covariance of the measurement.
DetectorIDHashType identifierHash() const
Returns the IdentifierHash of the measurement (corresponds to the detector element IdentifierHash).
DetectorIdentType identifier() const
Returns the full Identifier of the measurement.
ConstVectorMap< N > localPosition() const
Returns the local position of the measurement.
int uniqueID(const T &p)
row
Appending html table to final .html summary file.
SG::ConstAccessor< T, ALLOC > ConstAccessor
Definition AuxElement.h:570
SG::ReadCondHandle< T > makeHandle(const SG::ReadCondHandleKey< T > &key, const EventContext &ctx=Gaudi::Hive::currentContext())
std::pair< float, float > computeOmegas(const xAOD::PixelCluster &cluster, const PixelID &pixelID)
PixelClusterContainer_v1 PixelClusterContainer
Define the version of the pixel cluster container.
TrackMeasurementValidation_v1 TrackMeasurementValidation
Reference the current persistent version:
long unsigned int DetectorIdentType
PixelCluster_v1 PixelCluster
Define the version of the pixel cluster class.
TrackMeasurementValidationContainer_v1 TrackMeasurementValidationContainer
Definition of the current "TrackMeasurementValidation container version".
unsigned int DetectorIDHashType
@ detector ID element hash

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

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

◆ 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 ActsTrk::PixelClusterTruthDecoratorAlg::initialize ( )
overridevirtual

Definition at line 21 of file PixelClusterTruthDecoratorAlg.cxx.

21 {
22 ATH_MSG_DEBUG("Initialize " << name() << " ...");
23
24 // Read keys
27 ATH_CHECK(m_pixelDetEleCollKey.initialize());
28
29 // Tracks only needed if we want on track clusters only
31
32 // Write keys
33 ATH_CHECK(m_write_xaod_key.initialize());
34
35 // Decorators
37
40
42 ATH_CHECK(m_measurement_waferID.initialize());
43 ATH_CHECK(m_measurement_bec.initialize());
44 ATH_CHECK(m_measurement_layer.initialize());
45 ATH_CHECK(m_measurement_sizePhi.initialize());
46 ATH_CHECK(m_measurement_sizeZ.initialize());
47 ATH_CHECK(m_measurement_SiWidth.initialize());
50 ATH_CHECK(m_measurement_omegax.initialize());
51 ATH_CHECK(m_measurement_omegay.initialize());
55 ATH_CHECK(m_measurement_side.initialize());
56
57 ATH_CHECK(m_measurement_tots.initialize());
58
59 ATH_CHECK( m_lorentzAngleTool.retrieve() );
60 ATH_CHECK( detStore()->retrieve(m_PixelHelper, "PixelID") );
61
62 return StatusCode::SUCCESS;
63 }
SG::ReadHandleKeyArray< xAOD::TrackParticleContainer > m_trackParticlesKey
const ServiceHandle< StoreGateSvc > & detStore() const

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

◆ labelMeasurementToKeep()

StatusCode ActsTrk::PixelClusterTruthDecoratorAlg::labelMeasurementToKeep ( const EventContext & ctx,
const xAOD::PixelClusterContainer & clusters,
std::vector< bool > & labels ) const
private

Definition at line 254 of file PixelClusterTruthDecoratorAlg.cxx.

257{
258 labels.clear();
260 labels.resize(clusters.size(), true);
261 return StatusCode::SUCCESS;
262 }
263 labels.resize(clusters.size(), false);
264
265 static const SG::ConstAccessor< ElementLink<ActsTrk::TrackContainer> > decorator_trackLink("actsTrack");
266
267 // get the tracks
268 for (const SG::ReadHandleKey<xAOD::TrackParticleContainer>& trackParticleKey : m_trackParticlesKey) {
269 SG::ReadHandle<xAOD::TrackParticleContainer> trackParticleHandle = SG::makeHandle( trackParticleKey, ctx );
270 ATH_CHECK(trackParticleHandle.isValid());
271 const xAOD::TrackParticleContainer* trackParticles = trackParticleHandle.cptr();
272
273 for (const xAOD::TrackParticle* trackParticle : *trackParticles) {
274 // Get the ACTS track object
275 ATH_CHECK( decorator_trackLink.isAvailable(*trackParticle) );
276 ElementLink<ActsTrk::TrackContainer> trackLink = decorator_trackLink(*trackParticle);
277 ATH_CHECK(trackLink.isValid());
278
279 std::optional<ActsTrk::TrackContainer::ConstTrackProxy> optional_track = *trackLink;
280 if ( not optional_track.has_value() ) {
281 ATH_MSG_ERROR("Invalid track link for particle " << trackParticle->index());
282 return StatusCode::FAILURE;
283 }
284 ActsTrk::TrackContainer::ConstTrackProxy track = optional_track.value();
285
286 // loop on track states
287 track.container().trackStateContainer()
288 .visitBackwards(track.tipIndex(),
289 [&labels]
290 (const typename ActsTrk::TrackContainer::ConstTrackStateProxy& state)
291 {
292 auto flags = state.typeFlags();
293 if (not flags.hasMeasurement()) return;
294
295 auto sl = state.getUncalibratedSourceLink().template get<ATLASUncalibSourceLink>();
296 if (sl == nullptr) return;
297
298 const xAOD::UncalibratedMeasurement &cluster = getUncalibratedMeasurement(sl);
299 if (cluster.type() != xAOD::UncalibMeasType::PixelClusterType) return;
300 labels.at(cluster.index()) = true;
301 });
302 } // loop on tracks
303 } // loop on read handle keys
304
305 return StatusCode::SUCCESS;
306}
TrackParticle_v1 TrackParticle
Reference the current persistent version:
TrackParticleContainer_v1 TrackParticleContainer
Definition of the current "TrackParticle container version".

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

75{
76 return BaseAlg::sysExecute (ctx);
77}

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

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

SG::ReadHandleKey<ActsTrk::MeasurementToTruthParticleAssociation> ActsTrk::PixelClusterTruthDecoratorAlg::m_associationMap_key {this,"AssociationMapOut","", "Association map between measurements and truth particles"}
private

Definition at line 61 of file PixelClusterTruthDecoratorAlg.h.

61{this,"AssociationMapOut","", "Association map between measurements and truth particles"};

◆ m_clustercontainer_key

SG::ReadHandleKey<xAOD::PixelClusterContainer> ActsTrk::PixelClusterTruthDecoratorAlg::m_clustercontainer_key {this,"ClusterContainer", "","Input Pixel Cluster container"}
private

Definition at line 60 of file PixelClusterTruthDecoratorAlg.h.

60{this,"ClusterContainer", "","Input Pixel Cluster container"};

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

Gaudi::Property<bool> ActsTrk::PixelClusterTruthDecoratorAlg::m_keepOnlyOnTrackMeasurements {this, "KeepOnlyOnTrackMeasurements", false, "Keep on on-track measurements instead of the full collection"}
private

Definition at line 93 of file PixelClusterTruthDecoratorAlg.h.

93{this, "KeepOnlyOnTrackMeasurements", false, "Keep on on-track measurements instead of the full collection"};

◆ m_lorentzAngleTool

ToolHandle<ISiLorentzAngleTool> ActsTrk::PixelClusterTruthDecoratorAlg::m_lorentzAngleTool {this, "LorentzAngleTool", ""}
private

Definition at line 58 of file PixelClusterTruthDecoratorAlg.h.

58{this, "LorentzAngleTool", ""};

◆ m_measurement_bec

SG::WriteDecorHandleKey<xAOD::TrackMeasurementValidationContainer> ActsTrk::PixelClusterTruthDecoratorAlg::m_measurement_bec {this, "MeasurementBEC", m_write_xaod_key, "bec"}
private

Definition at line 76 of file PixelClusterTruthDecoratorAlg.h.

76{this, "MeasurementBEC", m_write_xaod_key, "bec"};

◆ m_measurement_centroid_xeta

SG::WriteDecorHandleKey<xAOD::TrackMeasurementValidationContainer> ActsTrk::PixelClusterTruthDecoratorAlg::m_measurement_centroid_xeta {this, "MeasurementCentroidXeta", m_write_xaod_key, "centroid_xeta"}
private

Definition at line 87 of file PixelClusterTruthDecoratorAlg.h.

87{this, "MeasurementCentroidXeta", m_write_xaod_key, "centroid_xeta"};

◆ m_measurement_centroid_xphi

SG::WriteDecorHandleKey<xAOD::TrackMeasurementValidationContainer> ActsTrk::PixelClusterTruthDecoratorAlg::m_measurement_centroid_xphi {this, "MeasurementCentroidXphi", m_write_xaod_key, "centroid_xphi"}
private

Definition at line 86 of file PixelClusterTruthDecoratorAlg.h.

86{this, "MeasurementCentroidXphi", m_write_xaod_key, "centroid_xphi"};

◆ m_measurement_detectorElementID

SG::WriteDecorHandleKey<xAOD::TrackMeasurementValidationContainer> ActsTrk::PixelClusterTruthDecoratorAlg::m_measurement_detectorElementID {this, "MeasurementDetectorElementID", m_write_xaod_key, "detectorElementID"}
private

Definition at line 74 of file PixelClusterTruthDecoratorAlg.h.

74{this, "MeasurementDetectorElementID", m_write_xaod_key, "detectorElementID"};

◆ m_measurement_eta_module

SG::WriteDecorHandleKey<xAOD::TrackMeasurementValidationContainer> ActsTrk::PixelClusterTruthDecoratorAlg::m_measurement_eta_module {this, "MeasurementEtaModule", m_write_xaod_key, "eta_module"}
private

Definition at line 81 of file PixelClusterTruthDecoratorAlg.h.

81{this, "MeasurementEtaModule", m_write_xaod_key, "eta_module"};

◆ m_measurement_layer

SG::WriteDecorHandleKey<xAOD::TrackMeasurementValidationContainer> ActsTrk::PixelClusterTruthDecoratorAlg::m_measurement_layer {this, "MeasurementLayer", m_write_xaod_key, "layer"}
private

Definition at line 77 of file PixelClusterTruthDecoratorAlg.h.

77{this, "MeasurementLayer", m_write_xaod_key, "layer"};

◆ m_measurement_LorentzShift

SG::WriteDecorHandleKey<xAOD::TrackMeasurementValidationContainer> ActsTrk::PixelClusterTruthDecoratorAlg::m_measurement_LorentzShift {this, "MeasurementLorentzShift", m_write_xaod_key, "LorentzShift"}
private

Definition at line 85 of file PixelClusterTruthDecoratorAlg.h.

85{this, "MeasurementLorentzShift", m_write_xaod_key, "LorentzShift"};

◆ m_measurement_omegax

SG::WriteDecorHandleKey<xAOD::TrackMeasurementValidationContainer> ActsTrk::PixelClusterTruthDecoratorAlg::m_measurement_omegax {this, "MeasurementOmegaX", m_write_xaod_key, "omegax"}
private

Definition at line 83 of file PixelClusterTruthDecoratorAlg.h.

83{this, "MeasurementOmegaX", m_write_xaod_key, "omegax"};

◆ m_measurement_omegay

SG::WriteDecorHandleKey<xAOD::TrackMeasurementValidationContainer> ActsTrk::PixelClusterTruthDecoratorAlg::m_measurement_omegay {this, "MeasurementOmegaY", m_write_xaod_key, "omegay"}
private

Definition at line 84 of file PixelClusterTruthDecoratorAlg.h.

84{this, "MeasurementOmegaY", m_write_xaod_key, "omegay"};

◆ m_measurement_phi_module

SG::WriteDecorHandleKey<xAOD::TrackMeasurementValidationContainer> ActsTrk::PixelClusterTruthDecoratorAlg::m_measurement_phi_module {this, "MeasurementPhiModule", m_write_xaod_key, "phi_module"}
private

Definition at line 82 of file PixelClusterTruthDecoratorAlg.h.

82{this, "MeasurementPhiModule", m_write_xaod_key, "phi_module"};

◆ m_measurement_side

SG::WriteDecorHandleKey<xAOD::TrackMeasurementValidationContainer> ActsTrk::PixelClusterTruthDecoratorAlg::m_measurement_side {this, "MeasurementSide", m_write_xaod_key, "side"}
private

Definition at line 88 of file PixelClusterTruthDecoratorAlg.h.

88{this, "MeasurementSide", m_write_xaod_key, "side"};

◆ m_measurement_SiWidth

SG::WriteDecorHandleKey<xAOD::TrackMeasurementValidationContainer> ActsTrk::PixelClusterTruthDecoratorAlg::m_measurement_SiWidth {this, "MeasurementSiWidth", m_write_xaod_key, "SiWidth"}
private

Definition at line 80 of file PixelClusterTruthDecoratorAlg.h.

80{this, "MeasurementSiWidth", m_write_xaod_key, "SiWidth"};

◆ m_measurement_sizePhi

SG::WriteDecorHandleKey<xAOD::TrackMeasurementValidationContainer> ActsTrk::PixelClusterTruthDecoratorAlg::m_measurement_sizePhi {this, "MeasurementSizePhi", m_write_xaod_key, "sizePhi"}
private

Definition at line 78 of file PixelClusterTruthDecoratorAlg.h.

78{this, "MeasurementSizePhi", m_write_xaod_key, "sizePhi"};

◆ m_measurement_sizeZ

SG::WriteDecorHandleKey<xAOD::TrackMeasurementValidationContainer> ActsTrk::PixelClusterTruthDecoratorAlg::m_measurement_sizeZ {this, "MeasurementSizeZ", m_write_xaod_key, "sizeZ"}
private

Definition at line 79 of file PixelClusterTruthDecoratorAlg.h.

79{this, "MeasurementSizeZ", m_write_xaod_key, "sizeZ"};

◆ m_measurement_tots

SG::WriteDecorHandleKey<xAOD::TrackMeasurementValidationContainer> ActsTrk::PixelClusterTruthDecoratorAlg::m_measurement_tots {this, "MeasurementToT", m_write_xaod_key, "tots"}
private

Definition at line 90 of file PixelClusterTruthDecoratorAlg.h.

90{this, "MeasurementToT", m_write_xaod_key, "tots"};

◆ m_measurement_truth_barcodes

SG::WriteDecorHandleKey<xAOD::TrackMeasurementValidationContainer> ActsTrk::PixelClusterTruthDecoratorAlg::m_measurement_truth_barcodes {this, "MeasurementTruthBarcode", m_write_xaod_key, "truth_barcode"}
private

Definition at line 72 of file PixelClusterTruthDecoratorAlg.h.

72{this, "MeasurementTruthBarcode", m_write_xaod_key, "truth_barcode"};

◆ m_measurement_truth_indices

SG::WriteDecorHandleKey<xAOD::TrackMeasurementValidationContainer> ActsTrk::PixelClusterTruthDecoratorAlg::m_measurement_truth_indices {this, "MeasurementTruthIndices", m_write_xaod_key, "truth_index"}
private

Definition at line 71 of file PixelClusterTruthDecoratorAlg.h.

71{this, "MeasurementTruthIndices", m_write_xaod_key, "truth_index"};

◆ m_measurement_waferID

SG::WriteDecorHandleKey<xAOD::TrackMeasurementValidationContainer> ActsTrk::PixelClusterTruthDecoratorAlg::m_measurement_waferID {this, "MeasurementWaferID", m_write_xaod_key, "waferID"}
private

Definition at line 75 of file PixelClusterTruthDecoratorAlg.h.

75{this, "MeasurementWaferID", m_write_xaod_key, "waferID"};

◆ m_pixelDetEleCollKey

SG::ReadCondHandleKey<InDetDD::SiDetectorElementCollection> ActsTrk::PixelClusterTruthDecoratorAlg::m_pixelDetEleCollKey {this, "PixelDetEleCollKey", "ITkPixelDetectorElementCollection"}
private

Definition at line 65 of file PixelClusterTruthDecoratorAlg.h.

65{this, "PixelDetEleCollKey", "ITkPixelDetectorElementCollection"};

◆ m_PixelHelper

const PixelID* ActsTrk::PixelClusterTruthDecoratorAlg::m_PixelHelper {nullptr}
private

Definition at line 95 of file PixelClusterTruthDecoratorAlg.h.

95{nullptr};

◆ m_trackMeasurement_link

SG::WriteDecorHandleKey< xAOD::PixelClusterContainer > ActsTrk::PixelClusterTruthDecoratorAlg::m_trackMeasurement_link {this, "MeasurementLink", m_clustercontainer_key, "validationMeasurementLink"}
private

Definition at line 69 of file PixelClusterTruthDecoratorAlg.h.

69{this, "MeasurementLink", m_clustercontainer_key, "validationMeasurementLink"};

◆ m_trackParticlesKey

SG::ReadHandleKeyArray< xAOD::TrackParticleContainer > ActsTrk::PixelClusterTruthDecoratorAlg::m_trackParticlesKey {this, "TrackParticles", {}, "Input xAOD::TrackParticles"}
private

Definition at line 63 of file PixelClusterTruthDecoratorAlg.h.

63{this, "TrackParticles", {}, "Input xAOD::TrackParticles"};

◆ m_useTruthInfo

Gaudi::Property<bool> ActsTrk::PixelClusterTruthDecoratorAlg::m_useTruthInfo {this, "UseTruthInfo", true}
private

Definition at line 92 of file PixelClusterTruthDecoratorAlg.h.

92{this, "UseTruthInfo", true};

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

SG::WriteHandleKey<xAOD::TrackMeasurementValidationContainer> ActsTrk::PixelClusterTruthDecoratorAlg::m_write_xaod_key {this,"MeasurementContainer","", "Output Pixel Validation Clusters"}
private

Definition at line 66 of file PixelClusterTruthDecoratorAlg.h.

66{this,"MeasurementContainer","", "Output Pixel Validation Clusters"};

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