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

#include <GridTripletSeedingTool.h>

Inheritance diagram for ActsTrk::GridTripletSeedingTool:
Collaboration diagram for ActsTrk::GridTripletSeedingTool:

Public Member Functions

 GridTripletSeedingTool (const std::string &type, const std::string &name, const IInterface *parent)
virtual StatusCode initialize () override
StatusCode createSeeds2 (const EventContext &ctx, const std::vector< const xAOD::SpacePointContainer * > &spacePointCollections, const Eigen::Vector3f &beamSpotPos, float bFieldInZ, ActsTrk::SeedContainer &seedContainer) const override

Protected Attributes

Gaudi::Property< bool > m_seedQualitySelection
Gaudi::Property< float > m_minPt
Gaudi::Property< float > m_cotThetaMax
Gaudi::Property< float > m_zMin
Gaudi::Property< float > m_zMax
Gaudi::Property< float > m_deltaRMax
Gaudi::Property< float > m_impactMax
Gaudi::Property< std::vector< float > > m_zBinEdges
Gaudi::Property< std::vector< float > > m_rBinEdges
Gaudi::Property< float > m_gridRMax
Gaudi::Property< float > m_gridPhiMin
Gaudi::Property< float > m_gridPhiMax
Gaudi::Property< int > m_phiBinDeflectionCoverage
Gaudi::Property< int > m_maxPhiBins
Gaudi::Property< float > m_rMax
Gaudi::Property< float > m_binSizeR
Gaudi::Property< float > m_deltaRMin
Gaudi::Property< float > m_deltaRMinTopSP
Gaudi::Property< float > m_deltaRMaxTopSP
Gaudi::Property< float > m_deltaRMinBottomSP
Gaudi::Property< float > m_deltaRMaxBottomSP
Gaudi::Property< float > m_deltaZMax
Gaudi::Property< float > m_collisionRegionMin
Gaudi::Property< float > m_collisionRegionMax
Gaudi::Property< float > m_sigmaScattering
Gaudi::Property< float > m_maxPtScattering
Gaudi::Property< float > m_radLengthPerSeed
Gaudi::Property< int > m_maxSeedsPerSpM
Gaudi::Property< bool > m_interactionPointCut
Gaudi::Property< std::vector< size_t > > m_zBinsCustomLooping
Gaudi::Property< std::vector< std::size_t > > m_rBinsCustomLooping
Gaudi::Property< bool > m_useVariableMiddleSPRange
Gaudi::Property< std::vector< std::vector< double > > > m_rRangeMiddleSP
Gaudi::Property< float > m_deltaRMiddleMinSPRange
Gaudi::Property< float > m_deltaRMiddleMaxSPRange
Gaudi::Property< bool > m_seedConfirmation
Gaudi::Property< float > m_seedConfCentralZMin
Gaudi::Property< float > m_seedConfCentralZMax
Gaudi::Property< float > m_seedConfCentralRMax
Gaudi::Property< size_t > m_seedConfCentralNTopLargeR
Gaudi::Property< size_t > m_seedConfCentralNTopSmallR
Gaudi::Property< float > m_seedConfCentralMinBottomRadius
Gaudi::Property< float > m_seedConfCentralMaxZOrigin
Gaudi::Property< float > m_seedConfCentralMinImpact
Gaudi::Property< float > m_seedConfForwardZMin
Gaudi::Property< float > m_seedConfForwardZMax
Gaudi::Property< float > m_seedConfForwardRMax
Gaudi::Property< size_t > m_seedConfForwardNTopLargeR
Gaudi::Property< size_t > m_seedConfForwardNTopSmallR
Gaudi::Property< float > m_seedConfForwardMinBottomRadius
Gaudi::Property< float > m_seedConfForwardMaxZOrigin
Gaudi::Property< float > m_seedConfForwardMinImpact
Gaudi::Property< bool > m_useDetailedDoubleMeasurementInfo
Gaudi::Property< float > m_toleranceParam
Gaudi::Property< float > m_phiMin
Gaudi::Property< float > m_phiMax
Gaudi::Property< float > m_rMin {this, "rMin", 0 * Acts::UnitConstants::mm, ""}
Gaudi::Property< float > m_zAlign
Gaudi::Property< float > m_rAlign
Gaudi::Property< float > m_sigmaError {this, "sigmaError", 5, ""}
Gaudi::Property< float > m_impactWeightFactor
Gaudi::Property< float > m_zOriginWeightFactor {this, "zOriginWeightFactor", 1.}
Gaudi::Property< float > m_compatSeedWeight
Gaudi::Property< std::size_t > m_compatSeedLimit
Gaudi::Property< float > m_seedWeightIncrement
Gaudi::Property< float > m_numSeedIncrement
Gaudi::Property< bool > m_seedConfirmationInFilter
Gaudi::Property< std::size_t > m_maxSeedsPerSpMConf
Gaudi::Property< std::size_t > m_maxQualitySeedsPerSpMConf
Gaudi::Property< bool > m_useDeltaRorTopRadius
Gaudi::Property< float > m_deltaInvHelixDiameter
Gaudi::Property< std::vector< std::pair< int, int > > > m_zBinNeighborsTop
Gaudi::Property< std::vector< std::pair< int, int > > > m_zBinNeighborsBottom
Gaudi::Property< std::vector< std::pair< int, int > > > m_rBinNeighborsTop
Gaudi::Property< std::vector< std::pair< int, int > > > m_rBinNeighborsBottom
Gaudi::Property< int > m_numPhiNeighbors
Gaudi::Property< bool > m_useExperimentCuts
Gaudi::Property< int > m_stateVectorReserveSize
Gaudi::Property< float > m_expCutrMin

Private Member Functions

const Acts::Logger & logger () const
 Private access to the logger.
bool spacePointSelectionFunction (const xAOD::SpacePoint *sp, float r) const
bool doubletSelectionFunction (const Acts::ConstSpacePointProxy2 &middle, const Acts::ConstSpacePointProxy2 &other, float cotTheta, bool isBottomCandidate) const
std::pair< float, float > retrieveRadiusRangeForMiddle (const Acts::ConstSpacePointProxy2 &spM, const Acts::Range1D< float > &rMiddleSpRange) const

Private Attributes

Acts::CylindricalSpacePointGrid2::Config m_gridCfg
Acts::DoubletSeedFinder::Config m_bottomDoubletFinderCfg
Acts::DoubletSeedFinder::Config m_topDoubletFinderCfg
Acts::TripletSeedFinder::Config m_tripletFinderCfg
Acts::BroadTripletSeedFilter::Config m_filterCfg
std::optional< Acts::TripletSeeder > m_finder
std::unique_ptr< const Acts::Logger > m_logger
 logging instance
std::unique_ptr< const Acts::Logger > m_loggerFilter
const PixelIDm_pixelId {nullptr}

Detailed Description

Definition at line 27 of file GridTripletSeedingTool.h.

Constructor & Destructor Documentation

◆ GridTripletSeedingTool()

ActsTrk::GridTripletSeedingTool::GridTripletSeedingTool ( const std::string & type,
const std::string & name,
const IInterface * parent )

Definition at line 9 of file GridTripletSeedingTool.cxx.

12 : base_class(type, name, parent) {}

Member Function Documentation

◆ createSeeds2()

StatusCode ActsTrk::GridTripletSeedingTool::createSeeds2 ( const EventContext & ctx,
const std::vector< const xAOD::SpacePointContainer * > & spacePointCollections,
const Eigen::Vector3f & beamSpotPos,
float bFieldInZ,
ActsTrk::SeedContainer & seedContainer ) const
override

Definition at line 386 of file GridTripletSeedingTool.cxx.

390 {
391 (void)ctx;
392
393 auto gridCfg = m_gridCfg;
394 gridCfg.bFieldInZ = bFieldInZ;
395
396 Acts::CylindricalSpacePointGrid2 grid(gridCfg,
397 logger().cloneWithSuffix("Grid"));
398
399 std::size_t totalSpacePoints = 0;
400 for (const xAOD::SpacePointContainer* spacePoints : spacePointCollections) {
401 totalSpacePoints += spacePoints->size();
402 }
403
404 std::vector<const xAOD::SpacePoint*> selectedXAODSpacePoints;
405 std::vector<float> selectedSpacePointsR;
406 selectedXAODSpacePoints.reserve(totalSpacePoints);
407 selectedSpacePointsR.reserve(totalSpacePoints);
408
409 for (const xAOD::SpacePointContainer* spacePoints : spacePointCollections) {
410 for (const xAOD::SpacePoint* sp : *spacePoints) {
411 float x = static_cast<float>(sp->x() - beamSpotPos[0]);
412 float y = static_cast<float>(sp->y() - beamSpotPos[1]);
413 float z = static_cast<float>(sp->z());
414 float r = std::hypot(x, y);
415 float phi = std::atan2(y, x);
416
418 continue;
419 }
420
421 grid.insert(selectedXAODSpacePoints.size(), phi, z, r);
422 selectedXAODSpacePoints.push_back(sp);
423 selectedSpacePointsR.push_back(r);
424 }
425 }
426
427 for (std::size_t i = 0; i < grid.numberOfBins(); ++i) {
428 std::ranges::sort(grid.at(i), [&](const Acts::SpacePointIndex2& a,
429 const Acts::SpacePointIndex2& b) {
430 return selectedSpacePointsR[a] < selectedSpacePointsR[b];
431 });
432 }
433
434 Acts::SpacePointContainer2 selectedSpacePoints;
435 selectedSpacePoints.createColumns(
436 Acts::SpacePointColumns::XY |
437 Acts::SpacePointColumns::ZR | Acts::SpacePointColumns::VarianceZ |
438 Acts::SpacePointColumns::VarianceR);
440 selectedSpacePoints.createColumns(Acts::SpacePointColumns::Strip);
441 }
442 selectedSpacePoints.reserve(grid.numberOfSpacePoints());
443 seedContainer.spacePoints().reserve(grid.numberOfSpacePoints());
444 std::vector<Acts::SpacePointIndex2> copyFromIndices;
445 copyFromIndices.reserve(grid.numberOfSpacePoints());
446 std::vector<Acts::SpacePointIndexRange2> gridSpacePointRanges;
447 gridSpacePointRanges.reserve(grid.numberOfBins());
448 for (std::size_t i = 0; i < grid.numberOfBins(); ++i) {
449 std::uint32_t begin = selectedSpacePoints.size();
450 for (const Acts::SpacePointIndex2 spIndex : grid.at(i)) {
451 const xAOD::SpacePoint* sp = selectedXAODSpacePoints[spIndex];
452
453 seedContainer.spacePoints().push_back(sp);
454 auto newSp = selectedSpacePoints.createSpacePoint();
455 newSp.xy() =
456 std::array<float, 2>{static_cast<float>(sp->x() - beamSpotPos[0]),
457 static_cast<float>(sp->y() - beamSpotPos[1])};
458 newSp.zr() = std::array<float, 2>{static_cast<float>(sp->z()),
459 selectedSpacePointsR[spIndex]};
460 newSp.varianceZ() = static_cast<float>(sp->varianceZ());
461 newSp.varianceR() = static_cast<float>(sp->varianceR());
463 Eigen::Vector3f topStripVector =
464 sp->topHalfStripLength() * sp->topStripDirection();
465 Eigen::Vector3f bottomStripVector =
466 sp->bottomHalfStripLength() * sp->bottomStripDirection();
467 Eigen::Vector3f stripCenterDistance = sp->stripCenterDistance();
468 Eigen::Vector3f topStripCenter = sp->topStripCenter();
469
470 newSp.topStripVector() = std::array<float, 3>{
471 topStripVector.x(), topStripVector.y(), topStripVector.z()};
472 newSp.bottomStripVector() =
473 std::array<float, 3>{bottomStripVector.x(), bottomStripVector.y(),
474 bottomStripVector.z()};
475 newSp.stripCenterDistance() = std::array<float, 3>{
476 stripCenterDistance.x(), stripCenterDistance.y(),
477 stripCenterDistance.z()};
478 newSp.topStripCenter() = std::array<float, 3>{
479 topStripCenter.x(), topStripCenter.y(), topStripCenter.z()};
480 }
481
482 copyFromIndices.push_back(spIndex);
483 }
484 std::uint32_t end = selectedSpacePoints.size();
485 gridSpacePointRanges.emplace_back(begin, end);
486 }
487
488 // clear temporary
489 selectedXAODSpacePoints = {};
490 selectedSpacePointsR = {};
491
492 ACTS_VERBOSE("Number of space points after selection "
493 << selectedSpacePoints.size() << " out of " << totalSpacePoints);
494
495 // Compute radius range. We rely on the fact the grid is storing the proxies
496 // with a sorting in the radius
497 const Acts::Range1D<float> rRange = [&]() -> Acts::Range1D<float> {
498 float minRange = std::numeric_limits<float>::max();
499 float maxRange = std::numeric_limits<float>::lowest();
500 for (const Acts::SpacePointIndexRange2& range : gridSpacePointRanges) {
501 if (range.first == range.second) {
502 continue;
503 }
504 auto first = selectedSpacePoints[range.first];
505 auto last = selectedSpacePoints[range.second - 1];
506 minRange = std::min(first.zr()[1], minRange);
507 maxRange = std::max(last.zr()[1], maxRange);
508 }
509 return {minRange, maxRange};
510 }();
511
512 auto bottomDoubletFinder =
513 Acts::DoubletSeedFinder::create(Acts::DoubletSeedFinder::DerivedConfig(
514 m_bottomDoubletFinderCfg, bFieldInZ));
515 auto topDoubletFinder = Acts::DoubletSeedFinder::create(
516 Acts::DoubletSeedFinder::DerivedConfig(m_topDoubletFinderCfg, bFieldInZ));
517 auto tripletFinder = Acts::TripletSeedFinder::create(
518 Acts::TripletSeedFinder::DerivedConfig(m_tripletFinderCfg, bFieldInZ));
519
520 // variable middle SP radial region of interest
521 const Acts::Range1D<float> rMiddleSpRange(
522 std::floor(rRange.min() / 2) * 2 + m_deltaRMiddleMinSPRange,
523 std::floor(rRange.max() / 2) * 2 - m_deltaRMiddleMaxSPRange);
524
525 Acts::BroadTripletSeedFilter::State filterState;
526 Acts::BroadTripletSeedFilter::Cache filterCache;
527 Acts::TripletSeeder::Cache cache;
528
529 Acts::BroadTripletSeedFilter filter(m_filterCfg, filterState, filterCache,
531
532 std::vector<Acts::SpacePointContainer2::ConstRange> bottomSpRanges;
533 std::optional<Acts::SpacePointContainer2::ConstRange> middleSpRange;
534 std::vector<Acts::SpacePointContainer2::ConstRange> topSpRanges;
535
536 Acts::SeedContainer2 tmpSeedContainer;
537
538 for (const auto [bottom, middle, top] : grid.binnedGroup()) {
539 ACTS_VERBOSE("Process middle bin " << middle);
540 if (middle >= gridSpacePointRanges.size()) {
541 ATH_MSG_ERROR("Grid Binned Group returned an unreasonable middle bin");
542 return StatusCode::FAILURE;
543 }
544
545 bottomSpRanges.clear();
546 topSpRanges.clear();
547
548 std::ranges::transform(
549 bottom, std::back_inserter(bottomSpRanges),
550 [&](std::size_t b) -> Acts::SpacePointContainer2::ConstRange {
551 return selectedSpacePoints.range(gridSpacePointRanges[b]).asConst();
552 });
553 middleSpRange =
554 selectedSpacePoints.range(gridSpacePointRanges[middle]).asConst();
555 std::ranges::transform(
556 top, std::back_inserter(topSpRanges),
557 [&](std::size_t t) -> Acts::SpacePointContainer2::ConstRange {
558 return selectedSpacePoints.range(gridSpacePointRanges[t]).asConst();
559 });
560
561 // we compute this here since all middle space point candidates belong to
562 // the same z-bin
563 auto firstMiddleSp = middleSpRange->front();
564 auto radiusRangeForMiddle =
565 retrieveRadiusRangeForMiddle(firstMiddleSp, rMiddleSpRange);
566
567 ACTS_VERBOSE("Validity range (radius) for the middle space point is ["
568 << radiusRangeForMiddle.first << ", "
569 << radiusRangeForMiddle.second << "]");
570
571 m_finder->createSeedsFromGroups(
572 cache, *bottomDoubletFinder, *topDoubletFinder, *tripletFinder, filter,
573 selectedSpacePoints, bottomSpRanges, *middleSpRange, topSpRanges,
574 radiusRangeForMiddle, tmpSeedContainer);
575 }
576
577 // Selection function - temporary implementation
578 // need change from ACTS for final implementation
579 // To be used only on PPP
580 auto selectionFunction =
581 [&filterState](const Acts::MutableSeedProxy2& seed) -> bool {
582 float seedQuality = seed.quality();
583 float bottomQuality =
584 filterState.bestSeedQualityMap.at(seed.spacePointIndices()[0]);
585 float middleQuality =
586 filterState.bestSeedQualityMap.at(seed.spacePointIndices()[1]);
587 float topQuality =
588 filterState.bestSeedQualityMap.at(seed.spacePointIndices()[2]);
589
590 return bottomQuality <= seedQuality || middleQuality <= seedQuality ||
591 topQuality <= seedQuality;
592 };
593
594 seedContainer.reserve(tmpSeedContainer.size());
595
596 // Select the seeds
597 for (Acts::MutableSeedProxy2 seed : tmpSeedContainer) {
598 if (m_seedQualitySelection && !selectionFunction(seed)) {
599 continue;
600 }
601
602 seedContainer.push_back(seed);
603 }
604
605 return StatusCode::SUCCESS;
606}
Scalar phi() const
phi method
#define ATH_MSG_ERROR(x)
static Double_t sp
static Double_t a
@ top
#define y
#define x
#define z
bool spacePointSelectionFunction(const xAOD::SpacePoint *sp, float r) const
Acts::TripletSeedFinder::Config m_tripletFinderCfg
Gaudi::Property< bool > m_seedQualitySelection
Acts::DoubletSeedFinder::Config m_bottomDoubletFinderCfg
std::pair< float, float > retrieveRadiusRangeForMiddle(const Acts::ConstSpacePointProxy2 &spM, const Acts::Range1D< float > &rMiddleSpRange) const
Acts::DoubletSeedFinder::Config m_topDoubletFinderCfg
std::optional< Acts::TripletSeeder > m_finder
Acts::BroadTripletSeedFilter::Config m_filterCfg
Gaudi::Property< bool > m_useDetailedDoubleMeasurementInfo
Acts::CylindricalSpacePointGrid2::Config m_gridCfg
Gaudi::Property< float > m_deltaRMiddleMaxSPRange
Gaudi::Property< float > m_deltaRMiddleMinSPRange
const Acts::Logger & logger() const
Private access to the logger.
std::unique_ptr< const Acts::Logger > m_loggerFilter
Gaudi::Property< bool > m_useExperimentCuts
int r
Definition globals.cxx:22
bool first
Definition DeMoScan.py:534
SpacePointContainer_v1 SpacePointContainer
Define the version of the space point container.
Acts::MutableSeedProxy2 push_back(Acts::SpacePointIndexSubset2 sp)
const SpacePointContainer & spacePoints() const noexcept

◆ doubletSelectionFunction()

bool ActsTrk::GridTripletSeedingTool::doubletSelectionFunction ( const Acts::ConstSpacePointProxy2 & middle,
const Acts::ConstSpacePointProxy2 & other,
float cotTheta,
bool isBottomCandidate ) const
private

Definition at line 335 of file GridTripletSeedingTool.cxx.

338 {
339 // We remove some doublets that have the middle space point in some specific
340 // areas This should eventually be moved inside ACTS and allow a veto
341 // mechanism according to the user desire. As of now we cannot really do this
342 // since we define a range of validity of the middle candidate, and if we want
343 // to veto some sub-regions inside it, we need to do it here.
344 if (std::abs(middle.zr()[0]) > 1500 and middle.zr()[1] > 100 and
345 middle.zr()[1] < 150) {
346 return false;
347 }
348
349 // We remove here some seeds, in case the bottom space point radius is
350 // too small (i.e. < fastTrackingRMin)
351
352 // This operation is done only within a specific eta window
353 // Instead of eta we use the doublet cottheta
354 static constexpr float cotThetaEta120 = 1.5095;
355 static constexpr float cotThetaEta360 = 18.2855;
356
357 float absCotTheta = std::abs(cotTheta);
358 if (isBottomCandidate && other.zr()[1] < m_expCutrMin &&
359 absCotTheta > cotThetaEta120 && absCotTheta < cotThetaEta360) {
360 return false;
361 }
362
363 return true;
364}

◆ initialize()

StatusCode ActsTrk::GridTripletSeedingTool::initialize ( )
overridevirtual

Definition at line 14 of file GridTripletSeedingTool.cxx.

14 {
15 ATH_MSG_DEBUG("Initializing " << name() << "...");
16
17 ATH_MSG_DEBUG("Properties Summary:");
23
24 ATH_MSG_DEBUG(" * Used by space point grid config:");
25 ATH_MSG_DEBUG(" " << m_minPt);
28 ATH_MSG_DEBUG(" " << m_zMin);
29 ATH_MSG_DEBUG(" " << m_zMax);
37
38 ATH_MSG_DEBUG(" * Used by seed finder config:");
39 ATH_MSG_DEBUG(" " << m_minPt);
42 ATH_MSG_DEBUG(" " << m_zMin);
43 ATH_MSG_DEBUG(" " << m_zMax);
45 ATH_MSG_DEBUG(" " << m_rMax);
66 } else if (not m_rRangeMiddleSP.empty())
86 }
89 ATH_MSG_DEBUG(" " << m_phiMin);
90 ATH_MSG_DEBUG(" " << m_phiMax);
91 ATH_MSG_DEBUG(" " << m_rMin);
92 ATH_MSG_DEBUG(" " << m_zAlign);
93 ATH_MSG_DEBUG(" " << m_rAlign);
95
96 ATH_MSG_DEBUG(" * Used by seed filter config:");
120 }
127
128 // Make the logger && Propagate to ACTS routines
129 m_logger = makeActsAthenaLogger(this, "Acts");
130
131 if (m_zBinEdges.size() - 1 != m_zBinNeighborsTop.size() &&
132 not m_zBinNeighborsTop.empty()) {
133 ATH_MSG_ERROR("Inconsistent config zBinNeighborsTop");
134 return StatusCode::FAILURE;
135 }
136
137 if (m_zBinEdges.size() - 1 != m_zBinNeighborsBottom.size() &&
138 not m_zBinNeighborsBottom.empty()) {
139 ATH_MSG_ERROR("Inconsistent config zBinNeighborsBottom");
140 return StatusCode::FAILURE;
141 }
142
143 if (m_rBinEdges.size() - 1 != m_rBinNeighborsTop.size() &&
144 not m_rBinNeighborsTop.empty()) {
145 ATH_MSG_ERROR("Inconsistent config rBinNeighborsTop");
146 return StatusCode::FAILURE;
147 }
148
149 if (m_rBinEdges.size() - 1 != m_rBinNeighborsBottom.size() &&
150 not m_rBinNeighborsBottom.empty()) {
151 ATH_MSG_ERROR("Inconsistent config rBinNeighborsBottom");
152 return StatusCode::FAILURE;
153 }
154
155 if (m_zBinsCustomLooping.size() != 0) {
156 // zBinsCustomLooping can contain a number of elements <= to the total
157 // number of bin in zBinEdges
158 for (std::size_t i : m_zBinsCustomLooping) {
159 if (i >= m_zBinEdges.size()) {
161 "Inconsistent config zBinsCustomLooping contains bins that are not "
162 "in zBinEdges");
163 return StatusCode::FAILURE;
164 }
165 }
166 }
167
168 if (m_rBinsCustomLooping.size() != 0) {
169 for (std::size_t i : m_rBinsCustomLooping) {
170 if (i >= m_rBinEdges.size()) {
172 "Inconsistent config rBinsCustomLooping contains bins that are not "
173 "in rBinEdges");
174 return StatusCode::FAILURE;
175 }
176 }
177 }
178
179 m_gridCfg.minPt = m_minPt;
180 m_gridCfg.rMin = 0;
181 m_gridCfg.rMax = m_gridRMax;
182 m_gridCfg.zMin = m_zMin;
183 m_gridCfg.zMax = m_zMax;
184 m_gridCfg.deltaRMax = m_deltaRMax;
185 m_gridCfg.cotThetaMax = m_cotThetaMax;
186 m_gridCfg.impactMax = m_impactMax;
187 m_gridCfg.phiMin = m_gridPhiMin;
188 m_gridCfg.phiMax = m_gridPhiMax;
189 m_gridCfg.phiBinDeflectionCoverage = m_phiBinDeflectionCoverage;
190 m_gridCfg.maxPhiBins = m_maxPhiBins;
191 m_gridCfg.zBinEdges = m_zBinEdges;
192 m_gridCfg.rBinEdges = m_rBinEdges;
193 m_gridCfg.bFieldInZ = 0; // will be set later
194 m_gridCfg.bottomBinFinder = Acts::GridBinFinder<3ul>(
196 m_rBinNeighborsBottom.value());
197 m_gridCfg.topBinFinder = Acts::GridBinFinder<3ul>(m_numPhiNeighbors.value(),
198 m_zBinNeighborsTop.value(),
199 m_rBinNeighborsTop.value());
200 m_gridCfg.navigation[0ul] = {};
201 m_gridCfg.navigation[1ul] = m_zBinsCustomLooping;
202 m_gridCfg.navigation[2ul] = m_rBinsCustomLooping;
203
204 m_bottomDoubletFinderCfg.spacePointsSortedByRadius = true;
205 m_bottomDoubletFinderCfg.candidateDirection = Acts::Direction::Backward();
216 m_bottomDoubletFinderCfg.helixCutTolerance = 1.;
218 m_bottomDoubletFinderCfg.experimentCuts
220 this);
221 }
222
223 m_topDoubletFinderCfg = m_bottomDoubletFinderCfg; // copy the bottom cuts
224 m_topDoubletFinderCfg.candidateDirection = Acts::Direction::Forward();
227
231 m_tripletFinderCfg.sigmaScattering = m_sigmaScattering;
232 m_tripletFinderCfg.radLengthPerSeed = m_radLengthPerSeed;
234 m_tripletFinderCfg.helixCutTolerance = 1.;
235 m_tripletFinderCfg.toleranceParam = m_toleranceParam;
236
237 m_filterCfg.deltaInvHelixDiameter = m_deltaInvHelixDiameter;
238 m_filterCfg.deltaRMin = m_deltaRMin;
239 m_filterCfg.compatSeedWeight = m_compatSeedWeight;
240 m_filterCfg.impactWeightFactor = m_impactWeightFactor;
241 m_filterCfg.zOriginWeightFactor = m_zOriginWeightFactor;
242 m_filterCfg.maxSeedsPerSpM = m_maxSeedsPerSpM;
243 m_filterCfg.compatSeedLimit = m_compatSeedLimit;
244 m_filterCfg.seedWeightIncrement = m_seedWeightIncrement;
245 m_filterCfg.numSeedIncrement = m_numSeedIncrement;
246 m_filterCfg.seedConfirmation = m_seedConfirmationInFilter;
247 m_filterCfg.centralSeedConfirmationRange.zMinSeedConf = m_seedConfCentralZMin;
248 m_filterCfg.centralSeedConfirmationRange.zMaxSeedConf = m_seedConfCentralZMax;
249 m_filterCfg.centralSeedConfirmationRange.rMaxSeedConf = m_seedConfCentralRMax;
250 m_filterCfg.centralSeedConfirmationRange.nTopForLargeR =
252 m_filterCfg.centralSeedConfirmationRange.nTopForSmallR =
254 m_filterCfg.centralSeedConfirmationRange.seedConfMinBottomRadius =
256 m_filterCfg.centralSeedConfirmationRange.seedConfMaxZOrigin =
258 m_filterCfg.centralSeedConfirmationRange.minImpactSeedConf =
260 m_filterCfg.forwardSeedConfirmationRange.zMinSeedConf = m_seedConfForwardZMin;
261 m_filterCfg.forwardSeedConfirmationRange.zMaxSeedConf = m_seedConfForwardZMax;
262 m_filterCfg.forwardSeedConfirmationRange.rMaxSeedConf = m_seedConfForwardRMax;
263 m_filterCfg.forwardSeedConfirmationRange.nTopForLargeR =
265 m_filterCfg.forwardSeedConfirmationRange.nTopForSmallR =
267 m_filterCfg.forwardSeedConfirmationRange.seedConfMinBottomRadius =
269 m_filterCfg.forwardSeedConfirmationRange.seedConfMaxZOrigin =
271 m_filterCfg.forwardSeedConfirmationRange.minImpactSeedConf =
273 m_filterCfg.maxSeedsPerSpMConf = m_maxSeedsPerSpMConf;
274 m_filterCfg.maxQualitySeedsPerSpMConf = m_maxQualitySeedsPerSpMConf;
275 m_filterCfg.useDeltaRinsteadOfTopRadius = m_useDeltaRorTopRadius;
276
277 m_finder = Acts::TripletSeeder(logger().cloneWithSuffix("Finder"));
278
279 m_loggerFilter = logger().cloneWithSuffix("Filter");
280
281 ATH_CHECK(detStore()->retrieve(m_pixelId, "PixelID"));
282
283 return StatusCode::SUCCESS;
284}
#define ATH_CHECK
Evaluate an expression and check for errors.
#define ATH_MSG_DEBUG(x)
std::unique_ptr< const Acts::Logger > makeActsAthenaLogger(IMessageSvc *svc, const std::string &name, int level, std::optional< std::string > parent_name)
Gaudi::Property< bool > m_useDeltaRorTopRadius
Gaudi::Property< float > m_seedConfForwardMinImpact
Gaudi::Property< std::vector< std::pair< int, int > > > m_rBinNeighborsTop
Gaudi::Property< float > m_impactWeightFactor
Gaudi::Property< float > m_collisionRegionMax
Gaudi::Property< float > m_seedConfCentralMinBottomRadius
Gaudi::Property< int > m_phiBinDeflectionCoverage
Gaudi::Property< float > m_zOriginWeightFactor
Gaudi::Property< std::size_t > m_maxSeedsPerSpMConf
Gaudi::Property< float > m_maxPtScattering
Gaudi::Property< bool > m_useVariableMiddleSPRange
Gaudi::Property< float > m_toleranceParam
Gaudi::Property< float > m_deltaRMaxBottomSP
Gaudi::Property< float > m_seedConfForwardMinBottomRadius
Gaudi::Property< float > m_compatSeedWeight
Gaudi::Property< std::vector< std::vector< double > > > m_rRangeMiddleSP
Gaudi::Property< float > m_deltaRMinTopSP
Gaudi::Property< float > m_seedConfForwardZMin
Gaudi::Property< std::vector< std::pair< int, int > > > m_rBinNeighborsBottom
Gaudi::Property< std::vector< std::pair< int, int > > > m_zBinNeighborsBottom
Gaudi::Property< float > m_gridPhiMin
Gaudi::Property< bool > m_interactionPointCut
Gaudi::Property< size_t > m_seedConfCentralNTopSmallR
Gaudi::Property< std::vector< float > > m_rBinEdges
Gaudi::Property< float > m_seedConfForwardRMax
Gaudi::Property< std::vector< std::pair< int, int > > > m_zBinNeighborsTop
Gaudi::Property< float > m_deltaInvHelixDiameter
Gaudi::Property< float > m_collisionRegionMin
Gaudi::Property< float > m_seedConfCentralMaxZOrigin
Gaudi::Property< float > m_seedConfCentralMinImpact
Gaudi::Property< std::size_t > m_maxQualitySeedsPerSpMConf
Gaudi::Property< float > m_gridPhiMax
Gaudi::Property< std::vector< float > > m_zBinEdges
Gaudi::Property< bool > m_seedConfirmation
Gaudi::Property< float > m_seedConfForwardMaxZOrigin
Gaudi::Property< float > m_seedWeightIncrement
bool doubletSelectionFunction(const Acts::ConstSpacePointProxy2 &middle, const Acts::ConstSpacePointProxy2 &other, float cotTheta, bool isBottomCandidate) const
Gaudi::Property< float > m_radLengthPerSeed
Gaudi::Property< float > m_cotThetaMax
Gaudi::Property< float > m_deltaRMinBottomSP
Gaudi::Property< size_t > m_seedConfCentralNTopLargeR
Gaudi::Property< float > m_seedConfForwardZMax
Gaudi::Property< bool > m_seedConfirmationInFilter
Gaudi::Property< std::vector< std::size_t > > m_rBinsCustomLooping
Gaudi::Property< float > m_seedConfCentralRMax
std::unique_ptr< const Acts::Logger > m_logger
logging instance
Gaudi::Property< float > m_sigmaScattering
Gaudi::Property< std::vector< size_t > > m_zBinsCustomLooping
Gaudi::Property< float > m_seedConfCentralZMax
Gaudi::Property< float > m_deltaRMaxTopSP
Gaudi::Property< std::size_t > m_compatSeedLimit
Gaudi::Property< size_t > m_seedConfForwardNTopSmallR
Gaudi::Property< float > m_seedConfCentralZMin
Gaudi::Property< float > m_numSeedIncrement
Gaudi::Property< size_t > m_seedConfForwardNTopLargeR
unsigned long ul
retrieve(aClass, aKey=None)
Definition PyKernel.py:110

◆ logger()

const Acts::Logger & ActsTrk::GridTripletSeedingTool::logger ( ) const
inlineprivate

Private access to the logger.

Definition at line 352 of file GridTripletSeedingTool.h.

352{ return *m_logger; }

◆ retrieveRadiusRangeForMiddle()

std::pair< float, float > ActsTrk::GridTripletSeedingTool::retrieveRadiusRangeForMiddle ( const Acts::ConstSpacePointProxy2 & spM,
const Acts::Range1D< float > & rMiddleSpRange ) const
private

Definition at line 366 of file GridTripletSeedingTool.cxx.

368 {
370 return {rMiddleSpRange.min(), rMiddleSpRange.max()};
371 }
372 if (m_rRangeMiddleSP.empty()) {
373 throw std::runtime_error(
374 "m_rRangeMiddleSP is empty, please check the configuration.");
375 }
376
377 // get zBin position of the middle SP
378 auto pVal =
379 std::lower_bound(m_zBinEdges.begin(), m_zBinEdges.end(), spM.zr()[0]);
380 int zBin = std::distance(m_zBinEdges.begin(), pVal);
381 // protects against zM at the limit of zBinEdges
382 zBin == 0 ? zBin : --zBin;
383 return {m_rRangeMiddleSP[zBin][0], m_rRangeMiddleSP[zBin][1]};
384}

◆ spacePointSelectionFunction()

bool ActsTrk::GridTripletSeedingTool::spacePointSelectionFunction ( const xAOD::SpacePoint * sp,
float r ) const
private

Definition at line 286 of file GridTripletSeedingTool.cxx.

287 {
288 float zabs = std::abs(sp->z());
289 float absCotTheta = zabs / r;
290
291 // checking configuration to remove pixel space points
292 Identifier identifier = m_pixelId->wafer_id(sp->elementIdList().at(0));
293 if (m_pixelId->is_barrel(identifier)) {
294 if (zabs > 200 && r < 40)
295 return false;
296
297 return true;
298 }
299
300 // Inner layers
301 // Below 1.20 - accept all
302 static constexpr float cotThetaEta120 = 1.5095;
303 if (absCotTheta < cotThetaEta120)
304 return true;
305
306 // Below 3.40 - remove if too close to beamline
307 static constexpr float cotThetaEta340 = 14.9654;
308 if (absCotTheta < cotThetaEta340 && r < m_expCutrMin)
309 return false;
310
311 // Outer layers
312 // Above 2.20
313 static constexpr float cotThetaEta220 = 4.4571;
314 if (absCotTheta > cotThetaEta220 && r > 260.)
315 return false;
316
317 // Above 2.60
318 static constexpr float cotThetaEta260 = 6.6947;
319 if (absCotTheta > cotThetaEta260 && r > 200.)
320 return false;
321
322 // Above 3.20
323 static constexpr float cotThetaEta320 = 12.2459;
324 if (absCotTheta > cotThetaEta320 && r > 140.)
325 return false;
326
327 // Above 4.00
328 static constexpr float cotThetaEta400 = 27.2899;
329 if (absCotTheta > cotThetaEta400)
330 return false;
331
332 return true;
333}

Member Data Documentation

◆ m_binSizeR

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_binSizeR
protected
Initial value:
{
this, "binSizeR", 1. * Acts::UnitConstants::mm,
"defining radial bin for space point sorting"}

Definition at line 93 of file GridTripletSeedingTool.h.

93 {
94 this, "binSizeR", 1. * Acts::UnitConstants::mm,
95 "defining radial bin for space point sorting"};

◆ m_bottomDoubletFinderCfg

Acts::DoubletSeedFinder::Config ActsTrk::GridTripletSeedingTool::m_bottomDoubletFinderCfg
private

Definition at line 338 of file GridTripletSeedingTool.h.

◆ m_collisionRegionMax

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_collisionRegionMax
protected
Initial value:
{
this, "collisionRegionMax", 200. * Acts::UnitConstants::mm,
"limiting location of collision region in z"}

Definition at line 118 of file GridTripletSeedingTool.h.

118 {
119 this, "collisionRegionMax", 200. * Acts::UnitConstants::mm,
120 "limiting location of collision region in z"};

◆ m_collisionRegionMin

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_collisionRegionMin
protected
Initial value:
{
this, "collisionRegionMin", -200. * Acts::UnitConstants::mm,
"limiting location of collision region in z"}

Definition at line 115 of file GridTripletSeedingTool.h.

115 {
116 this, "collisionRegionMin", -200. * Acts::UnitConstants::mm,
117 "limiting location of collision region in z"};

◆ m_compatSeedLimit

Gaudi::Property<std::size_t> ActsTrk::GridTripletSeedingTool::m_compatSeedLimit
protected
Initial value:
{
this, "compatSeedLimit", 3,
"how often do you want to increase the weight of a seed for finding a "
"compatible seed"}

Definition at line 249 of file GridTripletSeedingTool.h.

249 {
250 this, "compatSeedLimit", 3,
251 "how often do you want to increase the weight of a seed for finding a "
252 "compatible seed"};

◆ m_compatSeedWeight

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_compatSeedWeight
protected
Initial value:
{
this, "compatSeedWeight", 100.,
"seed weight increased by this value if a compatible seed has been "
"found"}

Definition at line 245 of file GridTripletSeedingTool.h.

245 {
246 this, "compatSeedWeight", 100.,
247 "seed weight increased by this value if a compatible seed has been "
248 "found"};

◆ m_cotThetaMax

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_cotThetaMax
protected
Initial value:
{this, "cotThetaMax", 27.2899,
"cot of maximum theta angle"}

Definition at line 50 of file GridTripletSeedingTool.h.

50 {this, "cotThetaMax", 27.2899,
51 "cot of maximum theta angle"};

◆ m_deltaInvHelixDiameter

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_deltaInvHelixDiameter
protected
Initial value:
{
this, "deltaInvHelixDiameter", 0.00003 * 1. / Acts::UnitConstants::mm,
"the allowed delta between two inverted seed radii for them to be "
"considered compatible"}

Definition at line 271 of file GridTripletSeedingTool.h.

271 {
272 this, "deltaInvHelixDiameter", 0.00003 * 1. / Acts::UnitConstants::mm,
273 "the allowed delta between two inverted seed radii for them to be "
274 "considered compatible"};

◆ m_deltaRMax

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_deltaRMax
protected
Initial value:
{
this, "deltaRMax", 280. * Acts::UnitConstants::mm,
"maximum distance in r between two measurements within one "
"seed"}

Definition at line 56 of file GridTripletSeedingTool.h.

56 {
57 this, "deltaRMax", 280. * Acts::UnitConstants::mm,
58 "maximum distance in r between two measurements within one "
59 "seed"};

◆ m_deltaRMaxBottomSP

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_deltaRMaxBottomSP
protected
Initial value:
{
this, "deltaRMaxBottomSP", 150. * Acts::UnitConstants::mm,
"maximum distance in r between middle and top SP"}

Definition at line 109 of file GridTripletSeedingTool.h.

109 {
110 this, "deltaRMaxBottomSP", 150. * Acts::UnitConstants::mm,
111 "maximum distance in r between middle and top SP"};

◆ m_deltaRMaxTopSP

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_deltaRMaxTopSP
protected
Initial value:
{
this, "deltaRMaxTopSP", 280. * Acts::UnitConstants::mm,
"maximum distance in r between middle and top SP"}

Definition at line 103 of file GridTripletSeedingTool.h.

103 {
104 this, "deltaRMaxTopSP", 280. * Acts::UnitConstants::mm,
105 "maximum distance in r between middle and top SP"};

◆ m_deltaRMiddleMaxSPRange

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_deltaRMiddleMaxSPRange
protected
Initial value:
{
this, "deltaRMiddleMaxSPRange", 10., "delta R for middle SP range (max)"}

Definition at line 168 of file GridTripletSeedingTool.h.

168 {
169 this, "deltaRMiddleMaxSPRange", 10., "delta R for middle SP range (max)"};

◆ m_deltaRMiddleMinSPRange

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_deltaRMiddleMinSPRange
protected
Initial value:
{
this, "deltaRMiddleMinSPRange", 10., "delta R for middle SP range (min)"}

Definition at line 166 of file GridTripletSeedingTool.h.

166 {
167 this, "deltaRMiddleMinSPRange", 10., "delta R for middle SP range (min)"};

◆ m_deltaRMin

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_deltaRMin
protected
Initial value:
{
this, "deltaRMin", 20. * Acts::UnitConstants::mm,
"minimum distance in r between two measurements within one "
"seed"}

Definition at line 96 of file GridTripletSeedingTool.h.

96 {
97 this, "deltaRMin", 20. * Acts::UnitConstants::mm,
98 "minimum distance in r between two measurements within one "
99 "seed"};

◆ m_deltaRMinBottomSP

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_deltaRMinBottomSP
protected
Initial value:
{
this, "deltaRMinBottomSP", 6. * Acts::UnitConstants::mm,
"minimum distance in r between middle and top SP"}

Definition at line 106 of file GridTripletSeedingTool.h.

106 {
107 this, "deltaRMinBottomSP", 6. * Acts::UnitConstants::mm,
108 "minimum distance in r between middle and top SP"};

◆ m_deltaRMinTopSP

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_deltaRMinTopSP
protected
Initial value:
{
this, "deltaRMinTopSP", 6. * Acts::UnitConstants::mm,
"minimum distance in r between middle and top SP"}

Definition at line 100 of file GridTripletSeedingTool.h.

100 {
101 this, "deltaRMinTopSP", 6. * Acts::UnitConstants::mm,
102 "minimum distance in r between middle and top SP"};

◆ m_deltaZMax

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_deltaZMax
protected
Initial value:
{
this, "deltaZMax", 600,
"maximum distance in z between two measurements within one seed"}

Definition at line 112 of file GridTripletSeedingTool.h.

112 {
113 this, "deltaZMax", 600,
114 "maximum distance in z between two measurements within one seed"};

◆ m_expCutrMin

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_expCutrMin
protected
Initial value:
{this, "SpSelectionExpCutrMin",
45. * Acts::UnitConstants::mm}

Definition at line 333 of file GridTripletSeedingTool.h.

333 {this, "SpSelectionExpCutrMin",
334 45. * Acts::UnitConstants::mm};

◆ m_filterCfg

Acts::BroadTripletSeedFilter::Config ActsTrk::GridTripletSeedingTool::m_filterCfg
private

Definition at line 341 of file GridTripletSeedingTool.h.

◆ m_finder

std::optional<Acts::TripletSeeder> ActsTrk::GridTripletSeedingTool::m_finder
private

Definition at line 343 of file GridTripletSeedingTool.h.

◆ m_gridCfg

Acts::CylindricalSpacePointGrid2::Config ActsTrk::GridTripletSeedingTool::m_gridCfg
private

Definition at line 337 of file GridTripletSeedingTool.h.

◆ m_gridPhiMax

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_gridPhiMax
protected
Initial value:
{this, "gridPhiMax",
std::numbers::pi_v<float>,
"phi max for space point grid formation"}

Definition at line 80 of file GridTripletSeedingTool.h.

80 {this, "gridPhiMax",
81 std::numbers::pi_v<float>,
82 "phi max for space point grid formation"};

◆ m_gridPhiMin

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_gridPhiMin
protected
Initial value:
{this, "gridPhiMin",
-std::numbers::pi_v<float>,
"phi min for space point grid formation"}

Definition at line 77 of file GridTripletSeedingTool.h.

77 {this, "gridPhiMin",
78 -std::numbers::pi_v<float>,
79 "phi min for space point grid formation"};

◆ m_gridRMax

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_gridRMax
protected
Initial value:
{
this, "gridRMax", 320. * Acts::UnitConstants::mm,
"radial extension of subdetector to be used in grid building"}

Definition at line 74 of file GridTripletSeedingTool.h.

74 {
75 this, "gridRMax", 320. * Acts::UnitConstants::mm,
76 "radial extension of subdetector to be used in grid building"};

◆ m_impactMax

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_impactMax
protected
Initial value:
{this, "impactMax",
2. * Acts::UnitConstants::mm,
"maximum impact parameter"}

Definition at line 60 of file GridTripletSeedingTool.h.

60 {this, "impactMax",
61 2. * Acts::UnitConstants::mm,
62 "maximum impact parameter"};

◆ m_impactWeightFactor

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_impactWeightFactor
protected
Initial value:
{
this, "impactWeightFactor", 100.,
"the impact parameters (d0) is multiplied by this factor and subtracted "
"from weight"}

Definition at line 240 of file GridTripletSeedingTool.h.

240 {
241 this, "impactWeightFactor", 100.,
242 "the impact parameters (d0) is multiplied by this factor and subtracted "
243 "from weight"};

◆ m_interactionPointCut

Gaudi::Property<bool> ActsTrk::GridTripletSeedingTool::m_interactionPointCut
protected
Initial value:
{
this, "interactionPointCut", true,
"Enable cut on the compatibility between interaction point and SPs"}

Definition at line 136 of file GridTripletSeedingTool.h.

136 {
137 this, "interactionPointCut", true,
138 "Enable cut on the compatibility between interaction point and SPs"};

◆ m_logger

std::unique_ptr<const Acts::Logger> ActsTrk::GridTripletSeedingTool::m_logger
private

logging instance

Definition at line 346 of file GridTripletSeedingTool.h.

◆ m_loggerFilter

std::unique_ptr<const Acts::Logger> ActsTrk::GridTripletSeedingTool::m_loggerFilter
private

Definition at line 347 of file GridTripletSeedingTool.h.

◆ m_maxPhiBins

Gaudi::Property<int> ActsTrk::GridTripletSeedingTool::m_maxPhiBins
protected
Initial value:
{this, "maxPhiBins", 200,
"max number of bins"}

Definition at line 87 of file GridTripletSeedingTool.h.

87 {this, "maxPhiBins", 200,
88 "max number of bins"};

◆ m_maxPtScattering

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_maxPtScattering
protected
Initial value:
{
this, "maxPtScattering", 10e6,
"Upper pt limit for scattering calculation"}

Definition at line 124 of file GridTripletSeedingTool.h.

124 {
125 this, "maxPtScattering", 10e6,
126 "Upper pt limit for scattering calculation"};

◆ m_maxQualitySeedsPerSpMConf

Gaudi::Property<std::size_t> ActsTrk::GridTripletSeedingTool::m_maxQualitySeedsPerSpMConf
protected
Initial value:
{
this, "maxQualitySeedsPerSpMConf", 5,
"Maximum number of quality seeds for each middle-bottom SP-duplet in "
"seed confirmation."}

Definition at line 264 of file GridTripletSeedingTool.h.

264 {
265 this, "maxQualitySeedsPerSpMConf", 5,
266 "Maximum number of quality seeds for each middle-bottom SP-duplet in "
267 "seed confirmation."};

◆ m_maxSeedsPerSpM

Gaudi::Property<int> ActsTrk::GridTripletSeedingTool::m_maxSeedsPerSpM
protected
Initial value:
{
this, "maxSeedsPerSpM", 4,
"In dense environments many seeds may be found per middle space point. "
"Only seeds with the highest weight will be kept if this limit is "
"reached."}

Definition at line 131 of file GridTripletSeedingTool.h.

131 {
132 this, "maxSeedsPerSpM", 4,
133 "In dense environments many seeds may be found per middle space point. "
134 "Only seeds with the highest weight will be kept if this limit is "
135 "reached."};

◆ m_maxSeedsPerSpMConf

Gaudi::Property<std::size_t> ActsTrk::GridTripletSeedingTool::m_maxSeedsPerSpMConf
protected
Initial value:
{
this, "maxSeedsPerSpMConf", 5,
"Maximum number of lower quality seeds in seed confirmation."}

Definition at line 261 of file GridTripletSeedingTool.h.

261 {
262 this, "maxSeedsPerSpMConf", 5,
263 "Maximum number of lower quality seeds in seed confirmation."};

◆ m_minPt

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_minPt
protected
Initial value:
{this, "minPt", 900. * Acts::UnitConstants::MeV,
"lower pT cutoff for seeds"}

Definition at line 48 of file GridTripletSeedingTool.h.

48 {this, "minPt", 900. * Acts::UnitConstants::MeV,
49 "lower pT cutoff for seeds"};

◆ m_numPhiNeighbors

Gaudi::Property<int> ActsTrk::GridTripletSeedingTool::m_numPhiNeighbors
protected
Initial value:
{
this, "numPhiNeighbors", 1,
"number of phi bin neighbors at each side of the current bin that will "
"be used to search for SPs"}

Definition at line 321 of file GridTripletSeedingTool.h.

321 {
322 this, "numPhiNeighbors", 1,
323 "number of phi bin neighbors at each side of the current bin that will "
324 "be used to search for SPs"};

◆ m_numSeedIncrement

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_numSeedIncrement
protected
Initial value:
{
this, "numSeedIncrement", 10e6,
"increment in seed weight is applied if the number of compatible seeds "
"is larger than numSeedIncrement"}

Definition at line 255 of file GridTripletSeedingTool.h.

255 {
256 this, "numSeedIncrement", 10e6,
257 "increment in seed weight is applied if the number of compatible seeds "
258 "is larger than numSeedIncrement"};

◆ m_phiBinDeflectionCoverage

Gaudi::Property<int> ActsTrk::GridTripletSeedingTool::m_phiBinDeflectionCoverage
protected
Initial value:
{
this, "phiBinDeflectionCoverage", 3,
"sets of consecutive phi bins to cover full deflection of minimum pT "
"particle"}

Definition at line 83 of file GridTripletSeedingTool.h.

83 {
84 this, "phiBinDeflectionCoverage", 3,
85 "sets of consecutive phi bins to cover full deflection of minimum pT "
86 "particle"};

◆ m_phiMax

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_phiMax
protected
Initial value:
{this, "phiMax", std::numbers::pi_v<float>,
""}

Definition at line 230 of file GridTripletSeedingTool.h.

230 {this, "phiMax", std::numbers::pi_v<float>,
231 ""};

◆ m_phiMin

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_phiMin
protected
Initial value:
{this, "phiMin", -std::numbers::pi_v<float>,
""}

Definition at line 228 of file GridTripletSeedingTool.h.

228 {this, "phiMin", -std::numbers::pi_v<float>,
229 ""};

◆ m_pixelId

const PixelID* ActsTrk::GridTripletSeedingTool::m_pixelId {nullptr}
private

Definition at line 349 of file GridTripletSeedingTool.h.

349{nullptr};

◆ m_radLengthPerSeed

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_radLengthPerSeed
protected
Initial value:
{
this, "radLengthPerSeed", 0.098045,
"average radiation lengths of material on the length of a seed. used for "
"scattering"}

Definition at line 127 of file GridTripletSeedingTool.h.

127 {
128 this, "radLengthPerSeed", 0.098045,
129 "average radiation lengths of material on the length of a seed. used for "
130 "scattering"};

◆ m_rAlign

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_rAlign
protected
Initial value:
{this, "rAlign", 0 * Acts::UnitConstants::mm,
""}

Definition at line 235 of file GridTripletSeedingTool.h.

235 {this, "rAlign", 0 * Acts::UnitConstants::mm,
236 ""};

◆ m_rBinEdges

Gaudi::Property<std::vector<float> > ActsTrk::GridTripletSeedingTool::m_rBinEdges
protected
Initial value:
{
this,
"rBinEdges",
{0., 1100 * Acts::UnitConstants::mm},
"enable non equidistant binning in radius"}

Definition at line 69 of file GridTripletSeedingTool.h.

69 {
70 this,
71 "rBinEdges",
72 {0., 1100 * Acts::UnitConstants::mm},
73 "enable non equidistant binning in radius"};

◆ m_rBinNeighborsBottom

Gaudi::Property<std::vector<std::pair<int, int> > > ActsTrk::GridTripletSeedingTool::m_rBinNeighborsBottom
protected
Initial value:
{
this,
"rBinNeighborsBottom",
{{0, 0}},
"vector containing the map of radius bins in the bottom layers"}

Definition at line 316 of file GridTripletSeedingTool.h.

316 {
317 this,
318 "rBinNeighborsBottom",
319 {{0, 0}},
320 "vector containing the map of radius bins in the bottom layers"};

◆ m_rBinNeighborsTop

Gaudi::Property<std::vector<std::pair<int, int> > > ActsTrk::GridTripletSeedingTool::m_rBinNeighborsTop
protected
Initial value:
{
this,
"rBinNeighborsTop",
{{0, 0}},
"vector containing the map of radius bins in the top layers"}

Definition at line 311 of file GridTripletSeedingTool.h.

311 {
312 this,
313 "rBinNeighborsTop",
314 {{0, 0}},
315 "vector containing the map of radius bins in the top layers"};

◆ m_rBinsCustomLooping

Gaudi::Property<std::vector<std::size_t> > ActsTrk::GridTripletSeedingTool::m_rBinsCustomLooping
protected
Initial value:
{
this, "rBinsCustomLooping", {1}, "defines order of r bins for looping"}

Definition at line 144 of file GridTripletSeedingTool.h.

144 {
145 this, "rBinsCustomLooping", {1}, "defines order of r bins for looping"};

◆ m_rMax

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_rMax
protected
Initial value:
{this, "rMax", 320. * Acts::UnitConstants::mm,
"limiting location of measurements"}

Definition at line 91 of file GridTripletSeedingTool.h.

91 {this, "rMax", 320. * Acts::UnitConstants::mm,
92 "limiting location of measurements"};

◆ m_rMin

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_rMin {this, "rMin", 0 * Acts::UnitConstants::mm, ""}
protected

Definition at line 232 of file GridTripletSeedingTool.h.

232{this, "rMin", 0 * Acts::UnitConstants::mm, ""};

◆ m_rRangeMiddleSP

Gaudi::Property<std::vector<std::vector<double> > > ActsTrk::GridTripletSeedingTool::m_rRangeMiddleSP
protected
Initial value:
{
this,
"rRangeMiddleSP",
{{40.0, 90.0},
{40.0, 90.0},
{40.0, 200.0},
{46.0, 200.0},
{46.0, 200.0},
{46.0, 250.0},
{46.0, 250.0},
{46.0, 250.0},
{46.0, 200.0},
{46.0, 200.0},
{40.0, 200.0},
{40.0, 90.0},
{40.0, 90.0}},
"radial range for middle SP"}

Definition at line 149 of file GridTripletSeedingTool.h.

149 {
150 this,
151 "rRangeMiddleSP",
152 {{40.0, 90.0},
153 {40.0, 90.0},
154 {40.0, 200.0},
155 {46.0, 200.0},
156 {46.0, 200.0},
157 {46.0, 250.0},
158 {46.0, 250.0},
159 {46.0, 250.0},
160 {46.0, 200.0},
161 {46.0, 200.0},
162 {40.0, 200.0},
163 {40.0, 90.0},
164 {40.0, 90.0}},
165 "radial range for middle SP"};

◆ m_seedConfCentralMaxZOrigin

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_seedConfCentralMaxZOrigin
protected
Initial value:
{
this, "seedConfCentralMaxZOrigin", 150 * Acts::UnitConstants::mm,
"Maximum zOrigin in seed confirmation"}

Definition at line 190 of file GridTripletSeedingTool.h.

190 {
191 this, "seedConfCentralMaxZOrigin", 150 * Acts::UnitConstants::mm,
192 "Maximum zOrigin in seed confirmation"};

◆ m_seedConfCentralMinBottomRadius

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_seedConfCentralMinBottomRadius
protected
Initial value:
{
this, "seedConfCentralMinBottomRadius", 60 * Acts::UnitConstants::mm,
"Minimum radius for bottom SP in seed confirmation"}

Definition at line 187 of file GridTripletSeedingTool.h.

187 {
188 this, "seedConfCentralMinBottomRadius", 60 * Acts::UnitConstants::mm,
189 "Minimum radius for bottom SP in seed confirmation"};

◆ m_seedConfCentralMinImpact

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_seedConfCentralMinImpact
protected
Initial value:
{
this, "seedConfCentralMinImpact", 1. * Acts::UnitConstants::mm,
"Minimum impact parameter for seed confirmation"}

Definition at line 193 of file GridTripletSeedingTool.h.

193 {
194 this, "seedConfCentralMinImpact", 1. * Acts::UnitConstants::mm,
195 "Minimum impact parameter for seed confirmation"};

◆ m_seedConfCentralNTopLargeR

Gaudi::Property<size_t> ActsTrk::GridTripletSeedingTool::m_seedConfCentralNTopLargeR
protected
Initial value:
{
this, "seedConfCentralNTopLargeR", 1,
"nTop for large R central seed confirmation"}

Definition at line 181 of file GridTripletSeedingTool.h.

181 {
182 this, "seedConfCentralNTopLargeR", 1,
183 "nTop for large R central seed confirmation"};

◆ m_seedConfCentralNTopSmallR

Gaudi::Property<size_t> ActsTrk::GridTripletSeedingTool::m_seedConfCentralNTopSmallR
protected
Initial value:
{
this, "seedConfCentralNTopSmallR", 2,
"nTop for small R central seed confirmation"}

Definition at line 184 of file GridTripletSeedingTool.h.

184 {
185 this, "seedConfCentralNTopSmallR", 2,
186 "nTop for small R central seed confirmation"};

◆ m_seedConfCentralRMax

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_seedConfCentralRMax
protected
Initial value:
{
this, "seedConfCentralRMax", 140. * Acts::UnitConstants::mm,
"maximum r for central seed confirmation "}

Definition at line 178 of file GridTripletSeedingTool.h.

178 {
179 this, "seedConfCentralRMax", 140. * Acts::UnitConstants::mm,
180 "maximum r for central seed confirmation "};

◆ m_seedConfCentralZMax

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_seedConfCentralZMax
protected
Initial value:
{
this, "seedConfCentralZMax", 250. * Acts::UnitConstants::mm,
"maximum z for central seed confirmation "}

Definition at line 175 of file GridTripletSeedingTool.h.

175 {
176 this, "seedConfCentralZMax", 250. * Acts::UnitConstants::mm,
177 "maximum z for central seed confirmation "};

◆ m_seedConfCentralZMin

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_seedConfCentralZMin
protected
Initial value:
{
this, "seedConfCentralZMin", -250. * Acts::UnitConstants::mm,
"minimum z for central seed confirmation "}

Definition at line 172 of file GridTripletSeedingTool.h.

172 {
173 this, "seedConfCentralZMin", -250. * Acts::UnitConstants::mm,
174 "minimum z for central seed confirmation "};

◆ m_seedConfForwardMaxZOrigin

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_seedConfForwardMaxZOrigin
protected
Initial value:
{
this, "seedConfForwardMaxZOrigin", 150 * Acts::UnitConstants::mm,
"Maximum zOrigin in seed confirmation"}

Definition at line 214 of file GridTripletSeedingTool.h.

214 {
215 this, "seedConfForwardMaxZOrigin", 150 * Acts::UnitConstants::mm,
216 "Maximum zOrigin in seed confirmation"};

◆ m_seedConfForwardMinBottomRadius

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_seedConfForwardMinBottomRadius
protected
Initial value:
{
this, "seedConfForwardMinBottomRadius", 60 * Acts::UnitConstants::mm,
"Minimum radius for bottom SP in seed confirmation"}

Definition at line 211 of file GridTripletSeedingTool.h.

211 {
212 this, "seedConfForwardMinBottomRadius", 60 * Acts::UnitConstants::mm,
213 "Minimum radius for bottom SP in seed confirmation"};

◆ m_seedConfForwardMinImpact

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_seedConfForwardMinImpact
protected
Initial value:
{
this, "seedConfForwardMinImpact", 1. * Acts::UnitConstants::mm,
"Minimum impact parameter for seed confirmation"}

Definition at line 217 of file GridTripletSeedingTool.h.

217 {
218 this, "seedConfForwardMinImpact", 1. * Acts::UnitConstants::mm,
219 "Minimum impact parameter for seed confirmation"};

◆ m_seedConfForwardNTopLargeR

Gaudi::Property<size_t> ActsTrk::GridTripletSeedingTool::m_seedConfForwardNTopLargeR
protected
Initial value:
{
this, "seedConfForwardNTopLargeR", 1,
"nTop for large R forward seed confirmation"}

Definition at line 205 of file GridTripletSeedingTool.h.

205 {
206 this, "seedConfForwardNTopLargeR", 1,
207 "nTop for large R forward seed confirmation"};

◆ m_seedConfForwardNTopSmallR

Gaudi::Property<size_t> ActsTrk::GridTripletSeedingTool::m_seedConfForwardNTopSmallR
protected
Initial value:
{
this, "seedConfForwardNTopSmallR", 2,
"nTop for small R forward seed confirmation"}

Definition at line 208 of file GridTripletSeedingTool.h.

208 {
209 this, "seedConfForwardNTopSmallR", 2,
210 "nTop for small R forward seed confirmation"};

◆ m_seedConfForwardRMax

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_seedConfForwardRMax
protected
Initial value:
{
this, "seedConfForwardRMax", 140. * Acts::UnitConstants::mm,
"maximum r for forward seed confirmation "}

Definition at line 202 of file GridTripletSeedingTool.h.

202 {
203 this, "seedConfForwardRMax", 140. * Acts::UnitConstants::mm,
204 "maximum r for forward seed confirmation "};

◆ m_seedConfForwardZMax

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_seedConfForwardZMax
protected
Initial value:
{
this, "seedConfForwardZMax", 3000. * Acts::UnitConstants::mm,
"maximum z for forward seed confirmation "}

Definition at line 199 of file GridTripletSeedingTool.h.

199 {
200 this, "seedConfForwardZMax", 3000. * Acts::UnitConstants::mm,
201 "maximum z for forward seed confirmation "};

◆ m_seedConfForwardZMin

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_seedConfForwardZMin
protected
Initial value:
{
this, "seedConfForwardZMin", -3000. * Acts::UnitConstants::mm,
"minimum z for forward seed confirmation "}

Definition at line 196 of file GridTripletSeedingTool.h.

196 {
197 this, "seedConfForwardZMin", -3000. * Acts::UnitConstants::mm,
198 "minimum z for forward seed confirmation "};

◆ m_seedConfirmation

Gaudi::Property<bool> ActsTrk::GridTripletSeedingTool::m_seedConfirmation
protected
Initial value:
{this, "seedConfirmation", true,
"run seed confirmation"}

Definition at line 170 of file GridTripletSeedingTool.h.

170 {this, "seedConfirmation", true,
171 "run seed confirmation"};

◆ m_seedConfirmationInFilter

Gaudi::Property<bool> ActsTrk::GridTripletSeedingTool::m_seedConfirmationInFilter
protected
Initial value:
{
this, "seedConfirmationInFilter", true, "run seed confirmation"}

Definition at line 259 of file GridTripletSeedingTool.h.

259 {
260 this, "seedConfirmationInFilter", true, "run seed confirmation"};

◆ m_seedQualitySelection

Gaudi::Property<bool> ActsTrk::GridTripletSeedingTool::m_seedQualitySelection
protected
Initial value:
{
this, "doSeedQualitySelection", true,
"Select seed according to quality criteria"}

Definition at line 42 of file GridTripletSeedingTool.h.

42 {
43 this, "doSeedQualitySelection", true,
44 "Select seed according to quality criteria"};

◆ m_seedWeightIncrement

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_seedWeightIncrement
protected
Initial value:
{
this, "seedWeightIncrement", 0., "increment in seed weight if needed"}

Definition at line 253 of file GridTripletSeedingTool.h.

253 {
254 this, "seedWeightIncrement", 0., "increment in seed weight if needed"};

◆ m_sigmaError

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_sigmaError {this, "sigmaError", 5, ""}
protected

Definition at line 237 of file GridTripletSeedingTool.h.

237{this, "sigmaError", 5, ""};

◆ m_sigmaScattering

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_sigmaScattering
protected
Initial value:
{
this, "sigmaScattering", 2.,
"how many sigmas of scattering angle should be considered"}

Definition at line 121 of file GridTripletSeedingTool.h.

121 {
122 this, "sigmaScattering", 2.,
123 "how many sigmas of scattering angle should be considered"};

◆ m_stateVectorReserveSize

Gaudi::Property<int> ActsTrk::GridTripletSeedingTool::m_stateVectorReserveSize
protected
Initial value:
{
this, "stateVectorReserveSize", 500,
"Size of the initial Seeding State internal vectors"}

Definition at line 329 of file GridTripletSeedingTool.h.

329 {
330 this, "stateVectorReserveSize", 500,
331 "Size of the initial Seeding State internal vectors"};

◆ m_toleranceParam

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_toleranceParam
protected
Initial value:
{
this, "toleranceParam", 1.1 * Acts::UnitConstants::mm,
"tolerance parameter used to check the compatibility of SPs coordinates "
"in xyz"}

Definition at line 224 of file GridTripletSeedingTool.h.

224 {
225 this, "toleranceParam", 1.1 * Acts::UnitConstants::mm,
226 "tolerance parameter used to check the compatibility of SPs coordinates "
227 "in xyz"};

◆ m_topDoubletFinderCfg

Acts::DoubletSeedFinder::Config ActsTrk::GridTripletSeedingTool::m_topDoubletFinderCfg
private

Definition at line 339 of file GridTripletSeedingTool.h.

◆ m_tripletFinderCfg

Acts::TripletSeedFinder::Config ActsTrk::GridTripletSeedingTool::m_tripletFinderCfg
private

Definition at line 340 of file GridTripletSeedingTool.h.

◆ m_useDeltaRorTopRadius

Gaudi::Property<bool> ActsTrk::GridTripletSeedingTool::m_useDeltaRorTopRadius
protected
Initial value:
{
this, "useDeltaRorTopRadius", true,
"use deltaR (top radius - middle radius) instead of top radius"}

Definition at line 268 of file GridTripletSeedingTool.h.

268 {
269 this, "useDeltaRorTopRadius", true,
270 "use deltaR (top radius - middle radius) instead of top radius"};

◆ m_useDetailedDoubleMeasurementInfo

Gaudi::Property<bool> ActsTrk::GridTripletSeedingTool::m_useDetailedDoubleMeasurementInfo
protected
Initial value:
{
this, "useDetailedDoubleMeasurementInfo", false,
"enable use of double measurement details"}

Definition at line 220 of file GridTripletSeedingTool.h.

220 {
221 this, "useDetailedDoubleMeasurementInfo", false,
222 "enable use of double measurement details"};

◆ m_useExperimentCuts

Gaudi::Property<bool> ActsTrk::GridTripletSeedingTool::m_useExperimentCuts
protected
Initial value:
{this, "useExperimentCuts", false,
""}

Definition at line 326 of file GridTripletSeedingTool.h.

326 {this, "useExperimentCuts", false,
327 ""};

◆ m_useVariableMiddleSPRange

Gaudi::Property<bool> ActsTrk::GridTripletSeedingTool::m_useVariableMiddleSPRange
protected
Initial value:
{
this, "useVariableMiddleSPRange", true,
"Enable variable range to search for middle SPs"}

Definition at line 146 of file GridTripletSeedingTool.h.

146 {
147 this, "useVariableMiddleSPRange", true,
148 "Enable variable range to search for middle SPs"};

◆ m_zAlign

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_zAlign
protected
Initial value:
{this, "zAlign", 0 * Acts::UnitConstants::mm,
""}

Definition at line 233 of file GridTripletSeedingTool.h.

233 {this, "zAlign", 0 * Acts::UnitConstants::mm,
234 ""};

◆ m_zBinEdges

Gaudi::Property<std::vector<float> > ActsTrk::GridTripletSeedingTool::m_zBinEdges
protected
Initial value:
{
this,
"zBinEdges",
{-3000., -2700., -2500., -1400., -925., -500., -250., 250., 500., 925.,
1400., 2500., 2700, 3000.},
"enable non equidistant binning in z"}

Definition at line 63 of file GridTripletSeedingTool.h.

63 {
64 this,
65 "zBinEdges",
66 {-3000., -2700., -2500., -1400., -925., -500., -250., 250., 500., 925.,
67 1400., 2500., 2700, 3000.},
68 "enable non equidistant binning in z"};

◆ m_zBinNeighborsBottom

Gaudi::Property<std::vector<std::pair<int, int> > > ActsTrk::GridTripletSeedingTool::m_zBinNeighborsBottom
protected
Initial value:
{
this,
"zBinNeighborsBottom",
{{0, 0},
{0, 1},
{0, 1},
{0, 1},
{0, 1},
{0, 1},
{0, 0},
{-1, 0},
{-1, 0},
{-1, 0},
{-1, 0},
{-1, 0},
{0, 0}},
"vector containing the map of z bins in the top layers"}

Definition at line 294 of file GridTripletSeedingTool.h.

294 {
295 this,
296 "zBinNeighborsBottom",
297 {{0, 0},
298 {0, 1},
299 {0, 1},
300 {0, 1},
301 {0, 1},
302 {0, 1},
303 {0, 0},
304 {-1, 0},
305 {-1, 0},
306 {-1, 0},
307 {-1, 0},
308 {-1, 0},
309 {0, 0}},
310 "vector containing the map of z bins in the top layers"};

◆ m_zBinNeighborsTop

Gaudi::Property<std::vector<std::pair<int, int> > > ActsTrk::GridTripletSeedingTool::m_zBinNeighborsTop
protected
Initial value:
{
this,
"zBinNeighborsTop",
{{0, 0},
{-1, 0},
{-2, 0},
{-1, 0},
{-1, 0},
{-1, 0},
{-1, 1},
{0, 1},
{0, 1},
{0, 1},
{0, 2},
{0, 1},
{0, 0}},
"vector containing the map of z bins in the top layers"}

Definition at line 277 of file GridTripletSeedingTool.h.

277 {
278 this,
279 "zBinNeighborsTop",
280 {{0, 0},
281 {-1, 0},
282 {-2, 0},
283 {-1, 0},
284 {-1, 0},
285 {-1, 0},
286 {-1, 1},
287 {0, 1},
288 {0, 1},
289 {0, 1},
290 {0, 2},
291 {0, 1},
292 {0, 0}},
293 "vector containing the map of z bins in the top layers"};

◆ m_zBinsCustomLooping

Gaudi::Property<std::vector<size_t> > ActsTrk::GridTripletSeedingTool::m_zBinsCustomLooping
protected
Initial value:
{
this,
"zBinsCustomLooping",
{2, 3, 4, 5, 12, 11, 10, 9, 7, 6, 8},
"defines order of z bins for looping"}

Definition at line 139 of file GridTripletSeedingTool.h.

139 {
140 this,
141 "zBinsCustomLooping",
142 {2, 3, 4, 5, 12, 11, 10, 9, 7, 6, 8},
143 "defines order of z bins for looping"};

◆ m_zMax

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_zMax
protected
Initial value:
{this, "zMax", 3000. * Acts::UnitConstants::mm,
"limiting location of measurements"}

Definition at line 54 of file GridTripletSeedingTool.h.

54 {this, "zMax", 3000. * Acts::UnitConstants::mm,
55 "limiting location of measurements"};

◆ m_zMin

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_zMin
protected
Initial value:
{this, "zMin", -3000. * Acts::UnitConstants::mm,
"limiting location of measurements"}

Definition at line 52 of file GridTripletSeedingTool.h.

52 {this, "zMin", -3000. * Acts::UnitConstants::mm,
53 "limiting location of measurements"};

◆ m_zOriginWeightFactor

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_zOriginWeightFactor {this, "zOriginWeightFactor", 1.}
protected

Definition at line 244 of file GridTripletSeedingTool.h.

244{this, "zOriginWeightFactor", 1.};

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