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 createSeeds (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_maxStripDeltaCotTheta
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< float > m_absDeltaEtaWeightFactor
Gaudi::Property< float > m_absDeltaEtaMinImpact
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

◆ createSeeds()

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

Definition at line 389 of file GridTripletSeedingTool.cxx.

393 {
394 (void)ctx;
395
396 auto gridCfg = m_gridCfg;
397 gridCfg.bFieldInZ = bFieldInZ;
398
399 Acts::CylindricalSpacePointGrid2 grid(gridCfg,
400 logger().cloneWithSuffix("Grid"));
401
402 std::size_t totalSpacePoints = 0;
403 for (const xAOD::SpacePointContainer* spacePoints : spacePointCollections) {
404 totalSpacePoints += spacePoints->size();
405 }
406
407 std::vector<const xAOD::SpacePoint*> selectedXAODSpacePoints;
408 std::vector<float> selectedSpacePointsR;
409 selectedXAODSpacePoints.reserve(totalSpacePoints);
410 selectedSpacePointsR.reserve(totalSpacePoints);
411
412 for (const xAOD::SpacePointContainer* spacePoints : spacePointCollections) {
413 for (const xAOD::SpacePoint* sp : *spacePoints) {
414 float x = static_cast<float>(sp->x() - beamSpotPos[0]);
415 float y = static_cast<float>(sp->y() - beamSpotPos[1]);
416 float z = static_cast<float>(sp->z());
417 float r = std::hypot(x, y);
418 float phi = std::atan2(y, x);
419
421 continue;
422 }
423
424 grid.insert(selectedXAODSpacePoints.size(), phi, z, r);
425 selectedXAODSpacePoints.push_back(sp);
426 selectedSpacePointsR.push_back(r);
427 }
428 }
429
430 for (std::size_t i = 0; i < grid.numberOfBins(); ++i) {
431 std::ranges::sort(
432 grid.at(i), [&](Acts::SpacePointIndex2 a, Acts::SpacePointIndex2 b) {
433 return selectedSpacePointsR[a] < selectedSpacePointsR[b];
434 });
435 }
436
437 Acts::SpacePointContainer2 selectedSpacePoints;
438 selectedSpacePoints.createColumns(
439 Acts::SpacePointColumns::CopyFromIndex |
440 Acts::SpacePointColumns::PackedXY | Acts::SpacePointColumns::PackedZR |
441 Acts::SpacePointColumns::VarianceZ | Acts::SpacePointColumns::VarianceR);
443 selectedSpacePoints.createColumns(Acts::SpacePointColumns::Strip);
444 }
445 selectedSpacePoints.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 auto newSp = selectedSpacePoints.createSpacePoint();
454 newSp.copyFromIndex() = spIndex;
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 std::uint32_t end = selectedSpacePoints.size();
483 gridSpacePointRanges.emplace_back(begin, end);
484 }
485
486 // clear temporary
487 selectedSpacePointsR = {};
488
489 ACTS_VERBOSE("Number of space points after selection "
490 << selectedSpacePoints.size() << " out of " << totalSpacePoints);
491
492 // Compute radius range. We rely on the fact the grid is storing the proxies
493 // with a sorting in the radius
494 const Acts::Range1D<float> rRange = [&]() -> Acts::Range1D<float> {
495 float minRange = std::numeric_limits<float>::max();
496 float maxRange = std::numeric_limits<float>::lowest();
497 for (const Acts::SpacePointIndexRange2& range : gridSpacePointRanges) {
498 if (range.first == range.second) {
499 continue;
500 }
501 auto first = selectedSpacePoints[range.first];
502 auto last = selectedSpacePoints[range.second - 1];
503 minRange = std::min(first.zr()[1], minRange);
504 maxRange = std::max(last.zr()[1], maxRange);
505 }
506 return {minRange, maxRange};
507 }();
508
509 auto bottomDoubletFinder =
510 Acts::DoubletSeedFinder::create(Acts::DoubletSeedFinder::DerivedConfig(
511 m_bottomDoubletFinderCfg, bFieldInZ));
512 auto topDoubletFinder = Acts::DoubletSeedFinder::create(
513 Acts::DoubletSeedFinder::DerivedConfig(m_topDoubletFinderCfg, bFieldInZ));
514 auto tripletFinder = Acts::TripletSeedFinder::create(
515 Acts::TripletSeedFinder::DerivedConfig(m_tripletFinderCfg, bFieldInZ));
516
517 // variable middle SP radial region of interest
518 const Acts::Range1D<float> rMiddleSpRange(
519 std::floor(rRange.min() / 2) * 2 + m_deltaRMiddleMinSPRange,
520 std::floor(rRange.max() / 2) * 2 - m_deltaRMiddleMaxSPRange);
521
522 Acts::BroadTripletSeedFilter::State filterState;
523 Acts::BroadTripletSeedFilter::Cache filterCache;
524 Acts::TripletSeeder::Cache cache;
525
526 Acts::BroadTripletSeedFilter filter(m_filterCfg, filterState, filterCache,
528
529 std::vector<Acts::SpacePointContainer2::ConstRange> bottomSpRanges;
530 std::optional<Acts::SpacePointContainer2::ConstRange> middleSpRange;
531 std::vector<Acts::SpacePointContainer2::ConstRange> topSpRanges;
532
533 Acts::SeedContainer2 tmpSeedContainer;
534
535 for (const auto [bottom, middle, top] : grid.binnedGroup()) {
536 ACTS_VERBOSE("Process middle bin " << middle);
537 if (middle >= gridSpacePointRanges.size()) {
538 ATH_MSG_ERROR("Grid Binned Group returned an unreasonable middle bin");
539 return StatusCode::FAILURE;
540 }
541
542 bottomSpRanges.clear();
543 topSpRanges.clear();
544
545 std::ranges::transform(
546 bottom, std::back_inserter(bottomSpRanges),
547 [&](std::size_t b) -> Acts::SpacePointContainer2::ConstRange {
548 return selectedSpacePoints.range(gridSpacePointRanges[b]).asConst();
549 });
550 middleSpRange =
551 selectedSpacePoints.range(gridSpacePointRanges[middle]).asConst();
552 std::ranges::transform(
553 top, std::back_inserter(topSpRanges),
554 [&](std::size_t t) -> Acts::SpacePointContainer2::ConstRange {
555 return selectedSpacePoints.range(gridSpacePointRanges[t]).asConst();
556 });
557
558 // we compute this here since all middle space point candidates belong to
559 // the same z-bin
560 auto firstMiddleSp = middleSpRange->front();
561 auto radiusRangeForMiddle =
562 retrieveRadiusRangeForMiddle(firstMiddleSp, rMiddleSpRange);
563
564 ACTS_VERBOSE("Validity range (radius) for the middle space point is ["
565 << radiusRangeForMiddle.first << ", "
566 << radiusRangeForMiddle.second << "]");
567
568 m_finder->createSeedsFromGroups(
569 cache, *bottomDoubletFinder, *topDoubletFinder, *tripletFinder, filter,
570 selectedSpacePoints, bottomSpRanges, *middleSpRange, topSpRanges,
571 radiusRangeForMiddle, tmpSeedContainer);
572 }
573
574 // Selection function - temporary implementation
575 // need change from ACTS for final implementation
576 // To be used only on PPP
577 auto selectionFunction =
578 [&filterState](const Acts::MutableSeedProxy2& seed) -> bool {
579 float seedQuality = seed.quality();
580 float bottomQuality =
581 filterState.bestSeedQualityMap.at(seed.spacePointIndices()[0]);
582 float middleQuality =
583 filterState.bestSeedQualityMap.at(seed.spacePointIndices()[1]);
584 float topQuality =
585 filterState.bestSeedQualityMap.at(seed.spacePointIndices()[2]);
586
587 return bottomQuality <= seedQuality || middleQuality <= seedQuality ||
588 topQuality <= seedQuality;
589 };
590
591 seedContainer.reserve(seedContainer.size() + tmpSeedContainer.size());
592
593 // Select and convert the seeds
594 for (Acts::MutableSeedProxy2 seed : tmpSeedContainer) {
595 if (m_seedQualitySelection && !selectionFunction(seed)) {
596 continue;
597 }
598
599 seedContainer.push_back(
600 Acts::ConstSeedProxy2(seed), [&](const Acts::SpacePointIndex2 spIndex) {
601 const Acts::SpacePointIndex2 originalIndex =
602 selectedSpacePoints.at(spIndex).copyFromIndex();
603 return selectedXAODSpacePoints[originalIndex];
604 });
605 }
606
607 return StatusCode::SUCCESS;
608}
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
const IIntersectionCache * cache() const
Retrieve the associated cache block, if it exists.
SpacePointContainer_v1 SpacePointContainer
Define the version of the space point container.
Seed push_back(SpacePointRange spacePoints, float quality, float vertexZ)
void reserve(std::size_t size, float averageSpacePoints=3) noexcept
std::size_t size() const noexcept

◆ doubletSelectionFunction()

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

Definition at line 338 of file GridTripletSeedingTool.cxx.

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

◆ 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
229 m_tripletFinderCfg.sortedByCotTheta = true;
231 m_tripletFinderCfg.sigmaScattering = m_sigmaScattering;
232 m_tripletFinderCfg.radLengthPerSeed = m_radLengthPerSeed;
234 m_tripletFinderCfg.helixCutTolerance = 1.;
235 m_tripletFinderCfg.toleranceParam = m_toleranceParam;
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 m_filterCfg.absDeltaEtaWeightFactor = m_absDeltaEtaWeightFactor;
277 m_filterCfg.absDeltaEtaMinImpact = m_absDeltaEtaMinImpact;
278
279
280 m_finder = Acts::TripletSeeder(logger().cloneWithSuffix("Finder"));
281
282 m_loggerFilter = logger().cloneWithSuffix("Filter");
283
284 ATH_CHECK(detStore()->retrieve(m_pixelId, "PixelID"));
285
286 return StatusCode::SUCCESS;
287}
#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_maxStripDeltaCotTheta
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_absDeltaEtaMinImpact
Gaudi::Property< float > m_absDeltaEtaWeightFactor
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

◆ logger()

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

Private access to the logger.

Definition at line 365 of file GridTripletSeedingTool.h.

365{ 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 369 of file GridTripletSeedingTool.cxx.

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

◆ spacePointSelectionFunction()

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

Definition at line 289 of file GridTripletSeedingTool.cxx.

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

Member Data Documentation

◆ m_absDeltaEtaMinImpact

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_absDeltaEtaMinImpact
protected
Initial value:
{
this, "absDeltaEtaMinImpact", 2. * Acts::UnitConstants::mm,
"minimum impact parameter to apply abs(delta-eta) weight"}

Definition at line 284 of file GridTripletSeedingTool.h.

284 {
285 this, "absDeltaEtaMinImpact", 2. * Acts::UnitConstants::mm,
286 "minimum impact parameter to apply abs(delta-eta) weight"};

◆ m_absDeltaEtaWeightFactor

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_absDeltaEtaWeightFactor
protected
Initial value:
{
this, "absDeltaEtaWeightFactor", 0.,
"weight factor for abs(delta-eta) penalty between seed direction and "
"beamspot-to-PCA direction (0 = disabled, typical LRT value: 10)"}

Definition at line 280 of file GridTripletSeedingTool.h.

280 {
281 this, "absDeltaEtaWeightFactor", 0.,
282 "weight factor for abs(delta-eta) penalty between seed direction and "
283 "beamspot-to-PCA direction (0 = disabled, typical LRT value: 10)"};

◆ 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 351 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 254 of file GridTripletSeedingTool.h.

254 {
255 this, "compatSeedLimit", 3,
256 "how often do you want to increase the weight of a seed for finding a "
257 "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 250 of file GridTripletSeedingTool.h.

250 {
251 this, "compatSeedWeight", 100.,
252 "seed weight increased by this value if a compatible seed has been "
253 "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 276 of file GridTripletSeedingTool.h.

276 {
277 this, "deltaInvHelixDiameter", 0.00003 * 1. / Acts::UnitConstants::mm,
278 "the allowed delta between two inverted seed radii for them to be "
279 "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 346 of file GridTripletSeedingTool.h.

346 {this, "SpSelectionExpCutrMin",
347 45. * Acts::UnitConstants::mm};

◆ m_filterCfg

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

Definition at line 354 of file GridTripletSeedingTool.h.

◆ m_finder

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

Definition at line 356 of file GridTripletSeedingTool.h.

◆ m_gridCfg

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

Definition at line 350 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 245 of file GridTripletSeedingTool.h.

245 {
246 this, "impactWeightFactor", 100.,
247 "the impact parameters (d0) is multiplied by this factor and subtracted "
248 "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 359 of file GridTripletSeedingTool.h.

◆ m_loggerFilter

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

Definition at line 360 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 269 of file GridTripletSeedingTool.h.

269 {
270 this, "maxQualitySeedsPerSpMConf", 5,
271 "Maximum number of quality seeds for each middle-bottom SP-duplet in "
272 "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 266 of file GridTripletSeedingTool.h.

266 {
267 this, "maxSeedsPerSpMConf", 5,
268 "Maximum number of lower quality seeds in seed confirmation."};

◆ m_maxStripDeltaCotTheta

Gaudi::Property<float> ActsTrk::GridTripletSeedingTool::m_maxStripDeltaCotTheta
protected
Initial value:
{
this, "maxStripDeltaCotTheta", 1e10f,
"maximum allowed |cotTheta_bottom - cotTheta_top| pre-filter for strip "
"triplets before expensive coordinate checks"}

Definition at line 228 of file GridTripletSeedingTool.h.

228 {
229 this, "maxStripDeltaCotTheta", 1e10f,
230 "maximum allowed |cotTheta_bottom - cotTheta_top| pre-filter for strip "
231 "triplets before expensive coordinate checks"};

◆ 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 334 of file GridTripletSeedingTool.h.

334 {
335 this, "numPhiNeighbors", 1,
336 "number of phi bin neighbors at each side of the current bin that will "
337 "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 260 of file GridTripletSeedingTool.h.

260 {
261 this, "numSeedIncrement", 10e6,
262 "increment in seed weight is applied if the number of compatible seeds "
263 "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 235 of file GridTripletSeedingTool.h.

235 {this, "phiMax", std::numbers::pi_v<float>,
236 ""};

◆ m_phiMin

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

Definition at line 233 of file GridTripletSeedingTool.h.

233 {this, "phiMin", -std::numbers::pi_v<float>,
234 ""};

◆ m_pixelId

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

Definition at line 362 of file GridTripletSeedingTool.h.

362{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 240 of file GridTripletSeedingTool.h.

240 {this, "rAlign", 0 * Acts::UnitConstants::mm,
241 ""};

◆ 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 329 of file GridTripletSeedingTool.h.

329 {
330 this,
331 "rBinNeighborsBottom",
332 {{0, 0}},
333 "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 324 of file GridTripletSeedingTool.h.

324 {
325 this,
326 "rBinNeighborsTop",
327 {{0, 0}},
328 "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 237 of file GridTripletSeedingTool.h.

237{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 264 of file GridTripletSeedingTool.h.

264 {
265 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 258 of file GridTripletSeedingTool.h.

258 {
259 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 242 of file GridTripletSeedingTool.h.

242{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 342 of file GridTripletSeedingTool.h.

342 {
343 this, "stateVectorReserveSize", 500,
344 "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 352 of file GridTripletSeedingTool.h.

◆ m_tripletFinderCfg

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

Definition at line 353 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 273 of file GridTripletSeedingTool.h.

273 {
274 this, "useDeltaRorTopRadius", true,
275 "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 339 of file GridTripletSeedingTool.h.

339 {this, "useExperimentCuts", false,
340 ""};

◆ 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 238 of file GridTripletSeedingTool.h.

238 {this, "zAlign", 0 * Acts::UnitConstants::mm,
239 ""};

◆ 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 307 of file GridTripletSeedingTool.h.

307 {
308 this,
309 "zBinNeighborsBottom",
310 {{0, 0},
311 {0, 1},
312 {0, 1},
313 {0, 1},
314 {0, 1},
315 {0, 1},
316 {0, 0},
317 {-1, 0},
318 {-1, 0},
319 {-1, 0},
320 {-1, 0},
321 {-1, 0},
322 {0, 0}},
323 "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 290 of file GridTripletSeedingTool.h.

290 {
291 this,
292 "zBinNeighborsTop",
293 {{0, 0},
294 {-1, 0},
295 {-2, 0},
296 {-1, 0},
297 {-1, 0},
298 {-1, 0},
299 {-1, 1},
300 {0, 1},
301 {0, 1},
302 {0, 1},
303 {0, 2},
304 {0, 1},
305 {0, 0}},
306 "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 249 of file GridTripletSeedingTool.h.

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

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