ATLAS Offline Software
Loading...
Searching...
No Matches
ActsTrk::detail Namespace Reference

Athena definition of the Eigen plugin. More...

Namespaces

namespace  FitterHelperFunctions
namespace  MakeDerivedVariant

Classes

class  MeasurementCalibratorBase
 Base class providing the boiler code to fill the Acts multi trajectory track states. More...
class  TrkMeasSurfaceAccessor
 Helper class to access the Acts::Surface for a given Acts::SourceLink which is poiniting to a Trk::MeasurementBase. More...
class  TrkMeasurementCalibrator
 Calibrator class that links the legacy Trk::MeasurementBase objects with the Acts MultiTrajectory track state proxies without applying any further calibrating the measurement. More...
class  TrkPrepRawDataCalibrator
 Class to calibrate the Acts track states with uncalibrated Trk::PrepRaw data objects. More...
class  TrkPrepRawDataSurfaceAcc
 Helper class to access the Acts::surface associated with a Trk::PrepRawData measurement. More...
class  xAODUncalibMeasCalibrator
 Source link calibrator implementation for xAOD::Uncalibrated measurements. More...
class  xAODUncalibMeasSurfAcc
 Helper class to access the Acts::surface associated with an Uncalibrated xAOD measurement. More...
struct  Decoration
struct  accepted_decoration_types
struct  ExpectedLayerPatternHelper
 Helper functions to encode the expected layer patterns in separate columns. More...
class  HitSummaryData
 Helper class to gather hit summary information for e.g. More...
class  SumOfValues
 Helper class to gather statistics and compute the biased variance. More...
class  AnalogueClusteringCalibrator
 the Analogue clustering calibrator More...
struct  AnalogueClusteringCalibratorOptions
 Options for the analogue clustering calibrator. More...
class  AnalogueClusteringToolImpl
 the tool to create the analogue clustering calibrator. More...
struct  MeasurementRange
class  GenMeasurementRangeList
class  GenMeasurementRangeListFlat
class  GenUncalibSourceLinkAccessor
 Accessor for the above source link container. More...
class  AtlasMeasurementContainerList
struct  CKF_config
class  DuplicateSeedDetector
class  MeasurementIndex
class  OnTrackCalibrator
 Inner detector / ITk calibrator implementation used in the KalmanFilterTool. More...
struct  PixelClusterCalibratorOptionsBase
 the base options the options of the options of every PixelClusterCalibrator must be based on More...
class  PixelClusterCalibratorCommon
 the common base class of a PixelClusterCalibrator. More...
class  PixelClusterCalibratorBase
class  PixelClusterCalibrationToolBase
 base class of a Pixel cluster calibration tool In addition to some common functionality provied by PixelClusterCalibrationCommon this class implements the methods to connect the calibrator to the calibrator delegates, and the OnTrack and OnBoundState interfaces which will call a single calibrate method. More...
class  RefittingCalibrator
class  SharedHitCounter
class  StripCalibrator
class  StripCalibratorToolImpl
class  TrackFindingMeasurements

Typedefs

using SetterType
using GetterType
using CopierType
using MeasurementRangeList = GenMeasurementRangeList< AtlasMeasurementContainerList >
using MeasurementRangeListFlat = GenMeasurementRangeListFlat< AtlasMeasurementContainerList >
using UncalibSourceLinkAccessor = GenUncalibSourceLinkAccessor< MeasurementRangeList >
using RecoTrackContainer
using RecoTrackContainerProxy = RecoTrackContainer::TrackProxy
using RecoTrackStateContainer = Acts::VectorMultiTrajectory
using RecoTrackStateContainerProxy = RecoTrackStateContainer::TrackStateProxy
using RecoConstTrackStateContainerProxy = RecoTrackStateContainer::ConstTrackStateProxy
using Stepper = Acts::SympyStepper
 Adapted from Acts Examples/Algorithms/TrackFinding/src/TrackFindingAlgorithmFunction.cpp.
using Navigator = Acts::Navigator
using Propagator = Acts::Propagator<Stepper, Navigator>
using CKF = Acts::CombinatorialKalmanFilter<Propagator, RecoTrackContainer>
using Extrapolator = Propagator

Enumerations

enum class  SourceLinkType { TrkMeasurement , TrkPrepRawData , xAODUnCalibMeas , nTypes }
 Enumeration to distinguish between the ATLAS EDM -> Acts::SourceLink variants. More...
enum class  HitCategory : std::uint8_t { DeadSensor , Hole , N }

Functions

std::ostream & operator<< (std::ostream &ostr, const SourceLinkType sl)
template<typename T>
const std::any constDecorationGetter (const SG::IConstAuxStore *container, ActsTrk::IndexType idx, SG::auxid_t decorationId)
template<typename T>
const std::any decorationGetter (const SG::IAuxStore *container, ActsTrk::IndexType idx, SG::auxid_t decorationId)
template<typename T>
std::any decorationSetter (SG::IAuxStore *container, ActsTrk::IndexType idx, SG::auxid_t decorationId)
template<typename T>
void decorationCopier (SG::IAuxStore *dst, ActsTrk::IndexType dst_idx, SG::auxid_t decorationId, const std::any &src_ptr)
template<typename T>
static Decoration decoration (std::string_view n, GetterType g, CopierType c, SetterType s=static_cast< SetterType >(nullptr))
std::vector< DecorationrestoreDecorations (const SG::IConstAuxStore *container, const std::set< std::string > &staticVariables)
std::array< unsigned int, 4 > expectedLayerPattern (const EventContext &ctx, const ActsTrk::IExtrapolationTool &extrapolator, const Acts::BoundTrackParameters &perigee_parameters, double pathLimit)
 Extrapolate from the perigee outwards and gather information which detector layers should have hits.
std::array< unsigned int, 4 > expectedLayerPattern (std::span< const ActsDetectorElement * > detectorElements)
 From a pre-computed set of detector elements, determine what the hit pattern is and which detector layers should have hits.
void addToExpectedLayerPattern (std::array< unsigned int, 4 > &pattern, const ActsDetectorElement &detElement)
template<typename T>
bool build (const std::type_info *typeInfo, const std::string &name, std::vector< Decoration > &decorations)
double computeDtDs (const Acts::ParticleHypothesis &hypothesis, double qop)
 Helper function to compute dt/ds Helper function to compute the derivative of the time as function of the path length.
Acts::FreeToPathMatrix computeFreeToPathDerivatives (const Acts::Vector3 &direction, double qop, const Acts::Vector3 &bfield, const Acts::ParticleHypothesis &particle_hypothesis)
 Compute the path length derivatives for the free/bound to curvilinear paramter transform.
std::optional< Acts::BoundMatrix > convertActsBoundCovToCurvilinearParam (const Acts::GeometryContext &tgContext, const Acts::BoundTrackParameters &param, const Acts::Vector3 &magnFieldVect, const Acts::ParticleHypothesis &particle_hypothesis)
 Convert the covariance of the given Acts track parameters into curvilinear parameterisation.
void gatherTrackSummaryData (const typename ActsTrk::TrackContainer::ConstTrackProxy &track, const std::array< unsigned short, Acts::toUnderlying(xAOD::UncalibMeasType::nTypes)> &measurement_to_summary_type, SumOfValues &chi2_stat_out, HitSummaryData &hit_info_out, std::vector< ActsTrk::TrackStateBackend::ConstTrackStateProxy::IndexType > &param_state_idx_out, std::array< std::array< uint8_t, Acts::toUnderlying(HitCategory::N)>, Acts::toUnderlying(xAOD::UncalibMeasType::nTypes)> &special_hit_counts_out)
 Helper to gather track summary information from the track states of the specified track.
std::tuple< std::vector< int >, std::vector< std::vector< int > >, std::vector< std::vector< float > > > getSDOInformation (const std::vector< Identifier > &rdoList, const InDetSimDataCollection &sdoCollection)
std::tuple< std::vector< float >, std::vector< float >, std::vector< int >, std::vector< int >, std::vector< float >, std::vector< float >, std::vector< float >, std::vector< float >, std::vector< float >, std::vector< float > > getSiHitInformation (const InDetDD::SiDetectorElement &element, const std::vector< SiHit > &matchingHits)
std::unique_ptr< ActsTrk::IMeasurementSelectorgetMeasurementSelector (const EventContext &ctx, const ActsTrk::IPixelOnBoundStateCalibratorTool *pixelOnTrackCalibratorTool, const ActsTrk::IStripOnBoundStateCalibratorTool *stripOnTrackCalibratorTool, const ActsTrk::IHGTDOnBoundStateCalibratorTool *hgtdOnTrackCalibratorTool, const ActsTrk::detail::MeasurementRangeList &measurementRanges, const std::vector< float > &etaBinsf, const std::vector< std::pair< float, float > > &chi2CutOffOutlier, const std::vector< size_t > &numMeasurementsCutOff, double edge_hole_border_width)

Detailed Description

Athena definition of the Eigen plugin.

Typedef Documentation

◆ CKF

using ActsTrk::detail::CKF = Acts::CombinatorialKalmanFilter<Propagator, RecoTrackContainer>

◆ CopierType

Initial value:
std::function<void(SG::IAuxStore*, ActsTrk::IndexType, SG::auxid_t, const std::any&)>
Interface for non-const operations on an auxiliary store.
Definition IAuxStore.h:51
std::uint32_t IndexType
Definition Decoration.h:16
size_t auxid_t
Identifier for a particular aux data item.
Definition AuxTypes.h:27

Definition at line 22 of file Decoration.h.

◆ Extrapolator

◆ GetterType

Initial value:
std::function<const std::any(
const SG::IConstAuxStore*, ActsTrk::IndexType, SG::auxid_t)>

Definition at line 20 of file Decoration.h.

◆ MeasurementRangeList

◆ MeasurementRangeListFlat

◆ Navigator

◆ Propagator

◆ RecoConstTrackStateContainerProxy

using ActsTrk::detail::RecoConstTrackStateContainerProxy = RecoTrackStateContainer::ConstTrackStateProxy

◆ RecoTrackContainer

Initial value:
Acts::TrackContainer<Acts::VectorTrackContainer,
Acts::VectorMultiTrajectory>

Definition at line 21 of file Tracking/Acts/ActsTrackReconstruction/src/detail/Definitions.h.

◆ RecoTrackContainerProxy

using ActsTrk::detail::RecoTrackContainerProxy = RecoTrackContainer::TrackProxy

◆ RecoTrackStateContainer

◆ RecoTrackStateContainerProxy

using ActsTrk::detail::RecoTrackStateContainerProxy = RecoTrackStateContainer::TrackStateProxy

◆ SetterType

Initial value:
std::function<std::any(SG::IAuxStore*, ActsTrk::IndexType, SG::auxid_t)>

Definition at line 18 of file Decoration.h.

◆ Stepper

using ActsTrk::detail::Stepper = Acts::SympyStepper

Adapted from Acts Examples/Algorithms/TrackFinding/src/TrackFindingAlgorithmFunction.cpp.

Definition at line 30 of file Tracking/Acts/ActsTrackReconstruction/src/detail/Definitions.h.

◆ UncalibSourceLinkAccessor

Enumeration Type Documentation

◆ HitCategory

enum class ActsTrk::detail::HitCategory : std::uint8_t
strong
Enumerator
DeadSensor 
Hole 

Definition at line 21 of file HitSummaryDataUtils.h.

◆ SourceLinkType

Enumeration to distinguish between the ATLAS EDM -> Acts::SourceLink variants.

Enumerator
TrkMeasurement 
TrkPrepRawData 

Calibrated Trk::MeasurementBase objects.

xAODUnCalibMeas 

UnCalibrated Trk::PrepRawData objects.

nTypes 

Uncalbirated xAOD::UnCalibratedMeasurement objects.

Number of source link types

Definition at line 11 of file SourceLinkType.h.

11 {
15 nTypes
16 };
@ xAODUnCalibMeas
UnCalibrated Trk::PrepRawData objects.
@ TrkPrepRawData
Calibrated Trk::MeasurementBase objects.

Function Documentation

◆ addToExpectedLayerPattern()

void ActsTrk::detail::addToExpectedLayerPattern ( std::array< unsigned int, 4 > & pattern,
const ActsDetectorElement & detElement )

Definition at line 42 of file ExpectedHitUtils.cxx.

42 {
44 detEl = dynamic_cast<const InDetDD::SiDetectorElement *>(detElement.upstreamDetectorElement());
45 if (detEl) {
46 if (detEl->isPixel()) {
48 unsigned int pattern_idx = type==InDetDD::PixelBarrel ? 0 : 1;
49 const PixelID* pixel_id = static_cast<const PixelID *>(detEl->getIdHelper());
50 pattern[pattern_idx] |= (1<< pixel_id->layer_disk(detEl->identify()) );
51 }
52 else if (detEl->isSCT()) {
53 // @TODO SCT/strip layer number should be shifted by total number of pixel layers ...
54 const SCT_ID* sct_id = static_cast<const SCT_ID *>(detEl->getIdHelper());
55 unsigned int pattern_idx = detEl->isBarrel() ? 2 : 3;
56 pattern[pattern_idx] |= (1<< sct_id->layer_disk(detEl->identify()) );
57 }
58 }
59 }
const GeoVDetectorElement * upstreamDetectorElement() const
Returns the underllying GeoModel detectorelement that this one is based on.
virtual DetectorType type() const
Type of element.
Class to hold geometrical description of a silicon detector element.
virtual const SiDetectorDesign & design() const override final
access to the local description (inline):
virtual Identifier identify() const override final
identifier of this detector element (inline)
const AtlasDetectorID * getIdHelper() const
Returns the id helper (inline).
This is an Identifier helper class for the Pixel subdetector.
Definition PixelID.h:69
int layer_disk(const Identifier &id) const
Definition PixelID.h:602
This is an Identifier helper class for the SCT subdetector.
Definition SCT_ID.h:68
int layer_disk(const Identifier &id) const
Definition SCT_ID.h:687

◆ build()

template<typename T>
bool ActsTrk::detail::build ( const std::type_info * typeInfo,
const std::string & name,
std::vector< Decoration > & decorations )

Definition at line 26 of file Decoration.cxx.

26 {
27 if (*typeInfo == typeid(T)) {
28 decorations.emplace_back(
31 return true;
32 }
33 return false;
34}
void decorationCopier(SG::IAuxStore *dst, ActsTrk::IndexType dst_idx, SG::auxid_t decorationId, const std::any &src_ptr)
Definition Decoration.h:78
const std::any constDecorationGetter(const SG::IConstAuxStore *container, ActsTrk::IndexType idx, SG::auxid_t decorationId)
Definition Decoration.h:51
static Decoration decoration(std::string_view n, GetterType g, CopierType c, SetterType s=static_cast< SetterType >(nullptr))
Definition Decoration.h:85

◆ computeDtDs()

double ActsTrk::detail::computeDtDs ( const Acts::ParticleHypothesis & hypothesis,
double qop )
inline

Helper function to compute dt/ds Helper function to compute the derivative of the time as function of the path length.

Definition at line 16 of file CurvilinearCovarianceHelper.h.

16 {
17 return std::hypot(1.,hypothesis.mass() / hypothesis.extractMomentum(qop));
18 }

◆ computeFreeToPathDerivatives()

Acts::FreeToPathMatrix ActsTrk::detail::computeFreeToPathDerivatives ( const Acts::Vector3 & direction,
double qop,
const Acts::Vector3 & bfield,
const Acts::ParticleHypothesis & particle_hypothesis )
inline

Compute the path length derivatives for the free/bound to curvilinear paramter transform.

Parameters
directionthe direction of trajectory at the location in question
qopq/p of the particle at the location in question in Acts units
bfieldthe magnetic field at the location in question in Acts units
particle_hypothesisthe particle hypothesis e.g. Acts::ParticleHypothesis::pion()
Returns
path length derivatives ( dr(...)/ds, dt/ds, dr(...)/ds2, d qop/ds [== 0] )

Definition at line 27 of file CurvilinearCovarianceHelper.h.

31 {
32 Acts::FreeToPathMatrix path_length_deriv;
33 static_assert(path_length_deriv.cols() == 8); // ensure that all elements are initialized
34 path_length_deriv.segment<3>(Acts::eFreePos0) = direction;
35 path_length_deriv(0,Acts::eFreeTime) = computeDtDs(particle_hypothesis,qop);
36 path_length_deriv.segment<3>(Acts::eFreeDir0) = (qop * direction.cross(bfield)).transpose();
37 path_length_deriv(0,Acts::eFreeQOverP) = 0.;
38 return path_length_deriv;
39 }
double computeDtDs(const Acts::ParticleHypothesis &hypothesis, double qop)
Helper function to compute dt/ds Helper function to compute the derivative of the time as function of...

◆ constDecorationGetter()

template<typename T>
const std::any ActsTrk::detail::constDecorationGetter ( const SG::IConstAuxStore * container,
ActsTrk::IndexType idx,
SG::auxid_t decorationId )

Definition at line 51 of file Decoration.h.

53 {
54 const void* data = container->getData(decorationId);
55 return &(static_cast<const T*>(data)[idx]);
56}
char data[hepevt_bytes_allocation_ATLAS]
Definition HepEvt.cxx:11
AuxDataTraits< T >::reference_type getData(SG::auxid_t auxid, size_t ndx)
Return reference to an aux data item.

◆ convertActsBoundCovToCurvilinearParam()

std::optional< Acts::BoundMatrix > ActsTrk::detail::convertActsBoundCovToCurvilinearParam ( const Acts::GeometryContext & tgContext,
const Acts::BoundTrackParameters & param,
const Acts::Vector3 & magnFieldVect,
const Acts::ParticleHypothesis & particle_hypothesis )
inline

Convert the covariance of the given Acts track parameters into curvilinear parameterisation.

Parameters
tgContextthe current geometry context
paramthe Acts track parameters
magnFieldVectthe vector of the magnetic field at the position of the track parameters in Acts units
particle_hypothesisthe particle hypothesis e.g. Acts::ParticleHypothesis::pion() Usage:
  
     using namespace Acts::UnitLiterals;
     MagField::AtlasFieldCache fieldCache;
     ...
     Amg::Vector3D magnFieldVect;
     fieldCache.getField(param.position(tgContext).data(), magnFieldVect.data());
     magnFieldVect *= 1000_T;
     auto cov = convertActsBoundCovToCurvilinearParam(tgContext, param, magnFieldVect);
     if (cov.has_value()) { ... }
   

Definition at line 61 of file CurvilinearCovarianceHelper.h.

65 {
66 if (param.covariance().has_value()) {
67 Acts::FreeVector freeParams = Acts::transformBoundToFreeParameters(
68 param.referenceSurface(), tgContext, param.parameters());
69 Acts::Vector3 position = freeParams.segment<3>(Acts::eFreePos0);
70 Acts::Vector3 direction = freeParams.segment<3>(Acts::eFreeDir0);
71
72 Acts::BoundToFreeMatrix boundToFreeJacobian = param.referenceSurface().boundToFreeJacobian(tgContext, position, direction);
73 Acts::FreeMatrix freeTransportJacobian = Acts::FreeMatrix::Identity();
74 Acts::FreeToBoundMatrix freeToBoundJacobian;
75 Acts::FreeVector freeToPathDerivatives = computeFreeToPathDerivatives(direction,
76 param.parameters()[Acts::eBoundQOverP],
77 magnFieldVect,
78 particle_hypothesis);
79 Acts::BoundMatrix fullTransportJacobian;
80 Acts::detail::boundToCurvilinearTransportJacobian(direction,
81 boundToFreeJacobian,
82 freeTransportJacobian,
83 freeToBoundJacobian,
84 freeToPathDerivatives,
85 fullTransportJacobian);
86
87 return fullTransportJacobian * param.covariance().value() * fullTransportJacobian.transpose();
88 }
89 else {
90 return {};
91 }
92 }
Acts::FreeToPathMatrix computeFreeToPathDerivatives(const Acts::Vector3 &direction, double qop, const Acts::Vector3 &bfield, const Acts::ParticleHypothesis &particle_hypothesis)
Compute the path length derivatives for the free/bound to curvilinear paramter transform.

◆ decoration()

template<typename T>
Decoration ActsTrk::detail::decoration ( std::string_view n,
GetterType g,
CopierType c,
SetterType s = static_cast<SetterType>(nullptr) )
static

Definition at line 85 of file Decoration.h.

86 {
87 Decoration dec;
88 dec.name = n;
89 dec.hash = Acts::hashStringDynamic(n);
91 if (dec.auxid == SG::null_auxid)
92 throw std::runtime_error("ActsTrk::Decoration Aux ID for " + dec.name +
93 " could not be found");
94 dec.getter = std::move(g);
95 dec.copier = std::move(c);
96 dec.setter = std::move(s);
97 return dec;
98}
SG::auxid_t getAuxID(const std::string &name, const std::string &clsname="", const Flags flags=Flags::None, const SG::auxid_t linkedVariable=SG::null_auxid)
Look up a name -> auxid_t mapping.
static AuxTypeRegistry & instance()
Return the singleton registry instance.
static const auxid_t null_auxid
To signal no aux data item.
Definition AuxTypes.h:30

◆ decorationCopier()

template<typename T>
void ActsTrk::detail::decorationCopier ( SG::IAuxStore * dst,
ActsTrk::IndexType dst_idx,
SG::auxid_t decorationId,
const std::any & src_ptr )

Definition at line 78 of file Decoration.h.

79 {
80 *std::any_cast<T*>(decorationSetter<T>(dst, dst_idx, decorationId)) =
81 *std::any_cast<const T*>(src_ptr);
82}
std::any decorationSetter(SG::IAuxStore *container, ActsTrk::IndexType idx, SG::auxid_t decorationId)
Definition Decoration.h:69

◆ decorationGetter()

template<typename T>
const std::any ActsTrk::detail::decorationGetter ( const SG::IAuxStore * container,
ActsTrk::IndexType idx,
SG::auxid_t decorationId )

Definition at line 59 of file Decoration.h.

61 {
62 const void* data = container->getData(decorationId);
63 return &(static_cast<T*>(data)[idx]);
64}

◆ decorationSetter()

template<typename T>
std::any ActsTrk::detail::decorationSetter ( SG::IAuxStore * container,
ActsTrk::IndexType idx,
SG::auxid_t decorationId )

Definition at line 69 of file Decoration.h.

70 {
71 assert (idx < container->size());
72 // The size requested for the decoration must match the size of the container.
73 void* data = container->getData(decorationId, container->size(), container->size());
74 return &(static_cast<T*>(data)[idx]);
75}
size_t size() const
Number of registered mappings.

◆ expectedLayerPattern() [1/2]

std::array< unsigned int, 4 > ActsTrk::detail::expectedLayerPattern ( const EventContext & ctx,
const ActsTrk::IExtrapolationTool & extrapolator,
const Acts::BoundTrackParameters & perigee_parameters,
double pathLimit )

Extrapolate from the perigee outwards and gather information which detector layers should have hits.

Parameters
ctxthe current athena EvetContext @paran extrapolator referece to the Acts extrapolation tool
perigee_parametersthe Acts defining track parameters (parameters at the perigee).
pathLimitthe maximum path length to extrapolate to.
Returns
array of layer pattern words: two pairs for pixel and strips containing the barrel and end caps bit pattern with one bit per detector layer. Will extrapolate from the perigee to the given cylinder volume surface and gather the layers which are crossed and on which hits are expected.

Definition at line 14 of file ExpectedHitUtils.cxx.

17 {
18 std::array<unsigned int,4> expected_layer_pattern {0u,0u,0u,0u};
19 auto result = extrapolator.propagationSteps(ctx,
20 perigee_parameters,
21 Acts::Direction::Forward(),
22 pathLimit);
23 if (result.ok()) {
24 for (const Acts::detail::Step &step : result->first ) {
25 // @TODO boundary check ?, does layer number match layer numbering in athena ?
26 // @TODO filter out dead modules
27 if (step.geoID.sensitive()) {
28 if (step.surface && step.surface->surfacePlacement()) {
30 actsDetEl = dynamic_cast<const ActsDetectorElement *>(step.surface->surfacePlacement());
31 if (actsDetEl) {
32 addToExpectedLayerPattern(expected_layer_pattern, *actsDetEl);
33 }
34 }
35 }
36 }
37 }
38
39 return expected_layer_pattern;
40 }
virtual Acts::Result< PropagationOutput > propagationSteps(const EventContext &ctx, const Acts::BoundTrackParameters &startParameters, Acts::Direction navDir=Acts::Direction::Forward(), double pathLimit=std::numeric_limits< double >::max()) const =0
Extrapolate the track parameters until the end of the world and record the performed steps & the allo...
void addToExpectedLayerPattern(std::array< unsigned int, 4 > &pattern, const ActsDetectorElement &detElement)

◆ expectedLayerPattern() [2/2]

std::array< unsigned int, 4 > ActsTrk::detail::expectedLayerPattern ( std::span< const ActsDetectorElement * > detectorElements)

From a pre-computed set of detector elements, determine what the hit pattern is and which detector layers should have hits.

Parameters
detectorElementsA set of detector elements to consider

◆ gatherTrackSummaryData()

void ActsTrk::detail::gatherTrackSummaryData ( const typename ActsTrk::TrackContainer::ConstTrackProxy & track,
const std::array< unsigned short, Acts::toUnderlying(xAOD::UncalibMeasType::nTypes)> & measurement_to_summary_type,
SumOfValues & chi2_stat_out,
HitSummaryData & hit_info_out,
std::vector< ActsTrk::TrackStateBackend::ConstTrackStateProxy::IndexType > & param_state_idx_out,
std::array< std::array< uint8_t, Acts::toUnderlying(HitCategory::N)>, Acts::toUnderlying(xAOD::UncalibMeasType::nTypes)> & special_hit_counts_out )

Helper to gather track summary information from the track states of the specified track.

Parameters
tracka track of the given acts track container for which the summary information is to be gathered
measurement_to_summary_typea LUT to map measurement types to the corresponding summary type for the measurement counts
chi2_stat_outoutput of the per track state chi-squared sums and squared sums to compute the per state chi2 variance.
hit_info_outoutput of the gathered measurement statistics per detector region, layer, ... .
param_state_idx_outoutput vector to be filled with the state index of all track states which are not holes.
special_hit_counts_outarrays to count holes (and @TODO dead sensors) per measurement type.

Definition at line 17 of file HitSummaryDataUtils.cxx.

25 {
26 chi2_stat_out.reset();
27
28 hit_info_out.reset();
29 param_state_idx_out.clear();
30
31 const auto lastMeasurementIndex = track.tipIndex();
32 track.container().trackStateContainer().visitBackwards(
33 lastMeasurementIndex,
34 [&measurement_to_summary_type,
35 &chi2_stat_out,
36 &hit_info_out,
37 &param_state_idx_out,
38 &special_hit_counts_out
39 ](const typename ActsTrk::TrackStateBackend::ConstTrackStateProxy &state) -> void
40 {
41
42 auto flag = state.typeFlags();
43 if (!state.hasReferenceSurface()) {
44 return;
45 }
47 const auto* detEl = dynamic_cast<const IDetectorElementBase*>(state.referenceSurface().surfacePlacement());
48 if (detEl != nullptr) {
49 det_type = toMeasType(detEl->detectorType());
50 }
51
52 if (flag.isHole()) {
53 const Amg::Vector2D localPos{state.parameters()[Acts::eBoundLoc0],
54 state.parameters()[Acts::eBoundLoc1]};
55 if (state.referenceSurface().insideBounds(localPos)) {
56 // @TODO check whether detector element is dead..
57 ++special_hit_counts_out.at(Acts::toUnderlying(det_type)).at(Acts::toUnderlying(HitCategory::Hole));
58 }
59 return;
60
61 }
62 // do not consider material states
63 if (!flag.hasMeasurement() || !state.hasUncalibratedSourceLink()) {
64 return;
65 }
66 param_state_idx_out.push_back(state.index());
67
68 // @TODO dead elements
69 auto uncalibMeas = detail::xAODUncalibMeasCalibrator::unpack(state.getUncalibratedSourceLink());
70 assert( uncalibMeas != nullptr );
71 assert( det_type == uncalibMeas->type());
72
73 if (measurement_to_summary_type.at(Acts::toUnderlying(uncalibMeas->type())) <
75 HitSummaryData::EHitSelection hit_selection = (flag.isOutlier()
78 if (flag.isSharedHit()) {
79 hit_selection = HitSummaryData::EHitSelection(hit_selection | HitSummaryData::SharedHit);
80 }
81 const InDetDD::SiDetectorElement* siDet{nullptr};
82 if (const auto* idDetEl = dynamic_cast<const ActsDetectorElement*>(detEl); idDetEl != nullptr) {
83 siDet = dynamic_cast<const InDetDD::SiDetectorElement*>(idDetEl->upstreamDetectorElement());
84 }
85 hit_info_out.addHit(siDet, hit_selection);
86
87
88 if (state.calibratedSize()>0 && !flag.isOutlier()) {
89 // from Tracking/TrkTools/TrkTrackSummaryTool/src/TrackSummaryTool.cxx
90 // processTrackState
91 double chi2add = std::min(state.chi2(),1e5f) / state.calibratedSize();
92 chi2_stat_out.add(chi2add );
93 }
94 }
95
96 });
97 hit_info_out.computeSummaries();
98 }
base class interface providing the bare minimal interface extension.
void reset()
reset all summary counters to zero.
void computeSummaries()
Compute the varius summaries.
bool addHit(const InDetDD::SiDetectorElement *detEl, EHitSelection hit_selection)
update summaries to take the given hit into account.
static const xAOD::UncalibratedMeasurement * unpack(const Acts::SourceLink &sl)
Helper method to unpack an Acts source link to an uncalibrated measurement.
xAOD::UncalibMeasType toMeasType(const DetectorType dType)
Conversts the detector type to an uncalibrated measurement type.
Eigen::Matrix< double, 2, 1 > Vector2D
bool flag
Definition master.py:29
UncalibMeasType
Define the type of the uncalibrated measurement.
@ numberOfTrackSummaryTypes

◆ getMeasurementSelector()

std::unique_ptr< ActsTrk::IMeasurementSelector > ActsTrk::detail::getMeasurementSelector ( const EventContext & ctx,
const ActsTrk::IPixelOnBoundStateCalibratorTool * pixelOnTrackCalibratorTool,
const ActsTrk::IStripOnBoundStateCalibratorTool * stripOnTrackCalibratorTool,
const ActsTrk::IHGTDOnBoundStateCalibratorTool * hgtdOnTrackCalibratorTool,
const ActsTrk::detail::MeasurementRangeList & measurementRanges,
const std::vector< float > & etaBinsf,
const std::vector< std::pair< float, float > > & chi2CutOffOutlier,
const std::vector< size_t > & numMeasurementsCutOff,
double edge_hole_border_width )

Definition at line 406 of file AtlasMeasurementSelector.cxx.

414 {
415
416 // set calibrators per measurement container type (order does not matter);
417 ActsTrk::MeasurementCalibrator atl_measurement_calibrator(ctx,
418 pixelOnTrackCalibratorTool,
419 stripOnTrackCalibratorTool,
420 hgtdOnTrackCalibratorTool);
421 using AtlMeasurementSelectorCuts = AtlasMeasurementSelectorCuts;
422
423 using AtlMeasurementSelector = AtlasActsMeasurmentSelector<RecoTrackContainer>;
424 using AtlMeasurementSelectorConfig = AtlMeasurementSelector::TheAtlasMeasurementSelector::Config;
425
426 std::unique_ptr<ActsTrk::IMeasurementSelector>
427 selector(new AtlMeasurementSelector(
428 std::move(atl_measurement_calibrator),
429 measurementRanges,
430 AtlMeasurementSelectorConfig{
431 {Acts::GeometryIdentifier(),
432 AtlMeasurementSelectorCuts{ etaBinsf,
433 chi2CutOffOutlier,
434 numMeasurementsCutOff,
435 edge_hole_border_width==0.
436 ? std::optional<Acts::BoundaryTolerance>{}
437 : std::optional{Acts::BoundaryTolerance::AbsoluteEuclidean(-std::abs(edge_hole_border_width))}
438 }
439 }}));
440 return selector;
441}

◆ getSDOInformation()

std::tuple< std::vector< int >, std::vector< std::vector< int > >, std::vector< std::vector< float > > > ActsTrk::detail::getSDOInformation ( const std::vector< Identifier > & rdoList,
const InDetSimDataCollection & sdoCollection )

Definition at line 13 of file Tracking/Acts/ActsObjectDecoration/src/detail/Utilities.cxx.

15 {
16 std::vector<int> sdo_word {};
17 std::vector< std::vector< int > > sdo_depositsUniqueID {};
18 std::vector< std::vector< float > > sdo_depositsEnergy {};
19
20 for (const Identifier hitIdentifier : rdoList) {
21 auto pos = sdoCollection.find(hitIdentifier);
22 if( pos == sdoCollection.end() ) continue;
23
24 sdo_word.push_back( pos->second.word() ) ;
25
26 std::vector<int> sdoDepUID(pos->second.getdeposits().size(), HepMC::INVALID_PARTICLE_ID);
27 std::vector<float> sdoDepEnergy(pos->second.getdeposits().size());
28
29 unsigned int nDepos {0};
30 for (const auto& deposit: pos->second.getdeposits()) {
31 if (deposit.first) sdoDepUID[nDepos] = HepMC::uniqueID(deposit.first);
32 sdoDepEnergy[nDepos] = deposit.second;
33 ++nDepos;
34 }
35
36 sdo_depositsUniqueID.push_back( std::move(sdoDepUID) );
37 sdo_depositsEnergy.push_back( std::move(sdoDepEnergy) );
38 }
39
40 return std::make_tuple(std::move(sdo_word),
41 std::move(sdo_depositsUniqueID),
42 std::move(sdo_depositsEnergy));
43 }
constexpr int INVALID_PARTICLE_ID
int uniqueID(const T &p)

◆ getSiHitInformation()

std::tuple< std::vector< float >, std::vector< float >, std::vector< int >, std::vector< int >, std::vector< float >, std::vector< float >, std::vector< float >, std::vector< float >, std::vector< float >, std::vector< float > > ActsTrk::detail::getSiHitInformation ( const InDetDD::SiDetectorElement & element,
const std::vector< SiHit > & matchingHits )

Definition at line 57 of file Tracking/Acts/ActsObjectDecoration/src/detail/Utilities.cxx.

59 {
60 int numHits = matchingHits.size();
61
62 std::vector<float> sihit_energyDeposit(numHits, 0);
63 std::vector<float> sihit_meanTime(numHits, 0);
64 std::vector<int> sihit_uniqueID(numHits, 0);
65 std::vector<int> sihit_pdgid(numHits, 0);
66
67 std::vector<float> sihit_startPosX(numHits, 0);
68 std::vector<float> sihit_startPosY(numHits, 0);
69 std::vector<float> sihit_startPosZ(numHits, 0);
70
71 std::vector<float> sihit_endPosX(numHits, 0);
72 std::vector<float> sihit_endPosY(numHits, 0);
73 std::vector<float> sihit_endPosZ(numHits, 0);
74
75 int hitNumber {0};
76 for ( const SiHit& sihit : matchingHits ) {
77 sihit_energyDeposit[hitNumber] = sihit.energyLoss() ;
78 sihit_meanTime[hitNumber] = sihit.meanTime() ;
79
80 const HepMcParticleLink& HMPL = sihit.particleLink();
81 sihit_uniqueID[hitNumber] = HepMC::uniqueID(HMPL);
82 if( HMPL.isValid() ){
83 sihit_pdgid[hitNumber] = HMPL->pdg_id();
84 }
85
86 // Convert Simulation frame into reco frame
87 const HepGeom::Point3D<double>& startPos=sihit.localStartPosition();
88
89 Amg::Vector2D pos = element.hitLocalToLocal( startPos.z(), startPos.y() );
90 sihit_startPosX[hitNumber] = pos[0];
91 sihit_startPosY[hitNumber] = pos[1];
92 sihit_startPosZ[hitNumber] = startPos.x();
93
94 const HepGeom::Point3D<double>& endPos=sihit.localEndPosition();
95 pos = element.hitLocalToLocal( endPos.z(), endPos.y() );
96 sihit_endPosX[hitNumber] = pos[0];
97 sihit_endPosY[hitNumber] = pos[1];
98 sihit_endPosZ[hitNumber] = endPos.x();
99 ++hitNumber;
100 }
101
102 return std::make_tuple(std::move(sihit_energyDeposit), std::move(sihit_meanTime), std::move(sihit_uniqueID), std::move(sihit_pdgid),
103 std::move(sihit_startPosX), std::move(sihit_startPosY), std::move(sihit_startPosZ),
104 std::move(sihit_endPosX), std::move(sihit_endPosY), std::move(sihit_endPosZ));
105 }
Amg::Vector2D hitLocalToLocal(double xEta, double xPhi) const
Simulation/Hit local frame to reconstruction local frame.
Definition SiHit.h:19

◆ operator<<()

std::ostream & ActsTrk::detail::operator<< ( std::ostream & ostr,
const SourceLinkType sl )
inline

Definition at line 17 of file SourceLinkType.h.

17 {
18 switch (sl) {
19 using enum SourceLinkType;
20 case TrkMeasurement:
21 ostr<<"TrkMeasurement";
22 break;
23 case TrkPrepRawData:
24 ostr<<"TrkPrepRawData";
25 break;
26 case xAODUnCalibMeas:
27 ostr<<"xAODUnCalibMeas";
28 break;
29 case nTypes:
30 ostr<<"nTypes";
31 break;
32 }
33 return ostr;
34 }
SourceLinkType
Enumeration to distinguish between the ATLAS EDM -> Acts::SourceLink variants.
@ nTypes
Uncalbirated xAOD::UnCalibratedMeasurement objects.

◆ restoreDecorations()

std::vector< Decoration > ActsTrk::detail::restoreDecorations ( const SG::IConstAuxStore * container,
const std::set< std::string > & staticVariables )
  • container - source container to look for decorations
  • staticVariables - set of names of predefined variables for this container

Definition at line 37 of file Decoration.cxx.

39 {
40 std::vector<Decoration> decorations;
41 for (auto id : container->getAuxIDs()) {
42 const std::string name = SG::AuxTypeRegistry::instance().getName(id);
43 const std::type_info* typeInfo =
45 if (staticVariables.count(name) == 1) {
46 continue;
47 }
48
49 // try making decoration accessor of matching type
50 // there is a fixed set of supported types (as there is a fixed set
51 // available in MutableMTJ) setters are not needed so replaced by a
52 if ( build<float>(typeInfo, name, decorations) ||
53 build<double>(typeInfo, name, decorations) ||
54 build<short>(typeInfo, name, decorations) ||
55 build<int>(typeInfo, name, decorations) ||
56 build<uint8_t>(typeInfo, name, decorations) ||
57 build<uint16_t>(typeInfo, name, decorations) ||
58 build<uint32_t>(typeInfo, name, decorations) ||
59 build<uint64_t>(typeInfo, name, decorations) ||
60 build<int8_t>(typeInfo, name, decorations) ||
61 build<int16_t>(typeInfo, name, decorations) ||
62 build<int32_t>(typeInfo, name, decorations) ||
63 build<int64_t>(typeInfo, name, decorations)
64 ) {
65 continue;
66 }
67 throw std::runtime_error("Can't restore decoration of " + name +
68 " because it is of an unsupported type");
69 }
70 return decorations;
71}
const std::type_info * getType(SG::auxid_t auxid) const
Return the type of an aux data item.
std::string getName(SG::auxid_t auxid) const
Return the name of an aux data item.
const SG::auxid_set_t & getAuxIDs() const
Return a set of identifiers for existing data items in store associated with this object.
bool build(const std::type_info *typeInfo, const std::string &name, std::vector< Decoration > &decorations)