ATLAS Offline Software
Loading...
Searching...
No Matches
PixelClusterTruthDecoratorAlg.cxx
Go to the documentation of this file.
1/*
2 Copyright (C) 2002-2025 CERN for the benefit of the ATLAS collaboration
3*/
4
13
14namespace ActsTrk {
15
17 ISvcLocator *pSvcLocator) :
18 AthReentrantAlgorithm(name, pSvcLocator)
19 {}
20
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 }
64
65 StatusCode PixelClusterTruthDecoratorAlg::execute(const EventContext& ctx) const {
66
67 //Mandatory. Require if the algorithm is scheduled.
69 ATH_CHECK(PixelClusterContainer.isValid());
70 const xAOD::PixelClusterContainer* clusters = PixelClusterContainer.cptr();
71
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) {
80 ATH_CHECK(measToTruthHandle.isValid());
81 measToTruth = measToTruthHandle.cptr();
82 }
83
84 // Setup outputs
85 // Create the xAOD container and its auxiliary store:
87 ATH_CHECK(xaod.record(std::make_unique<xAOD::TrackMeasurementValidationContainer>(),
88 std::make_unique<xAOD::TrackMeasurementValidationAuxContainer>()));
89
90 // Decorations
93
109
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
139 const std::vector<Identifier> rdoList = cluster->rdoList();
140 std::vector< std::uint64_t > rdoIdentifierList;
141 rdoIdentifierList.reserve(rdoList.size());
142 int rowmin = std::numeric_limits<int>::max();
143 int rowmax = std::numeric_limits<int>::min();
144 int colmin = std::numeric_limits<int>::max();
145 int colmax = std::numeric_limits<int>::min();
146 for( const Identifier& hitIdentifier : rdoList ){
147 rdoIdentifierList.push_back( hitIdentifier.get_compact() );
148 //May want to addinformation about the individual hits here
149 int row = m_PixelHelper->phi_index(hitIdentifier);
150 int col = m_PixelHelper->eta_index(hitIdentifier);
151 rowmin = std::min(rowmin, row);
152 rowmax = std::max(rowmax, row);
153 colmin = std::min(colmin, col);
154 colmax = std::max(colmax, col);
155 }
156
157 // compute centroid
158 const InDetDD::PixelModuleDesign* design = dynamic_cast<const InDetDD::PixelModuleDesign*>(&element->design());
159 if (not design) {
160 ATH_MSG_ERROR("Cannot retrieve detector design");
161 return StatusCode::FAILURE;
162 }
163 InDetDD::SiLocalPosition pos1 = design->positionFromColumnRow(colmin,rowmin);
164 InDetDD::SiLocalPosition pos2 = design->positionFromColumnRow(colmax,rowmin);
165 InDetDD::SiLocalPosition pos3 = design->positionFromColumnRow(colmin,rowmax);
166 InDetDD::SiLocalPosition pos4 = design->positionFromColumnRow(colmax,rowmax);
167 InDetDD::SiLocalPosition centroid = 0.25 * (pos1 + pos2 + pos3 + pos4);
168
169 //Set Identifier
170 measurement->setIdentifier( clusterId );
171 measurement->setRdoIdentifierList(std::move(rdoIdentifierList));
172
173 //Set Global Position
174 auto gpos = cluster->globalPosition();
175 measurement->setGlobalPosition(gpos.x(), gpos.y(), gpos.z());
176
177 // Set local position and error matrix
178 auto locpos = cluster->localPosition<2>();
179 measurement->setLocalPosition(locpos[0], locpos[1]);
180
181 auto localCov = cluster->localCovariance<2>();
182 measurement->setLocalPositionError( localCov(0,0), localCov(1,1), localCov(0,1) );
183
184 const auto& [omegax, omegay] = TrackingUtilities::computeOmegas(*cluster,
186
187 const Identifier waferId = m_PixelHelper->wafer_id(hashId);
188 decor_detectorElementID(*measurement) = hashId;
189 decor_waferID(*measurement) = waferId.get_compact();
190 decor_bec(*measurement) = m_PixelHelper->barrel_ec(waferId);
191 decor_layer(*measurement) = m_PixelHelper->layer_disk(waferId);
192 decor_sizePhi(*measurement) = cluster->channelsInPhi();
193 decor_sizeZ(*measurement) = cluster->channelsInEta();
194 decor_SiWidth(*measurement) = cluster->channelsInPhi();
195 decor_eta_module(*measurement) = m_PixelHelper->eta_module(waferId);
196 decor_phi_module(*measurement) = m_PixelHelper->phi_module(waferId);
197 decor_omegax(*measurement) = omegax;
198 decor_omegay(*measurement) = omegay;
199 decor_LorentzShift(*measurement) = static_cast<float>( m_lorentzAngleTool->getLorentzShift(cluster->identifierHash(), ctx) );
200 decor_centroid_xphi(*measurement) = centroid.xPhi();
201 decor_centroid_xeta(*measurement) = centroid.xEta();
202 decor_side(*measurement) = 0;
203 decor_tots(*measurement) = cluster->totList();
204 }
205
206
207 // handle the truth
208 if (m_useTruthInfo) {
211
212 // reset measurement counter
213 std::size_t measurementIndex = 0;
214 for (std::size_t i(0); i<clusters->size(); ++i) {
215 if (not keepClusterCollection[i]) continue;
216 const xAOD::PixelCluster* cluster = clusters->at(i);
217 xAOD::TrackMeasurementValidation* measurement = measurements->at(measurementIndex);
218
219 // check the two match
220 if (cluster->identifier() != measurement->identifier()) {
221 ATH_MSG_ERROR("Cluster and Measurement are not matching!");
222 return StatusCode::FAILURE;
223 }
224
225 // Use the MultiTruth Collection
226 // to get a list of all true particle contributing to the cluster
227 if (cluster->index() >= measToTruth->size()) {
228 ATH_MSG_ERROR( "PRD index "<< cluster->index() << " not present in the measurement to truth vector with size " << measToTruth->size() );
229 return StatusCode::FAILURE;
230 }
231
232 auto tps = measToTruth->at(cluster->index());
233
234 std::vector<unsigned int> tp_indices;
235 std::vector<unsigned int> tp_barcodes;
236 for (const auto& tp : tps) {
237 tp_indices.push_back(tp->index());
238 tp_barcodes.push_back(HepMC::uniqueID(tp));
239 }
240
241 // decorate
242 decor_truth_indices(*measurement) = std::move(tp_indices);
243 decor_truth_barcode(*measurement) = std::move(tp_barcodes);
244 ++measurementIndex;
245 } // loop on clusters/measurements
246 } // if do truth
247
248 ATH_MSG_DEBUG( " recorded PixelPrepData objects: size " << measurements->size() );
249 return StatusCode::SUCCESS;
250}
251
253 const xAOD::PixelClusterContainer& clusters,
254 std::vector<bool>& labels) const
255{
256 labels.clear();
258 labels.resize(clusters.size(), true);
259 return StatusCode::SUCCESS;
260 }
261 labels.resize(clusters.size(), false);
262
263 static const SG::ConstAccessor< ElementLink<ActsTrk::TrackContainer> > decorator_trackLink("actsTrack");
264
265 // get the tracks
267 SG::ReadHandle<xAOD::TrackParticleContainer> trackParticleHandle = SG::makeHandle( trackParticleKey, ctx );
268 ATH_CHECK(trackParticleHandle.isValid());
269 const xAOD::TrackParticleContainer* trackParticles = trackParticleHandle.cptr();
270
271 for (const xAOD::TrackParticle* trackParticle : *trackParticles) {
272 // Get the ACTS track object
273 ATH_CHECK( decorator_trackLink.isAvailable(*trackParticle) );
274 ElementLink<ActsTrk::TrackContainer> trackLink = decorator_trackLink(*trackParticle);
275 ATH_CHECK(trackLink.isValid());
276
277 std::optional<ActsTrk::TrackContainer::ConstTrackProxy> optional_track = *trackLink;
278 if ( not optional_track.has_value() ) {
279 ATH_MSG_ERROR("Invalid track link for particle " << trackParticle->index());
280 return StatusCode::FAILURE;
281 }
282 ActsTrk::TrackContainer::ConstTrackProxy track = optional_track.value();
283
284 // loop on track states
285 track.container().trackStateContainer()
286 .visitBackwards(track.tipIndex(),
287 [&labels]
288 (const typename ActsTrk::TrackContainer::ConstTrackStateProxy& state)
289 {
290 auto flags = state.typeFlags();
291 if (not flags.test(Acts::TrackStateFlag::MeasurementFlag) and
292 not flags.test(Acts::TrackStateFlag::OutlierFlag)) return;
293
294 auto sl = state.getUncalibratedSourceLink().template get<ATLASUncalibSourceLink>();
295 if (sl == nullptr) return;
296
297 const xAOD::UncalibratedMeasurement &cluster = getUncalibratedMeasurement(sl);
298 if (cluster.type() != xAOD::UncalibMeasType::PixelClusterType) return;
299 labels.at(cluster.index()) = true;
300 });
301 } // loop on tracks
302 } // loop on read handle keys
303
304 return StatusCode::SUCCESS;
305}
306
307}
308
309
#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)
ATLAS-specific HepMC functions.
Handle class for reading a decoration on an object.
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
virtual StatusCode execute(const EventContext &ctx) const override
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainer > m_measurement_sizeZ
SG::WriteDecorHandleKey< xAOD::TrackMeasurementValidationContainer > m_measurement_centroid_xeta
SG::WriteHandleKey< xAOD::TrackMeasurementValidationContainer > m_write_xaod_key
PixelClusterTruthDecoratorAlg(const std::string &name, ISvcLocator *pSvcLocator)
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
SG::ReadHandleKeyArray< xAOD::TrackParticleContainer > m_trackParticlesKey
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 ServiceHandle< StoreGateSvc > & detStore() const
An algorithm that can be simultaneously executed in multiple threads.
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.
Class used to describe the design of a module (diode segmentation and readout scheme)
SiLocalPosition positionFromColumnRow(const int column, const int row) const
Given row and column index of a diode, return position of diode center ALTERNATIVE/PREFERED way is to...
Class to hold the SiDetectorElement objects to be put in the detector store.
const SiDetectorElement * getDetectorElement(const IdentifierHash &hash) const
Class to hold geometrical description of a silicon detector element.
virtual const SiDetectorDesign & design() const override final
access to the local description (inline):
Class to represent a position in the natural frame of a silicon sensor, for Pixel and SCT For Pixel: ...
double xPhi() const
position along phi direction:
double xEta() const
position along eta direction:
size_t index() const
Return the index of this element within its container.
Helper class to provide constant type-safe access to aux data.
bool isAvailable(const ELT &e) const
Test to see if this variable exists in the store.
const_pointer_type cptr()
Property holding a SG store/key/clid from which a ReadHandle is made.
virtual bool isValid() override final
Can the handle be successfully dereferenced?
const_pointer_type cptr()
Dereference the pointer.
Handle class for adding a decoration to an object.
StatusCode record(std::unique_ptr< T > data)
Record a const object to the store.
pointer_type ptr()
Dereference the pointer.
const std::vector< int > & totList() const
Returns the list of ToT 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,...
const std::vector< Identifier > rdoList() const
Returns the list of identifiers of the channels building the cluster.
ConstVectorMap< 3 > globalPosition() const
Returns the global position of the pixel 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.
The AlignStoreProviderAlg loads the rigid alignment corrections and pipes them through the readout ge...
int uniqueID(const T &p)
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:
TrackParticle_v1 TrackParticle
Reference the current persistent version:
long unsigned int DetectorIdentType
PixelCluster_v1 PixelCluster
Define the version of the pixel cluster class.
TrackParticleContainer_v1 TrackParticleContainer
Definition of the current "TrackParticle container version".
TrackMeasurementValidationContainer_v1 TrackMeasurementValidationContainer
Definition of the current "TrackMeasurementValidation container version".
unsigned int DetectorIDHashType
@ detector ID element hash