Loading [MathJax]/extensions/tex2jax.js
ATLAS Offline Software
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
TrigInDetTrackSeedingTool.cxx
Go to the documentation of this file.
1 /*
2  Copyright (C) 2002-2025 CERN for the benefit of the ATLAS collaboration
3 */
4 
7 
13 
15 
17 
19 
20 #include "GNN_TrackingFilter.h"
21 
22 //for GPU offloading
23 
26 
28  const std::string& n,
29  const IInterface* p ) : SeedingToolBase(t,n,p)
30 {
31 
32 }
33 
35 
37 
38  ATH_CHECK(m_regsel_pix.retrieve());
39  ATH_CHECK(m_regsel_sct.retrieve());
40 
42 
43  if(m_useGPU) {//for GPU offloading
44  ATH_CHECK(m_accelSvc.retrieve());
45  ATH_CHECK(m_accelSvc->isReady());
46  }
47 
49  ATH_MSG_FATAL("Both usePixelSpacePoints and useSctSpacePoints set to False. At least one needs to be True");
50  return StatusCode::FAILURE;
51  }
52 
53  if (!m_useSctSpacePoints) ATH_MSG_INFO("Only using Pixel spacepoints => Pixel seeds only");
54 
55  if (!m_usePixelSpacePoints) ATH_MSG_INFO("Only using SCT spacepoints => Strip seeds only");
56 
57  if (m_usePixelSpacePoints && m_useSctSpacePoints) ATH_MSG_INFO("Using SCT and Pixel spacepoints");
58 
60 
62 
63  ATH_MSG_INFO("TrigInDetTrackSeedingTool initialized with " << m_useGPU);
64 
65  return StatusCode::SUCCESS;
66 }
67 
70 }
71 
72 
73 TrigInDetTrackSeedingResult TrigInDetTrackSeedingTool::findSeeds(const IRoiDescriptor& internalRoI, std::vector<TrigInDetTracklet>& output, const EventContext& ctx) const {
74 
76 
77  output.clear();
78 
80  const Amg::Vector3D &vertex = beamSpotHandle->beamPos();
81  float shift_x = vertex.x() - beamSpotHandle->beamTilt(0)*vertex.z();
82  float shift_y = vertex.y() - beamSpotHandle->beamTilt(1)*vertex.z();
83 
84  std::unique_ptr<GNN_DataStorage> storage = std::make_unique<GNN_DataStorage>(*m_geo);
85 
86  int nPixels = 0;
87  int nStrips = 0;
88 
89  const SpacePointContainer* sctSpacePointsContainer = nullptr;
90  const SpacePointContainer* pixelSpacePointsContainer = nullptr;
91 
92  std::map<short, std::vector<IdentifierHash> > detIdMap;//relates global detector layer ID to constituent detector elements
93 
94  if (m_useSctSpacePoints) {
95 
97 
98  if(!sctHandle.isValid()) {
99  ATH_MSG_WARNING("Invalid Strip Spacepoints handle: "<<sctHandle);
100  return seedStats;
101 
102  }
103 
104  sctSpacePointsContainer = sctHandle.ptr();
105 
106  std::vector<IdentifierHash> listOfSctIds;
107  m_regsel_sct->lookup(ctx)->HashIDList( internalRoI, listOfSctIds );
108 
109  const std::vector<short>* h2l = m_layerNumberTool->sctLayers();
110 
111  for(const auto& hashId : listOfSctIds) {
112 
113  short layerIndex = h2l->at(static_cast<int>(hashId));
114 
115  auto it = detIdMap.find(layerIndex);
116  if(it != detIdMap.end()) (*it).second.push_back(hashId);
117  else {
118  std::vector<IdentifierHash> v = {hashId};
119  detIdMap.insert(std::make_pair(layerIndex,v));
120  }
121  }
122  }
123 
124  if (m_usePixelSpacePoints) {
125 
127 
128  if(!pixHandle.isValid()) {
129  ATH_MSG_WARNING("Invalid Pixel Spacepoints handle: "<<pixHandle);
130  return seedStats;
131  }
132 
133  pixelSpacePointsContainer = pixHandle.ptr();
134 
135  std::vector<IdentifierHash> listOfPixIds;
136 
137  m_regsel_pix->lookup(ctx)->HashIDList( internalRoI, listOfPixIds );
138 
139  const std::vector<short>* h2l = m_layerNumberTool->pixelLayers();
140 
141  for(const auto& hashId : listOfPixIds) {
142 
143  short layerIndex = h2l->at(static_cast<int>(hashId));
144 
145  auto it = detIdMap.find(layerIndex);
146  if(it != detIdMap.end()) (*it).second.push_back(hashId);
147  else {
148  std::vector<IdentifierHash> v = {hashId};
149  detIdMap.insert(std::make_pair(layerIndex,v));
150  }
151  }
152  }
153 
154  if(!m_useGPU) {
155 
156  std::unique_ptr<GNN_DataStorage> storage = std::make_unique<GNN_DataStorage>(*m_geo);
157 
158  std::vector<const Trk::SpacePoint*> vSP;
159 
160  vSP.reserve(m_nMaxEdges);
161 
162  std::vector<std::vector<GNN_Node> > trigSpStorage[2];
163 
164  trigSpStorage[1].resize(m_layerNumberTool->sctLayers()->size());
165 
166  trigSpStorage[0].resize(m_layerNumberTool->pixelLayers()->size());
167 
168  for(const auto& lColl : detIdMap) {
169 
170  short layerIndex = lColl.first;
171 
172  int layerKey = m_geo->getTrigFTF_GNN_LayerByIndex(layerIndex)->m_layer.m_subdet;
173 
174  bool isPixel = layerKey > 20000;
175 
176  auto pCont = isPixel ? pixelSpacePointsContainer : sctSpacePointsContainer;
177 
178  int contIdx= isPixel ? 0 : 1;
179 
180  int nNewNodes = 0;
181 
182  for(const auto& idx : lColl.second) {
183 
184  std::vector<GNN_Node>& tmpColl = trigSpStorage[contIdx].at(static_cast<int>(idx));
185 
186  auto input_coll = pCont->indexFindPtr(idx);
187 
188  if(input_coll == nullptr) continue;
189 
190  createGraphNodes(input_coll, tmpColl, vSP, layerIndex, shift_x, shift_y);//TO-DO: if(m_useBeamTilt) SP full transform functor
191 
192  nNewNodes += (isPixel) ? storage->loadPixelGraphNodes(layerIndex, tmpColl, m_useML) : storage->loadStripGraphNodes(layerIndex, tmpColl);
193  }
194 
195  if(isPixel) nPixels += nNewNodes;
196  else nStrips += nNewNodes;
197  }
198 
199  seedStats.m_nPixelSPs = nPixels;
200  seedStats.m_nStripSPs = nStrips;
201 
202  storage->sortByPhi();
203  storage->initializeNodes(m_useML);
204  storage->generatePhiIndexing(1.5*m_phiSliceWidth);
205 
206  std::vector<GNN_Edge> edgeStorage;
207 
208  std::pair<int, int> graphStats = buildTheGraph(internalRoI, storage, edgeStorage);
209 
210  ATH_MSG_DEBUG("Created graph with "<<graphStats.first<<" edges and "<<graphStats.second<< " edge links");
211 
212  seedStats.m_nGraphEdges = graphStats.first;
213  seedStats.m_nEdgeLinks = graphStats.second;
214 
215  if(graphStats.second == 0) return seedStats;
216 
217  int maxLevel = runCCA(graphStats.first, edgeStorage);
218 
219  ATH_MSG_DEBUG("Reached Level "<<maxLevel<<" after GNN iterations");
220 
221  int minLevel = 3;//a triplet + 1 confirmation
222 
223  if(m_LRTmode) {
224  minLevel = 2;//a triplet
225  }
226 
227  if(maxLevel < minLevel) return seedStats;
228 
229  std::vector<GNN_Edge*> vSeeds;
230 
231  vSeeds.reserve(graphStats.first/2);
232 
233  for(int edgeIndex=0;edgeIndex<graphStats.first;edgeIndex++) {
234  GNN_Edge* pS = &(edgeStorage.at(edgeIndex));
235 
236  if(pS->m_level < minLevel) continue;
237 
238  vSeeds.push_back(pS);
239  }
240 
241  if(vSeeds.empty()) return seedStats;
242 
243  std::sort(vSeeds.begin(), vSeeds.end(), GNN_Edge::CompareLevel());
244 
245  //backtracking
246 
247  TrigFTF_GNN_TrackingFilter tFilter(m_layerGeometry, edgeStorage);
248 
249  output.reserve(vSeeds.size());
250 
251  for(auto pS : vSeeds) {
252 
253  if(pS->m_level == -1) continue;
254 
255  TrigFTF_GNN_EdgeState rs(false);
256 
257  tFilter.followTrack(pS, rs);
258 
259  if(!rs.m_initialized) {
260  continue;
261  }
262 
263  if(static_cast<int>(rs.m_vs.size()) < minLevel) continue;
264 
265  std::vector<const GNN_Node*> vN;
266 
267  for(std::vector<GNN_Edge*>::reverse_iterator sIt=rs.m_vs.rbegin();sIt!=rs.m_vs.rend();++sIt) {
268 
269  (*sIt)->m_level = -1;//mark as collected
270 
271  if(sIt == rs.m_vs.rbegin()) {
272  vN.push_back((*sIt)->m_n1);
273  }
274  vN.push_back((*sIt)->m_n2);
275  }
276 
277  if(vN.size()<3) continue;
278 
279  unsigned int lastIdx = output.size();
280  output.emplace_back(rs.m_J);
281 
282  for(const auto& n : vN) {
283  output[lastIdx].addSpacePoint(vSP[n->m_idx]);
284  }
285  }
286 
287  ATH_MSG_DEBUG("Found "<<output.size()<<" tracklets");
288  }
289  else {//GPU-accelerated graph building
290 
291  //1. data export
292 
293  std::vector<const Trk::SpacePoint*> vSP;
294  std::vector<short> vL;
295 
296  vSP.reserve(TrigAccel::ITk::GBTS_MAX_NUMBER_SPACEPOINTS);
297  vL.reserve(TrigAccel::ITk::GBTS_MAX_NUMBER_SPACEPOINTS);
298 
299  std::unique_ptr<TrigAccel::DATA_EXPORT_BUFFER> dataBuffer = std::unique_ptr<TrigAccel::DATA_EXPORT_BUFFER>(new TrigAccel::DATA_EXPORT_BUFFER(5000));
300 
301  size_t dataTypeSize = sizeof(TrigAccel::ITk::GRAPH_MAKING_INPUT_DATA);
302  const size_t bufferOffset = 256;
303  size_t totalSize = bufferOffset+dataTypeSize;//make room for the header
304  if(!dataBuffer->fit(totalSize)) dataBuffer->reallocate(totalSize);
305 
306  TrigAccel::ITk::GRAPH_MAKING_INPUT_DATA* pJobData = reinterpret_cast<TrigAccel::ITk::GRAPH_MAKING_INPUT_DATA*>(dataBuffer->m_buffer + bufferOffset);
307 
308  unsigned int spIdx = 0;
309  int sp_offset = 0;
310  int nLayers = 0;
311  int MaxEtaBin = 0;
312  int nEtaBins = 0;
313 
314  for(const auto& lColl : detIdMap) {
315 
316  short layerIndex = lColl.first;
317 
318  const TrigFTF_GNN_Layer* pL = m_geo->getTrigFTF_GNN_LayerByIndex(layerIndex);
319 
320  int layerKey = pL->m_layer.m_subdet;
321 
322  bool isPixel = layerKey > 20000;
323  bool isBarrel = (pL->m_layer.m_type == 0);
324 
325  auto pCont = isPixel ? pixelSpacePointsContainer : sctSpacePointsContainer;
326 
327  pJobData->m_layerIdx[nLayers] = layerIndex;
328 
329  pJobData->m_layerInfo[4*nLayers ] = spIdx;//layerInfo.x
330  pJobData->m_layerInfo[4*nLayers + 2] = pL->num_bins();//layerInfo.z
331  pJobData->m_layerInfo[4*nLayers + 3] = pL->m_bins[0];//layerInfo.w
332 
333  pJobData->m_layerGeo[2*nLayers ] = pL->m_minEta;//layerGeo.x
334  pJobData->m_layerGeo[2*nLayers + 1] = pL->m_etaBin;//layerGeo.y
335 
336  nEtaBins += pL->m_bins.size();
337 
338  for(auto b : pL->m_bins) {
339  if(b > MaxEtaBin) MaxEtaBin = b;
340  }
341 
342  for(const auto& idx : lColl.second) {
343 
344  auto input_coll = pCont->indexFindPtr(idx);
345 
346  if(input_coll == nullptr) continue;
347 
348  for(const auto sp : *input_coll) {
349 
350  float cw = -1.0;
351 
352  const InDet::PixelCluster* pCL = dynamic_cast<const InDet::PixelCluster*>(sp->clusterList().first);
353  if(pCL != nullptr) {
354  cw = pCL->width().widthPhiRZ().y();
355  if(!isBarrel && m_useML) {
356  if(cw > 0.2) continue;
357  cw = -1.0;//set it to -1 so that it can be skipped later in the ML code on GPU
358  }
359  }
360 
361  vSP.emplace_back(sp);
362  vL.emplace_back(layerIndex);
363 
364  const auto& p = sp->globalPosition();
365 
366  float params[4] = {(float)(p.x() - shift_x), float(p.y() - shift_y), (float)(p.z()), cw};
367 
368  memcpy(&pJobData->m_params[sp_offset], &params[0], sizeof(params));
369 
370  sp_offset += 4;
371  spIdx++;
372  if(spIdx >= TrigAccel::ITk::GBTS_MAX_NUMBER_SPACEPOINTS) break;
373  }
374  if(spIdx >= TrigAccel::ITk::GBTS_MAX_NUMBER_SPACEPOINTS) break;
375  }
376 
377  pJobData->m_layerInfo[4*nLayers + 1] = spIdx;//layerInfo.y
378 
379  if (isPixel) nPixels += spIdx - pJobData->m_layerInfo[4*nLayers];
380  else nStrips += spIdx - pJobData->m_layerInfo[4*nLayers];
381 
382  nLayers++;
383  }
384 
385  pJobData->m_nSpacepoints = spIdx;
386  pJobData->m_nLayers = nLayers;
387  pJobData->m_nEtaBins = nEtaBins;
388  pJobData->m_maxEtaBin = MaxEtaBin;
389  pJobData->m_nMaxEdges = m_nMaxEdges;
390 
391  //load bin pairs
392 
393  int pairIdx = 0;
394 
395  for(const auto& bg : m_geo->bin_groups()) {//loop over bin groups
396 
397  int bin1_idx = bg.first;
398 
399  for(const auto& bin2_idx : bg.second) {
400  pJobData->m_bin_pairs[2*pairIdx ] = bin1_idx;
401  pJobData->m_bin_pairs[2*pairIdx+1] = bin2_idx;
402  pairIdx++;
403  }
404  }
405 
406  pJobData->m_nBinPairs = pairIdx;
407 
408  //add algorithm parameters
409 
410  const float ptCoeff = 0.29997*1.9972/2.0;// ~0.3*B/2 - assuming nominal field of 2*T
411 
412  float tripletPtMin = 0.8*m_minPt;//correction due to limited pT resolution
413 
414  float maxCurv = ptCoeff/tripletPtMin;
415 
416  const float min_deltaPhi = 0.001;
417  const float dphi_coeff = 0.68*maxCurv;
418  const float cut_dphi_max = m_LRTmode ? 0.07 : 0.012;
419  const float cut_dcurv_max = m_LRTmode ? 0.015 : 0.001;
420  const float cut_tau_ratio_max = m_LRTmode ? 0.015 : 0.007;
421  const float min_z0 = m_LRTmode ? -600.0 : internalRoI.zedMinus();
422  const float max_z0 = m_LRTmode ? 600.0 : internalRoI.zedPlus();
423 
424  const float maxOuterRadius = m_LRTmode ? 1050.0 : 550.0;
425  const float minDeltaRadius = 2.0;
426 
427  const float cut_zMinU = min_z0 + maxOuterRadius*internalRoI.dzdrMinus();
428  const float cut_zMaxU = max_z0 + maxOuterRadius*internalRoI.dzdrPlus();
429 
430  const float maxKappa_high_eta = m_LRTmode ? 1.0*maxCurv : std::sqrt(0.8)*maxCurv;
431  const float maxKappa_low_eta = m_LRTmode ? 1.0*maxCurv : std::sqrt(0.6)*maxCurv;
432 
433  pJobData->m_algo_params[0] = min_deltaPhi;
434  pJobData->m_algo_params[1] = dphi_coeff;
435  pJobData->m_algo_params[2] = minDeltaRadius;
436  pJobData->m_algo_params[3] = min_z0;
437  pJobData->m_algo_params[4] = max_z0;
438  pJobData->m_algo_params[5] = maxOuterRadius;
439  pJobData->m_algo_params[6] = cut_zMinU;
440  pJobData->m_algo_params[7] = cut_zMaxU;
441  pJobData->m_algo_params[8] = maxKappa_low_eta;
442  pJobData->m_algo_params[9] = maxKappa_high_eta;
443  pJobData->m_algo_params[10]= cut_dphi_max;
444  pJobData->m_algo_params[11]= cut_dcurv_max;
445  pJobData->m_algo_params[12]= cut_tau_ratio_max;
446 
447  int minLevel = 3;//a triplet + 1 confirmation
448 
449  if(m_LRTmode) {
450  minLevel = 2;//a triplet
451  }
452 
453  pJobData->m_minLevel = minLevel;
454 
456 
457  seedStats.m_nPixelSPs = nPixels;
458  seedStats.m_nStripSPs = nStrips;
459 
460  ATH_MSG_DEBUG("Loaded "<<nPixels<< " Pixel Spacepoints and "<<nStrips<< " Strip SpacePoints");
461 
462  std::shared_ptr<TrigAccel::OffloadBuffer> pBuff = std::make_shared<TrigAccel::OffloadBuffer>(dataBuffer.get());
463 
464  std::unique_ptr<TrigAccel::Work> pWork = std::unique_ptr<TrigAccel::Work>(m_accelSvc->createWork(TrigAccel::InDetJobControlCode::RUN_GBTS, pBuff));
465 
466  if(!pWork) {
467  ATH_MSG_WARNING("Failed to create a work item for task "<<TrigAccel::InDetJobControlCode::RUN_GBTS);
468  return seedStats;
469  }
470 
471  ATH_MSG_DEBUG("Work item created for task "<<TrigAccel::InDetJobControlCode::RUN_GBTS);
472 
473  bool workSuccess = pWork->run();
474  if(!workSuccess) {
475  ATH_MSG_WARNING("Work item failed to complete");
476  return seedStats;
477  }
478 
479  std::shared_ptr<TrigAccel::OffloadBuffer> pOutput = pWork->getOutput();
480 
482  TrigAccel::ITk::COMPRESSED_GRAPH* pGraph = &pGraphAndSeeds->m_CompressedGraph;
483  TrigAccel::ITk::OUTPUT_SEEDS* pSeeds = &pGraphAndSeeds->m_OutputSeeds;
484 
486  //converting tracklet into GBTS-CPU format
487  for(unsigned int seed=0; seed<pSeeds->m_nSeeds; seed++) {
488 
489  unsigned int lastIdx = output.size();
490  output.emplace_back(pSeeds->m_seedsArray[seed].m_Q);
491  for(int node=0; node<pSeeds->m_seedsArray[seed].m_size; node++) {
492  output[lastIdx].addSpacePoint(vSP[pSeeds->m_seedsArray[seed].m_nodes[node]]);
493  }
494  }
495  }
496  else {
497 
498  unsigned int nEdges = pGraph->m_nEdges;
499  unsigned int nMaxNei = pGraph->m_nMaxNeighbours;
500 
501  //populating the edgeStorage
502 
503  std::vector<GNN_Node> nodes;
504 
505  nodes.reserve(vSP.size());
506 
507  for(unsigned int idx = 0;idx < vSP.size(); idx++) {
508 
509  nodes.emplace_back(vL[idx]);
510 
511  const auto& pos = vSP[idx]->globalPosition();
512  float xs = pos.x() - shift_x;
513  float ys = pos.y() - shift_y;
514  float zs = pos.z();
515 
516  nodes[idx].m_x = xs;
517  nodes[idx].m_y = ys;
518  nodes[idx].m_z = zs;
519  nodes[idx].m_r = std::sqrt(xs*xs + ys*ys);
520 
521  nodes[idx].m_idx = idx;
522 
523  }
524 
525  std::vector<GNN_Edge> edgeStorage;
526 
527  std::pair<int, int> graphStats(0,0);
528 
529  edgeStorage.resize(nEdges);
530 
531  unsigned int edgeSize = nMaxNei + 1 + 2;//neigbours, num_neighbours, 2 nodes
532 
533  for(unsigned int idx=0;idx<nEdges;idx++) {
534  unsigned int pos = idx*edgeSize;
535 
536  int node1Idx = pGraph->m_graphArray[pos + TrigAccel::ITk::node1];
537  int node2Idx = pGraph->m_graphArray[pos + TrigAccel::ITk::node2];
538  int nNei = pGraph->m_graphArray[pos + TrigAccel::ITk::nNei];
539 
540  if(nNei > N_SEG_CONNS) nNei = N_SEG_CONNS;
541 
542  edgeStorage[idx].m_n1 = &nodes[node1Idx];
543  edgeStorage[idx].m_n2 = &nodes[node2Idx];
544  edgeStorage[idx].m_level = 1;
545  edgeStorage[idx].m_nNei = nNei;
546  for(int k=0;k<nNei;k++) {
547  edgeStorage[idx].m_vNei[k] = pGraph->m_graphArray[pos + TrigAccel::ITk::nei_idx_start + k];
548  }
549  }
550 
551  graphStats.first = nEdges;
552  graphStats.second = pGraph->m_nLinks;
553 
554  //run the rest of the GBTS workflow
555 
556  int maxLevel = runCCA(graphStats.first, edgeStorage);
557 
558  ATH_MSG_DEBUG("Reached Level "<<maxLevel<<" after GNN iterations");
559 
560  if(maxLevel < minLevel) return seedStats;
561 
562  std::vector<GNN_Edge*> vSeeds;
563 
564  vSeeds.reserve(graphStats.first/2);
565 
566  for(int edgeIndex=0;edgeIndex<graphStats.first;edgeIndex++) {
567  GNN_Edge* pS = &(edgeStorage.at(edgeIndex));
568 
569  if(pS->m_level < minLevel) continue;
570 
571  vSeeds.push_back(pS);
572  }
573 
574  if(vSeeds.empty()) return seedStats;
575 
576  std::sort(vSeeds.begin(), vSeeds.end(), GNN_Edge::CompareLevel());
577 
578  //backtracking
579 
580  TrigFTF_GNN_TrackingFilter tFilter(m_layerGeometry, edgeStorage);
581 
582  output.reserve(vSeeds.size());
583 
584  for(auto pS : vSeeds) {
585 
586  if(pS->m_level == -1) continue;
587 
588  TrigFTF_GNN_EdgeState rs(false);
589 
590  tFilter.followTrack(pS, rs);
591 
592  if(!rs.m_initialized) {
593  continue;
594  }
595 
596  if(static_cast<int>(rs.m_vs.size()) < minLevel) continue;
597 
598  std::vector<const GNN_Node*> vN;
599 
600  for(std::vector<GNN_Edge*>::reverse_iterator sIt=rs.m_vs.rbegin();sIt!=rs.m_vs.rend();++sIt) {
601 
602  (*sIt)->m_level = -1;//mark as collected
603 
604  if(sIt == rs.m_vs.rbegin()) {
605  vN.push_back((*sIt)->m_n1);
606  }
607  vN.push_back((*sIt)->m_n2);
608  }
609 
610  if(vN.size()<3) continue;
611 
612  unsigned int lastIdx = output.size();
613  output.emplace_back(rs.m_J);
614 
615  for(const auto& n : vN) {
616  output[lastIdx].addSpacePoint(vSP[n->m_idx]);
617  }
618  }
619  }
620 
621  ATH_MSG_DEBUG("Found "<<output.size()<<" tracklets");
622  }
623 
624  return seedStats;
625 
626 }
627 
628 void TrigInDetTrackSeedingTool::createGraphNodes(const SpacePointCollection* spColl, std::vector<GNN_Node>& tmpColl, std::vector<const Trk::SpacePoint*>& vSP, unsigned short layer, float shift_x, float shift_y) const {
629 
630  tmpColl.resize(spColl->size(), GNN_Node(layer));//all nodes belong to the same layer
631 
632  int idx = 0;
633  int init_size = vSP.size();
634  for(const auto sp : *spColl) {
635  const auto& pos = sp->globalPosition();
636  vSP.emplace_back(sp);
637  float xs = pos.x() - shift_x;
638  float ys = pos.y() - shift_y;
639  float zs = pos.z();
640  tmpColl[idx].m_x = xs;
641  tmpColl[idx].m_y = ys;
642  tmpColl[idx].m_z = zs;
643  tmpColl[idx].m_r = std::sqrt(xs*xs + ys*ys);
644  tmpColl[idx].m_phi = std::atan2(ys,xs);
645  tmpColl[idx].m_idx = init_size + idx;
646 
647  const InDet::PixelCluster* pCL = dynamic_cast<const InDet::PixelCluster*>(sp->clusterList().first);
648  if(pCL != nullptr){
649  tmpColl[idx].m_pcw = pCL->width().z();
650  }
651 
652  idx++;
653  }
654 }
655 
TrigInDetTrackSeedingTool::m_accelSvc
ServiceHandle< ITrigInDetAccelerationSvc > m_accelSvc
Definition: TrigInDetTrackSeedingTool.h:72
PixelID.h
This is an Identifier helper class for the Pixel subdetector. This class is a factory for creating co...
TrigAccel::ITk::GraphAndSeedsOutput::m_OutputSeeds
OUTPUT_SEEDS m_OutputSeeds
Definition: TrigITkAccelEDM.h:182
TrigInDetTrackSeedingResult::m_nStripSPs
int m_nStripSPs
Definition: TrigInDetTrackSeedingResult.h:12
TrigAccel::ITk::CompressedGraph::m_nEdges
unsigned int m_nEdges
Definition: TrigITkAccelEDM.h:157
IRegSelTool.h
TrigAccel::DataExportBuffer
Definition: DataExportBuffer.h:14
TrigAccel::ITk::GraphMakingInputData
Definition: TrigITkAccelEDM.h:126
TrigAccel::DataExportBuffer::fit
bool fit(size_t s)
Definition: DataExportBuffer.h:26
ATH_MSG_FATAL
#define ATH_MSG_FATAL(x)
Definition: AthMsgStreamMacros.h:34
SCT_ID.h
This is an Identifier helper class for the SCT subdetector. This class is a factory for creating comp...
SeedingToolBase::initialize
virtual StatusCode initialize()
Definition: SeedingToolBase.cxx:19
TrigInDetTrackSeedingTool::m_useSctSpacePoints
BooleanProperty m_useSctSpacePoints
Definition: TrigInDetTrackSeedingTool.h:58
TrigFTF_GNN_Edge::CompareLevel
Definition: GNN_DataStorage.h:109
SeedingToolBase
Definition: SeedingToolBase.h:26
StandaloneBunchgroupHandler.bg
bg
Definition: StandaloneBunchgroupHandler.py:243
SG::ReadCondHandle
Definition: ReadCondHandle.h:44
ATH_MSG_INFO
#define ATH_MSG_INFO(x)
Definition: AthMsgStreamMacros.h:31
TCS::KFMET::nEtaBins
constexpr unsigned nEtaBins
Definition: KalmanMETCorrectionConstants.h:18
TrigInDetTrackSeedingTool::m_beamSpotKey
SG::ReadCondHandleKey< InDet::BeamSpotData > m_beamSpotKey
Definition: TrigInDetTrackSeedingTool.h:55
TrigAccel::DataExportBuffer::reallocate
void reallocate(size_t s)
Definition: DataExportBuffer.h:30
PixelCluster.h
TrigAccel::ITk::GraphMakingInputData::m_layerIdx
int m_layerIdx[GBTS_MAX_SILICON_LAYERS]
Definition: TrigITkAccelEDM.h:133
TrigFTF_GNN_DataStorage::sortByPhi
void sortByPhi()
Definition: GNN_DataStorage.cxx:177
TrigAccel::Work::run
virtual bool run()=0
SG::ReadHandle< SpacePointContainer >
TrigAccel::ITk::OutputSeeds::m_nSeeds
unsigned int m_nSeeds
Definition: TrigITkAccelEDM.h:173
TrigFTF_GNN_EdgeState
Definition: GNN_TrackingFilter.h:11
SeedingToolBase::buildTheGraph
std::pair< int, int > buildTheGraph(const IRoiDescriptor &, const std::unique_ptr< GNN_DataStorage > &, std::vector< GNN_Edge > &) const
Definition: SeedingToolBase.cxx:71
InDet::SiWidth::widthPhiRZ
const Amg::Vector2D & widthPhiRZ() const
Definition: SiWidth.h:121
TrigInDetAccelCodes.h
SeedingToolBase::m_nMaxEdges
IntegerProperty m_nMaxEdges
Definition: SeedingToolBase.h:60
TrigAccel::Work::getOutput
virtual std::shared_ptr< OffloadBuffer > getOutput()=0
skel.it
it
Definition: skel.GENtoEVGEN.py:407
TrigFTF_GNN_Layer::m_bins
std::vector< int > m_bins
Definition: GNN_Geometry.h:31
TrigInDetTrackSeedingTool.h
TrigFTF_GNN_EdgeState::m_J
float m_J
Definition: GNN_TrackingFilter.h:31
read_hist_ntuple.t
t
Definition: read_hist_ntuple.py:5
TrigFTF_GNN_Node
Definition: GNN_DataStorage.h:18
IRoiDescriptor::dzdrMinus
virtual double dzdrMinus() const =0
return the gradients
TrigInDetTrackSeedingTool::m_usePixelSpacePoints
BooleanProperty m_usePixelSpacePoints
Definition: TrigInDetTrackSeedingTool.h:57
TrigAccel::RUN_GBTS
@ RUN_GBTS
Definition: TrigInDetAccelCodes.h:31
TrigInDetTrackSeedingTool::m_regsel_pix
ToolHandle< IRegSelTool > m_regsel_pix
region selector tools
Definition: TrigInDetTrackSeedingTool.h:66
TrigInDetTrackSeedingTool::m_useGPU
BooleanProperty m_useGPU
Definition: TrigInDetTrackSeedingTool.h:71
SpacePointContainer.h
TrigFTF_GNN_EdgeState::m_vs
std::vector< TrigFTF_GNN_Edge * > m_vs
Definition: GNN_TrackingFilter.h:33
IRoiDescriptor::dzdrPlus
virtual double dzdrPlus() const =0
TrigFTF_GNN_EdgeState::m_initialized
bool m_initialized
Definition: GNN_TrackingFilter.h:38
TrigAccel::ITk::GraphAndSeedsOutput
Definition: TrigITkAccelEDM.h:179
N_SEG_CONNS
#define N_SEG_CONNS
Definition: GNN_DataStorage.h:14
AtlasDetectorID.h
This class provides an interface to generate or decode an identifier for the upper levels of the dete...
SeedingToolBase::m_useGPUseedExtraction
BooleanProperty m_useGPUseedExtraction
Definition: SeedingToolBase.h:63
TrigAccel::ITk::GraphAndSeedsOutput::m_CompressedGraph
COMPRESSED_GRAPH m_CompressedGraph
Definition: TrigITkAccelEDM.h:181
SpacePointCollection.h
python.utils.AtlRunQueryDQUtils.p
p
Definition: AtlRunQueryDQUtils.py:210
SeedingToolBase::m_LRTmode
BooleanProperty m_LRTmode
Definition: SeedingToolBase.h:51
TrigFTF_GNN_Edge
Definition: GNN_DataStorage.h:106
TrigFTF_GNN_DataStorage::generatePhiIndexing
void generatePhiIndexing(float)
Definition: GNN_DataStorage.cxx:226
TrigAccel::ITk::GraphMakingInputData::m_nEtaBins
unsigned int m_nEtaBins
Definition: TrigITkAccelEDM.h:129
TrigInDetTrackSeedingTool::m_sctSpacePointsContainerKey
SG::ReadHandleKey< SpacePointContainer > m_sctSpacePointsContainerKey
Definition: TrigInDetTrackSeedingTool.h:61
TrigInDetTrackSeedingTool::m_regsel_sct
ToolHandle< IRegSelTool > m_regsel_sct
Definition: TrigInDetTrackSeedingTool.h:67
TrigAccel::ITk::GRAPH_MAKING_INPUT_DATA
struct TrigAccel::ITk::GraphMakingInputData GRAPH_MAKING_INPUT_DATA
TrigAccel::ITk::OutputSeeds::m_seedsArray
std::unique_ptr< Tracklet[]> m_seedsArray
Definition: TrigITkAccelEDM.h:175
TrigFTF_GNN_Edge::m_level
signed char m_level
Definition: GNN_DataStorage.h:128
SeedingToolBase::m_minPt
FloatProperty m_minPt
Definition: SeedingToolBase.h:58
TrigInDetTrackSeedingTool::initialize
virtual StatusCode initialize() override
Definition: TrigInDetTrackSeedingTool.cxx:34
beamspotman.n
n
Definition: beamspotman.py:731
EL::StatusCode
::StatusCode StatusCode
StatusCode definition for legacy code.
Definition: PhysicsAnalysis/D3PDTools/EventLoop/EventLoop/StatusCode.h:22
SpacePoint.h
IRoiDescriptor
Describes the API of the Region of Ineterest geometry.
Definition: IRoiDescriptor.h:23
ATH_MSG_DEBUG
#define ATH_MSG_DEBUG(x)
Definition: AthMsgStreamMacros.h:29
TRT::Hit::layer
@ layer
Definition: HitInfo.h:79
SeedingToolBase::m_layerGeometry
std::vector< TrigInDetSiLayer > m_layerGeometry
Definition: SeedingToolBase.h:68
TrigAccel::ITk::GraphMakingInputData::m_params
float m_params[4 *GBTS_MAX_NUMBER_SPACEPOINTS]
Definition: TrigITkAccelEDM.h:131
TrigFTF_GNN_Layer::m_layer
const TrigInDetSiLayer & m_layer
Definition: GNN_Geometry.h:30
TrigAccel::ITk::GraphMakingInputData::m_nSpacepoints
unsigned int m_nSpacepoints
Definition: TrigITkAccelEDM.h:129
SeedingToolBase::finalize
virtual StatusCode finalize()
Definition: SeedingToolBase.cxx:66
TrigAccel::ITk::GraphMakingInputData::m_minLevel
int m_minLevel
Definition: TrigITkAccelEDM.h:149
TrigAccel::ITk::CompressedGraph::m_nLinks
unsigned int m_nLinks
Definition: TrigITkAccelEDM.h:160
ATH_CHECK
#define ATH_CHECK
Definition: AthCheckMacros.h:40
GNN_TrackingFilter.h
SG::VarHandleKey::initialize
StatusCode initialize(bool used=true)
If this object is used as a property, then this should be called during the initialize phase.
Definition: AthToolSupport/AsgDataHandles/Root/VarHandleKey.cxx:103
TrigAccel::ITk::GraphMakingInputData::m_maxEtaBin
unsigned int m_maxEtaBin
Definition: TrigITkAccelEDM.h:129
TrigFTF_GNN_Layer::m_etaBin
float m_etaBin
Definition: GNN_Geometry.h:37
TrigAccel::ITk::GraphMakingInputData::m_bin_pairs
int m_bin_pairs[2 *GBTS_MAX_ETA_BIN_PAIR]
Definition: TrigITkAccelEDM.h:145
TrigFTF_GNN_DataStorage::loadPixelGraphNodes
int loadPixelGraphNodes(short, const std::vector< TrigFTF_GNN_Node > &, bool)
Definition: GNN_DataStorage.cxx:104
TrigInDetTrackSeedingTool::findSeeds
virtual TrigInDetTrackSeedingResult findSeeds(const IRoiDescriptor &, std::vector< TrigInDetTracklet > &, const EventContext &) const override final
Definition: TrigInDetTrackSeedingTool.cxx:73
SG::ReadHandle::isValid
virtual bool isValid() override final
Can the handle be successfully dereferenced?
TrigInDetTrackSeedingTool::finalize
virtual StatusCode finalize() override
Definition: TrigInDetTrackSeedingTool.cxx:68
TrigFTF_GNN_Layer::m_minEta
float m_minEta
Definition: GNN_Geometry.h:37
TrigInDetSiLayer::m_type
int m_type
Definition: TrigInDetSiLayer.h:11
merge.output
output
Definition: merge.py:17
MuonGM::nStrips
int nStrips(const MuonGM::TgcReadoutElement &readoutEle, int layer)
Definition: MuonDetDescr/MuonGeoModelTest/src/GeoModelTgcTest.cxx:46
TrigAccel::ITk::GraphMakingInputData::m_layerInfo
int m_layerInfo[4 *GBTS_MAX_SILICON_LAYERS]
Definition: TrigITkAccelEDM.h:137
TrigFTF_GNN_DataStorage::initializeNodes
void initializeNodes(bool)
Definition: GNN_DataStorage.cxx:182
TrigAccel::ITk::GraphMakingInputData::m_nMaxEdges
unsigned int m_nMaxEdges
Definition: TrigITkAccelEDM.h:129
SeedingToolBase::m_geo
std::unique_ptr< const TrigFTF_GNN_Geometry > m_geo
Definition: SeedingToolBase.h:69
PathResolver.h
TrigInDetTrackSeedingTool::TrigInDetTrackSeedingTool
TrigInDetTrackSeedingTool(const std::string &, const std::string &, const IInterface *)
Definition: TrigInDetTrackSeedingTool.cxx:27
TrigFTF_GNN_Layer
Definition: GNN_Geometry.h:16
TrigInDetTrackSeedingResult::m_nPixelSPs
int m_nPixelSPs
Definition: TrigInDetTrackSeedingResult.h:10
plotBeamSpotMon.b
b
Definition: plotBeamSpotMon.py:77
TrigAccel::ITk::GraphMakingInputData::m_layerGeo
float m_layerGeo[2 *GBTS_MAX_SILICON_LAYERS]
Definition: TrigITkAccelEDM.h:141
SeedingToolBase::m_phiSliceWidth
float m_phiSliceWidth
Definition: SeedingToolBase.h:65
TrigInDetTrackSeedingTool::createGraphNodes
void createGraphNodes(const SpacePointCollection *, std::vector< GNN_Node > &, std::vector< const Trk::SpacePoint * > &, unsigned short, float, float) const
Definition: TrigInDetTrackSeedingTool.cxx:628
TrigInDetTrackSeedingResult
Definition: TrigInDetTrackSeedingResult.h:8
SG::CondHandleKey::initialize
StatusCode initialize(bool used=true)
TrigAccel::ITk::GraphMakingInputData::m_nBinPairs
unsigned int m_nBinPairs
Definition: TrigITkAccelEDM.h:129
TrigInDetTrackSeedingResult::m_nGraphEdges
int m_nGraphEdges
Definition: TrigInDetTrackSeedingResult.h:12
Amg::Vector3D
Eigen::Matrix< double, 3, 1 > Vector3D
Definition: GeoPrimitives.h:47
TrigAccel::ITk::CompressedGraph::m_graphArray
std::unique_ptr< int[]> m_graphArray
Definition: TrigITkAccelEDM.h:161
TrigITkAccelEDM.h
python.LumiBlobConversion.pos
pos
Definition: LumiBlobConversion.py:18
TrigAccel::DataExportBuffer::m_buffer
char * m_buffer
Definition: DataExportBuffer.h:57
SG::ReadHandle::ptr
const_pointer_type ptr()
Dereference the pointer.
InDet::PixelCluster
Definition: InnerDetector/InDetRecEvent/InDetPrepRawData/InDetPrepRawData/PixelCluster.h:49
python.PyAthena.v
v
Definition: PyAthena.py:154
Trk::vertex
@ vertex
Definition: MeasurementType.h:21
TrigAccel::ITk::GraphMakingInputData::m_useGPUseedExtraction
bool m_useGPUseedExtraction
Definition: TrigITkAccelEDM.h:151
InDet::SiCluster::width
const InDet::SiWidth & width() const
return width class reference
TrigAccel::OffloadBuffer::m_rawBuffer
unsigned char * m_rawBuffer
Definition: OffloadBuffer.h:39
TrigAccel::ITk::GraphMakingInputData::m_algo_params
float m_algo_params[32]
Definition: TrigITkAccelEDM.h:147
IRoiDescriptor::zedPlus
virtual double zedPlus() const =0
the zed and eta values at the most forward and most rear ends of the RoI
ATH_MSG_WARNING
#define ATH_MSG_WARNING(x)
Definition: AthMsgStreamMacros.h:32
TrigAccel::ITk::CompressedGraph
Definition: TrigITkAccelEDM.h:155
TrigFTF_GNN_Layer::num_bins
int num_bins() const
Definition: GNN_Geometry.h:26
SpacePointCollection
Definition: SpacePointCollection.h:40
LArNewCalib_DelayDump_OFC_Cali.idx
idx
Definition: LArNewCalib_DelayDump_OFC_Cali.py:69
python.LArCondContChannels.isBarrel
isBarrel
Definition: LArCondContChannels.py:659
TrigAccel::ITk::OutputSeeds
Definition: TrigITkAccelEDM.h:171
TrigFTF_GNN_DataStorage::loadStripGraphNodes
int loadStripGraphNodes(short, const std::vector< TrigFTF_GNN_Node > &)
Definition: GNN_DataStorage.cxx:142
TrigFTF_GNN_TrackingFilter::followTrack
void followTrack(TrigFTF_GNN_Edge *, TrigFTF_GNN_EdgeState &)
Definition: GNN_TrackingFilter.cxx:82
IRoiDescriptor::zedMinus
virtual double zedMinus() const =0
SeedingToolBase::m_useML
BooleanProperty m_useML
Definition: SeedingToolBase.h:52
TrigAccel::ITk::GraphMakingInputData::m_nLayers
unsigned int m_nLayers
Definition: TrigITkAccelEDM.h:129
python.copyTCTOutput.totalSize
totalSize
Definition: copyTCTOutput.py:93
SpacePointContainer
Definition: Tracking/TrkEvent/TrkSpacePoint/TrkSpacePoint/SpacePointContainer.h:29
TrigInDetTrackSeedingTool::m_pixelSpacePointsContainerKey
SG::ReadHandleKey< SpacePointContainer > m_pixelSpacePointsContainerKey
Definition: TrigInDetTrackSeedingTool.h:62
PowhegControl_ttFCNC_NLO.params
params
Definition: PowhegControl_ttFCNC_NLO.py:226
TrigAccel::ITk::CompressedGraph::m_nMaxNeighbours
unsigned int m_nMaxNeighbours
Definition: TrigITkAccelEDM.h:159
DataVector::size
size_type size() const noexcept
Returns the number of elements in the collection.
SeedingToolBase::runCCA
int runCCA(int, std::vector< GNN_Edge > &) const
Definition: SeedingToolBase.cxx:297
SeedingToolBase::m_layerNumberTool
ToolHandle< ITrigL2LayerNumberTool > m_layerNumberTool
Definition: SeedingToolBase.h:43
InDet::SiWidth::z
double z() const
Definition: SiWidth.h:131
node
Definition: node.h:21
TrigInDetSiLayer::m_subdet
int m_subdet
Definition: TrigInDetSiLayer.h:10
fitman.k
k
Definition: fitman.py:528
python.LArMinBiasAlgConfig.float
float
Definition: LArMinBiasAlgConfig.py:65
TrigInDetTrackSeedingResult::m_nEdgeLinks
int m_nEdgeLinks
Definition: TrigInDetTrackSeedingResult.h:12
TrigFTF_GNN_TrackingFilter
Definition: GNN_TrackingFilter.h:44