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

The AlignStoreProviderAlg loads the rigid alignment corrections and pipes them through the readout geometry to cache the final transformations of the sensor surfaces associated to one particular detector technology (Pixel, Sct, etc.). More...

Namespaces

namespace  Cache
namespace  detail
 Athena definition of the Eigen plugin.
namespace  details
namespace  ParticleHypothesis
namespace  ScoreBasedSolverCutsImpl

Classes

class  ActsInspectTruthContentAlg
class  ActsMuonTrackingGeometryTest
 Extrapolation test for the ActsMuonTrackingGeometry for gen3. More...
class  ActsToTrkConverterTool
class  ActsToTrkConvertorAlg
class  ActsToXAODTrackConverterAlg
class  ActsTrackStateOnSurfaceDecoratorAlg
class  ActsVolumeIdToDetectorElementCollectionMap
class  ActsVolumeIdToDetectorElementCollectionMappingAlg
class  AdaptiveMultiPriVtxFinderTool
class  AlignStoreProviderAlg
class  AmbiguityResolutionAlg
class  AuxiliaryMeasurementHandler
 Utility class to handle the creation of the Auxiliary measurement used in an Acts track fit This class declares the additionally written xAOD::AuxiliaryMeasurementContainers to the AvalancheScheduler. More...
class  CaloBasedRoICreatorTool
class  CaloBlueprintNodeBuilder
 Builds the Calo Blueprint Node. More...
class  ClusterizationAlg
class  ConstTrackContainerHandlesHelper
class  CoreStripSpacePointFormationTool
 Tool to produce strip space points using ACTS SP builder. More...
struct  DataLinkHolder
class  DataPreparationAlg
class  DetectorAlignCondAlg
class  DetectorAlignStore
struct  DetectorElementToActsGeometryIdMap
class  DummyRDOList
class  EstimatedTrackParamsAnalysisAlg
class  ExtrapolationTool
class  FullScanRoICreatorTool
class  GaussianSumFitterTool
class  GbtsSeedingTool
class  GeometryContext
class  GeometryContextAlg
class  GlobalChiSquareFitterTool
class  GridTripletSeedingAlg
class  GridTripletSeedingTool
struct  has_rdoList
struct  has_rdoList< Object, std::void_t< rdoListFunc_t< Object > > >
class  HgtdClusterAnalysisAlg
class  HgtdClusterDataPreparationAlg
class  HgtdClusteringTool
class  HgtdClusterizationAlg
class  HgtdClusterToTruthAssociationAlg
class  HgtdClusterValidationPlots
class  HgtdTimedClusteringTool
class  HGTDTrackExtensionAlg
class  HGTDTruthTrackDecorationAlg
class  HitCounterArray
class  HitCountsPerTrack
 Container for hit counts per track Contains hit counts per associated truth particle and the total hit counts As last element in the container. More...
class  IActsToTrkConverterTool
 Conversion tool interface to translate surfaces & track parameters between the Acts & Trk realm. More...
class  IBlueprintNodeBuilder
 Interface for the Blueprint node builder This interface is used to build a Blueprint node for the Acts tracking geometry. More...
class  IDetectorElement
 Base class interface for the actual readout elements. More...
class  IDetectorElementBase
 base class interface providing the bare minimal interface extension. More...
class  IExtrapolationTool
 Tool to extrapolate bound track parameters. More...
class  IFitterTool
 Generic interface class to fit xAOD::Uncalibrated measurements to (multi)-trajectories. More...
class  IHGTDClusteringTool
class  IMeasurementSelector
class  IndexingPolicy
class  IOnBoundStateCalibratorTool
class  IOnTrackCalibratorTool
class  IPixelClusteringTool
class  IPixelSpacePointFormationTool
 Base class for pixel space point formation tool. More...
class  IProtoTrackCreatorTool
class  IRoICreatorTool
class  ISeedingTool
class  IStripClusteringTool
class  IStripSpacePointFormationTool
class  IterativePriVtxFinderTool
class  ITkAlignMonResidualsAlg
class  ITkAnalogueClusteringTool
class  ItkBlueprintNodeBuilder
 Helper class to build the ItkBlueprint node It adds the system as a node to the Blueprint. More...
class  ITkStripCalibrationTool
class  ITrackingGeometrySvc
class  ITrackingGeometryTool
 Geometry helper tool extending the Tracking geometry service by the data dependency to fetch the geometry context from StoreGate. More...
class  ITrackParamsEstimationTool
class  KalmanFitterTool
struct  MeasurementCalibrator
struct  MeasurementParameterMap
class  MeasurementToTrackParticleDecorationAlg
class  MeasurementToTruthAssociationAlg
 Algorithm template to associate measurements of a certain type to a xAOD truth particles using a sim data collection where the sim data collection contains associates RDOs to truth particles and there energy/charge disposition. More...
class  MeasurementToTruthParticleAssociation
class  MultiTrajectory
 Read only version of MTJ The implementation is separate as the details are significantly different and in addition only const methods are ever needed. More...
class  MuonBlueprintNodeBuilder
 Helper class to build a Blueprint node of the muon system. More...
class  MutableMultiTrajectory
 Athena implementation of ACTS::MultiTrajectory (ReadWrite version) The data is stored in 4 external backends. More...
struct  MutablePersistentTrackContainer
class  MutableTrackContainerHandlesHelper
class  MutableTrackSummaryContainer
class  NoDeletePtr
class  OrthogonalSeedingTool
class  PersistentTrackContainer
class  PhysValTool
class  PixelCacheClusterizationAlg
class  PixelCacheSpacePointFormationAlg
class  PixelClusterAnalysisAlg
class  PixelClusterCacheDataPreparationAlg
class  PixelClusterDataPreparationAlg
class  PixelClusteringTool
class  PixelClusterizationAlg
class  PixelClusterSiHitDecoratorAlg
class  PixelClusterToTruthAssociationAlg
class  PixelClusterTruthDecoratorAlg
class  PixelClusterValidationPlots
class  PixelSpacePointFormationAlg
 This version of PixelSpacePointFormationAlg uses xAOD pixel clusters to find space points in the ITk pixeldetectors. More...
class  PixelSpacePointFormationAlgBase
class  PixelSpacePointFormationTool
 Tool to produce pixel space points. More...
class  PixelSpacePointValidationPlots
class  PrdAssociationAlg
class  PrepRawDataAssociation
struct  ProtoTrack
class  ProtoTrackCreationAndFitAlg
class  ProtoTrackReportingAlg
 Very lightweight algorithm to print out the results of the EF track finding. More...
class  RandomProtoTrackCreatorTool
class  ReFitterAlg
class  RegionsOfInterestCreatorAlg
class  ScoreBasedAmbiguityResolutionAlg
struct  Seed
class  SeedAnalysisAlg
struct  SeedContainer
class  SeedingAlg
class  SeedingAlgorithmAnalysisAlg
class  SeedingTool
class  SeedsToTrackParamsAlg
class  SeedToTrackAnalysisAlg
class  SeedToTrackCnvAlg
class  SiSpacePointsSeedMaker
class  SpacePointAnalysisAlg
class  SpacePointCacheDataPreparationAlg
class  SpacePointCollector
class  SpacePointDataPreparationAlg
struct  SpacePointIndexSubset
class  StripCacheClusterizationAlg
class  StripCacheSpacePointFormationAlg
class  StripClusterAnalysisAlg
class  StripClusterCacheDataPreparationAlg
class  StripClusterDataPreparationAlg
class  StripClusteringTool
class  StripClusterizationAlg
class  StripClusterSiHitDecoratorAlg
class  StripClusterToTruthAssociationAlg
class  StripClusterTruthDecoratorAlg
class  StripClusterValidationPlots
class  StripInformationHelper
struct  StripSP
class  StripSpacePointFormationAlg
class  StripSpacePointFormationAlgBase
 This version of StripSpacePointFormationAlgBase uses xAOD strip clusters to find space points in the ITk strip detectors. More...
class  StripSpacePointFormationTool
class  StripSpacePointValidationPlots
class  SurfaceCache
 : Helper class to connect the aligned transformations of each active sensor(layer) with the Acts::Surfaces. More...
class  TestRoICreatorTool
class  TrackAnalysisAlg
class  TrackContainer
class  TrackContainerReader
class  TrackExtensionAlg
class  TrackFindingAlg
class  TrackFindingBaseAlg
class  TrackFindingValidationAlg
class  TrackParamsEstimationTool
class  TrackParticleAnalysisAlg
class  TrackParticleTruthDecorationAlg
class  TrackStatePrinterTool
class  TrackSummaryContainer
class  TrackToTrackParticleCnvAlg
class  TrackToTruthAssociationAlg
class  TrackToTruthParticleAssociation
class  TrackTruthMatchingBaseAlg
class  TransformCache
class  TransformCacheDetEle
class  TrkToActsConvertorAlg
 Algorithm convert Trk::Track to ACTS multistate objects. More...
class  TruthGuidedProtoTrackCreatorTool
class  TruthParticleHitCountAlg

Typedefs

using staticNodePtr = std::shared_ptr<Acts::Experimental::StaticBlueprintNode>
using surfacePtr = std::shared_ptr<Acts::Surface>
using MuonChamberSet = MuonGMR4::MuonDetectorManager::MuonChamberSet
using MuonSectorSet = MuonGMR4::MuonDetectorManager::MuonSectorSet
using StIdx = Muon::MuonStationIndex::StIndex
using IndexType = std::uint32_t
using ParticleVector = boost::container::small_vector<const xAOD::TruthParticle *, NTruthParticlesPerMeasurement>
using StoredSurface = std::variant<const Acts::Surface*, std::shared_ptr<const Acts::Surface>>
using MutablePersistentTrackBackend = ActsTrk::MutableTrackSummaryContainer
using PersistentTrackBackend = ActsTrk::TrackSummaryContainer
using MutablePersistentTrackStateBackend = ActsTrk::MutableMultiTrajectory
using PersistentTrackStateBackend = ActsTrk::MultiTrajectory
using PersistentTrackContainerBase
typedef std::vector< ActsTrk::ProtoTrackProtoTrackCollection
using TrackBackend = Acts::ConstVectorTrackContainer
using MutableTrackBackend = Acts::VectorTrackContainer
using TrackStateBackend = Acts::ConstVectorMultiTrajectory
using MutableTrackStateBackend = Acts::VectorMultiTrajectory
using TrackContainerBase
using MutableTrackContainer
typedef DataVector< Acts::BoundTrackParameters > BoundTrackParametersContainer
using ConstParameters = Acts::TrackStateTraits<3>::Parameters
using ConstCovariance = Acts::TrackStateTraits<3>::Covariance
using Parameters = Acts::TrackStateTraits<3, false>::Parameters
using Covariance = Acts::TrackStateTraits<3, false>::Covariance
using TruthParticleHitCounts = std::unordered_map<const xAOD::TruthParticle *,HitCounterArray>
using ATLASSourceLink = const Trk::MeasurementBase *
using ATLASUncalibSourceLink = const xAOD::UncalibratedMeasurement *
using DetectorElementKey = unsigned int
using TicketCounterArr = DetectorAlignStore::TrackingAlignStore::TicketCounterArr
using ReturnedTicketArr = DetectorAlignStore::TrackingAlignStore::ReturnedTicketArr
using ReturnedHintArr = DetectorAlignStore::TrackingAlignStore::ReturnedHintArr
using SurfaceCacheSet = std::set<std::unique_ptr<SurfaceCache>, std::less<>>
using AtlUncalibSourceLinkAccessor = detail::UncalibSourceLinkAccessor
using DefaultTrackStateCreator = Acts::TrackStateCreator<ActsTrk::detail::UncalibSourceLinkAccessor::Iterator,detail::RecoTrackContainer>
template<typename Object>
using rdoListFunc_t = decltype(std::declval<Object>().rdoList())

Enumerations

enum  NeighbourIndices {
  ThisOne , Opposite , PhiMinus , PhiPlus ,
  EtaMinus , EtaPlus , nNeighbours
}
 Total number of neightbours and indices. More...
enum class  DetectorType : unsigned short {
  Pixel , Sct , Trt , Hgtd ,
  Mdt , Rpc , Tgc , Csc ,
  Mm , sTgc , UnDefined
}
 Simple enum to Identify the Type of the ACTS sub detector. More...

Functions

Acts::CalibrationContext getCalibrationContext (const EventContext &ctx)
 The Acts::Calibration context is piped through the Acts fitters to (re)calibrate the Acts::SourceLinks during the track State upate.
template<typename IFACE, typename AUX>
std::unique_ptr< IFACE > makeInterfaceContainer (const AUX *aux)
 helper to construct interface container for already filled Aux container TODO maybe should be moved to xAOD area
std::string prefixFromTrackContainerName (const std::string &tracks)
 Parse TrackContainer name to get the prefix for backends The name has to contain XYZTracks, the XYZ is returned.
const xAOD::UncalibratedMeasurementgetUncalibratedMeasurement (const ATLASUncalibSourceLink &source_link)
ATLASUncalibSourceLink makeATLASUncalibSourceLink (const xAOD::UncalibratedMeasurementContainer *container, std::size_t index, const EventContext &ctx)
ATLASUncalibSourceLink makeATLASUncalibSourceLink (const xAOD::UncalibratedMeasurementContainer *container, const xAOD::UncalibratedMeasurement *measurement, const EventContext &ctx)
ATLASUncalibSourceLink makeATLASUncalibSourceLink (const xAOD::UncalibratedMeasurementContainer *container, std::size_t index)
ATLASUncalibSourceLink makeATLASUncalibSourceLink (const xAOD::UncalibratedMeasurement *measurement)
float localXFromSourceLink (const ATLASUncalibSourceLink &source_link)
float localYFromSourceLink (const ATLASUncalibSourceLink &source_link)
DetectorElementKey makeDetectorElementKey (xAOD::UncalibMeasType meas_type, unsigned int identifier_hash)
Acts::GeometryIdentifier getSurfaceGeometryIdOfMeasurement (const DetectorElementToActsGeometryIdMap &detector_element_to_geoid, const xAOD::UncalibratedMeasurement &measurement)
std::string to_string (const DetectorType &type)
bool operator< (const std::unique_ptr< SurfaceCache > &a, const std::unique_ptr< SurfaceCache > &b)
 Comparison operators.
bool operator< (const IdentifierHash &a, const std::unique_ptr< SurfaceCache > &b)
bool operator< (const std::unique_ptr< SurfaceCache > &a, const IdentifierHash &b)
void encodeSurface (xAOD::TrackSurfaceAuxContainer *backend, size_t index, const Acts::Surface *surface, const Acts::GeometryContext &geoContext)
 Prepares persistifiable representation of surface into xAOD::TrackSurface object.
void encodeSurface (xAOD::TrackSurface *backend, const Acts::Surface *surface, const Acts::GeometryContext &geoContext)
 As above, but works on xAOD::TrackSurface object.
std::shared_ptr< const Acts::Surface > decodeSurface (const xAOD::TrackSurface *backend)
 Creates transient Acts Surface objects given a surface backend implementation should be exact mirror of encodeSurface.
std::shared_ptr< const Acts::Surface > decodeSurface (const xAOD::TrackSurfaceAuxContainer *backend, size_t i)
 As above, but takes data from Aux container at an index i.
void encodeSurface (xAOD::SurfaceType &surfaceType, std::vector< float > &translation, std::vector< float > &rotation, std::vector< float > &boundValues, const Acts::Surface *surface, const Acts::GeometryContext &geoContext)
std::shared_ptr< const Acts::Surface > decodeSurface (const xAOD::SurfaceType surfaceType, const std::vector< float > &translation, const std::vector< float > &rotation, const std::vector< float > &boundValues)
Acts::Logging::Level actsLevelVector (MSG::Level lvl)
MSG::Level athLevelVector (Acts::Logging::Level lvl)
constexpr double energyToActs (const double athenaE)
 Converts an energy scalar from Athena to Acts units.
constexpr double energyToAthena (const double actsE)
 Converts an energy scalar from Acts to Athena units.
constexpr double lengthToActs (const double athenaL)
 Converts a length scalar from Acts to Athena units.
constexpr double lengthToAthena (const double actsL)
 Converts a length scalar from Acts to Athena units.
constexpr double timeToActs (const double athenaT)
 Converts a time unit from Athena to Acts units.
constexpr double timeToAthena (const double actsT)
 Converts a time unit from Acts to Athena units.
Acts::Vector3 convertDirToActs (const Amg::Vector3D &athenaDir)
 Converts a direction vector from athena units into acts units.
Amg::Vector3D convertDirFromActs (const Acts::Vector3 &actsDir)
 Converts a direction vector from acts units into athena units.
Acts::Vector4 convertPosToActs (const Amg::Vector3D &athenaPos, const double athenaTime=0.)
 Converts a position vector & time from Athena units into Acts units.
std::pair< Amg::Vector3D, double > convertPosFromActs (const Acts::Vector4 &actsPos)
 Converts an Acts 4-vector into a pair of an Athena spatial vector and the passed time.
Acts::Vector4 convertMomToActs (const Amg::Vector3D &threeMom, const double mass=0.)
 Converts a three momentum vector from Athena together with the associated particle mass into an Acts four-momentum vector.
std::pair< Amg::Vector3D, double > convertMomFromActs (const Acts::Vector4 &actsMom)
 Converts an Acts four-momentum vector into an pair of an Athena three-momentum and the paritcle's energy.
template<typename T>
std::underlying_type_t< T > to_underlying (T val)
template<class T_Cont, class T>
std::vector< SG::WriteDecorHandle< T_Cont, T > > createDecorators (const std::vector< SG::WriteDecorHandleKey< T_Cont > > &keys, const EventContext &ctx)
template<class T_Parent, class T_Cont>
void createDecoratorKeys (T_Parent &parent, const SG::ReadHandleKey< T_Cont > &container_key, const std::string &prefix, const std::vector< std::string > &decor_names, std::vector< SG::WriteDecorHandleKey< T_Cont > > &decor_out)
template<class T>
auto getRDOList (const T &a)
template<class T_TruthEventCollection>
auto makeDepositToTruthParticleMap (const T_TruthEventCollection *truth_particle_links)
template<class T_TruthEventCollection>
const char * getInTruthPropertyName ()
template<class T_SimDataCollection, class T_SimDataIterator>
auto getSimDataDeposits (const T_SimDataCollection &sim_data_collection, T_SimDataIterator sim_data_iter_for_identifier)
template<class T_Deposit>
float getDepositedEnergy (const T_Deposit &)
MsgStream & operator<< (MsgStream &out, const ActsUtils::Stat &stat)

Variables

constexpr double ONE_TWELFTH = 1./12.
constexpr float oneStripSF = 1.1025
constexpr float twoStripSF = 0.0729
constexpr unsigned int NTruthParticlesPerMeasurement = 5
constexpr unsigned int NHitCounter = static_cast< std::underlying_type<xAOD::UncalibMeasType>::type >(xAOD::UncalibMeasType::nTypes)
constexpr unsigned int NTruthParticlesPerTrack = 5
constexpr unsigned int DETELEMENT_TYPE_SHIFT = 28
constexpr unsigned int DETELEMENT_HASH_MASK = ~(1u<<31|1u<<30|1u<<29|1u<<28)
constexpr bool TrackToTruthParticleAssociationDebugHists = false
constexpr bool TrackFindingValidationDebugHists = false
constexpr bool TrackFindingValidationDetailedStat = true
constexpr bool TruthParticleHitCountDebugHists = false

Detailed Description

The AlignStoreProviderAlg loads the rigid alignment corrections and pipes them through the readout geometry to cache the final transformations of the sensor surfaces associated to one particular detector technology (Pixel, Sct, etc.).

copied from InDetPhysValMonitoring/src/safeDecorator.h

Put athena Eigen inlcude first.

: The NoDeletePtr is a shared_ptr with disabled deleter.

Header file to manage the common inlcudes.

Includes the GeoPrimitives.

Load ATLAS Eigen library with custom geometry functions.

Include the GeoPrimitives which need to be put first.

Put first the GeoPrimitives.

small non-persistent data class to wrap the output of the EF-tracking development pattern finding placeholder

The DetectorAlignCondAlg loads the rigid alignment corrections and pipes them through the readout geometry to cache the final transformations of the sensor surfaces associated to one particular detector technology (Pixel, Sct, etc.).

The transformations are cached in the DetectorAlignmentStore which is later propagated to the GeometryContext.

The ActsFromGeoAlignStore is an adaptor to go from the GeoModel world caching the rigid transformations of the detector elements to the Acts world where transformations

If the package is loaded in AthSimulation, the Acts library is not avaialble

ActsGeometry context carries all information related to the aboslute positions of the Readout geometry Per detector technology (e.g. Mdt), it contains an ActsTrk::DetectorAlignmentStore which carries pointers to the rigid alignment transfomrations of each FullPhysical volume representing the detector sensor envelope. Further, it carries the transformations for each tracking layer

Then load the Acts TypeDef definitions for Eigen

In AthSimulation, the Acts core library is not available yet

ATLAS extension of the Acts::DetectorElementBase. The extension provides extra methods to identify the element within the ATLAS identifier scheme and also the enum indicating to which tracking subsystem the DetectorElement belongs to. Finally, the detector element provides the interface to optionally precache the aligned transformations in the external AlignmentStore of the geometry context.

forward declarations of the classes defined in the package

Typedef Documentation

◆ ATLASSourceLink

Definition at line 23 of file ATLASSourceLink.h.

◆ ATLASUncalibSourceLink

◆ AtlUncalibSourceLinkAccessor

◆ BoundTrackParametersContainer

◆ ConstCovariance

using ActsTrk::ConstCovariance = Acts::TrackStateTraits<3>::Covariance

◆ ConstParameters

using ActsTrk::ConstParameters = Acts::TrackStateTraits<3>::Parameters

◆ Covariance

using ActsTrk::Covariance = Acts::TrackStateTraits<3, false>::Covariance

◆ DefaultTrackStateCreator

◆ DetectorElementKey

using ActsTrk::DetectorElementKey = unsigned int

Definition at line 19 of file DetectorElementToActsGeometryIdMap.h.

◆ IndexType

using ActsTrk::IndexType = std::uint32_t

Definition at line 14 of file Decoration.h.

◆ MuonChamberSet

◆ MuonSectorSet

◆ MutablePersistentTrackBackend

◆ MutablePersistentTrackStateBackend

◆ MutableTrackBackend

using ActsTrk::MutableTrackBackend = Acts::VectorTrackContainer

Definition at line 16 of file TrackContainer.h.

◆ MutableTrackContainer

Initial value:
Acts::TrackContainer<MutableTrackBackend,
Acts::detail::ValueHolder>
Acts::VectorMultiTrajectory MutableTrackStateBackend
Acts::VectorTrackContainer MutableTrackBackend

Definition at line 25 of file TrackContainer.h.

◆ MutableTrackStateBackend

using ActsTrk::MutableTrackStateBackend = Acts::VectorMultiTrajectory

Definition at line 18 of file TrackContainer.h.

◆ Parameters

using ActsTrk::Parameters = Acts::TrackStateTraits<3, false>::Parameters

◆ ParticleVector

using ActsTrk::ParticleVector = boost::container::small_vector<const xAOD::TruthParticle *, NTruthParticlesPerMeasurement>

Definition at line 17 of file MeasurementToTruthParticleAssociation.h.

◆ PersistentTrackBackend

◆ PersistentTrackContainerBase

◆ PersistentTrackStateBackend

◆ ProtoTrackCollection

Definition at line 12 of file ProtoTrackCollection.h.

◆ rdoListFunc_t

template<typename Object>
using ActsTrk::rdoListFunc_t = decltype(std::declval<Object>().rdoList())

Definition at line 94 of file MeasurementToTruthAssociationAlg.h.

◆ ReturnedHintArr

◆ ReturnedTicketArr

◆ staticNodePtr

using ActsTrk::staticNodePtr = std::shared_ptr<Acts::Experimental::StaticBlueprintNode>

Definition at line 40 of file MuonBlueprintNodeBuilder.h.

◆ StIdx

◆ StoredSurface

using ActsTrk::StoredSurface = std::variant<const Acts::Surface*, std::shared_ptr<const Acts::Surface>>

Definition at line 66 of file MultiTrajectory.h.

◆ SurfaceCacheSet

using ActsTrk::SurfaceCacheSet = std::set<std::unique_ptr<SurfaceCache>, std::less<>>

◆ surfacePtr

using ActsTrk::surfacePtr = std::shared_ptr<Acts::Surface>

Definition at line 41 of file MuonBlueprintNodeBuilder.h.

◆ TicketCounterArr

◆ TrackBackend

using ActsTrk::TrackBackend = Acts::ConstVectorTrackContainer

Definition at line 15 of file TrackContainer.h.

◆ TrackContainerBase

Initial value:
Acts::TrackContainer<TrackBackend,
Acts::detail::ValueHolder>
Acts::ConstVectorTrackContainer TrackBackend
Acts::ConstVectorMultiTrajectory TrackStateBackend

Definition at line 21 of file TrackContainer.h.

◆ TrackStateBackend

using ActsTrk::TrackStateBackend = Acts::ConstVectorMultiTrajectory

Definition at line 17 of file TrackContainer.h.

◆ TruthParticleHitCounts

Definition at line 19 of file TruthParticleHitCounts.h.

Enumeration Type Documentation

◆ DetectorType

enum class ActsTrk::DetectorType : unsigned short
strong

Simple enum to Identify the Type of the ACTS sub detector.

Enumerator
Pixel 

Inner detector legacy.

Sct 
Trt 

Maybe the Sct / Pixel for Itk become seperate entries?

Hgtd 
Mdt 

MuonSpectrometer.

Rpc 

Monitored Drift Tubes.

Tgc 

Resitive Plate Chambers.

Csc 

Thin gap champers.

Mm 

Maybe not needed in the migration.

sTgc 

Micromegas (NSW)

UnDefined 

Small Thing Gap chambers (NSW)

Definition at line 17 of file GeometryDefs.h.

17 : unsigned short {
19 Pixel,
20 Sct,
22 Trt,
23 Hgtd,
25 Mdt,
26 Rpc,
27 Tgc,
28 Csc,
29 Mm,
30 sTgc,
32 };
@ Mm
Maybe not needed in the migration.
@ Tgc
Resitive Plate Chambers.
@ sTgc
Micromegas (NSW)
@ Rpc
Monitored Drift Tubes.
@ Csc
Thin gap champers.
@ Trt
Maybe the Sct / Pixel for Itk become seperate entries?
@ Mdt
MuonSpectrometer.
@ UnDefined
Small Thing Gap chambers (NSW)
@ Pixel
Definition DetType.h:13

◆ NeighbourIndices

Total number of neightbours and indices.

Enumerator
ThisOne 
Opposite 
PhiMinus 
PhiPlus 
EtaMinus 
EtaPlus 
nNeighbours 

Definition at line 13 of file StripInformationHelper.h.

Function Documentation

◆ actsLevelVector()

Acts::Logging::Level ActsTrk::actsLevelVector ( MSG::Level lvl)

Definition at line 9 of file LoggerUtils.cxx.

9 {
10 // MSG::NIL and MSG::ALWAYS are not available in Acts. Need to protect against these
11 // For MSG::NIL we can return a Acts::Logging::Level::FATAL;
12 // For MSG::ALWAYS we can return a Acts::Logging::Level::VERBOSE
13
14 // Gaudi definitions are +1 w.r.t. Acts definitions
15 static const std::array<Acts::Logging::Level, 8> actsLevelVector{
16 Acts::Logging::Level::FATAL, // MSG::NIL
17 Acts::Logging::Level::VERBOSE,
18 Acts::Logging::Level::DEBUG,
19 Acts::Logging::Level::INFO,
20 Acts::Logging::Level::WARNING,
21 Acts::Logging::Level::ERROR,
22 Acts::Logging::Level::FATAL,
23 Acts::Logging::Level::VERBOSE // MSG::ALWAYS
24 };
25
26 return actsLevelVector[static_cast<int>(lvl)];
27 }
Acts::Logging::Level actsLevelVector(MSG::Level lvl)

◆ athLevelVector()

MSG::Level ActsTrk::athLevelVector ( Acts::Logging::Level lvl)

Definition at line 29 of file LoggerUtils.cxx.

29 {
30 // All Acts log levels are available in Gaudi, no need for protections
31 static const std::array<MSG::Level, 6> athLevelVector{
32 MSG::VERBOSE,
33 MSG::DEBUG,
34 MSG::INFO,
35 MSG::WARNING,
36 MSG::ERROR,
37 MSG::FATAL
38 };
39 return athLevelVector[static_cast<int>(lvl)];
40 }
MSG::Level athLevelVector(Acts::Logging::Level lvl)

◆ convertDirFromActs()

Amg::Vector3D ActsTrk::convertDirFromActs ( const Acts::Vector3 & actsDir)
inline

Converts a direction vector from acts units into athena units.

Parameters
actsDirUnit normalized vector to convert

Definition at line 68 of file UnitConverters.h.

68 {
69 return actsDir;
70 }

◆ convertDirToActs()

Acts::Vector3 ActsTrk::convertDirToActs ( const Amg::Vector3D & athenaDir)
inline

Converts a direction vector from athena units into acts units.

Parameters
athenaDirUnit normalized vector to convert

Definition at line 63 of file UnitConverters.h.

63 {
64 return athenaDir;
65 }

◆ convertMomFromActs()

std::pair< Amg::Vector3D, double > ActsTrk::convertMomFromActs ( const Acts::Vector4 & actsMom)
inline

Converts an Acts four-momentum vector into an pair of an Athena three-momentum and the paritcle's energy.

Parameters
actsMomThe four momentum vector from Acts

Definition at line 109 of file UnitConverters.h.

109 {
110 Amg::Vector3D threeMom{Amg::Vector3D::Zero()};
111 threeMom[Amg::x] = energyToAthena(actsMom[Acts::eMom0]);
112 threeMom[Amg::y] = energyToAthena(actsMom[Acts::eMom1]);
113 threeMom[Amg::z] = energyToAthena(actsMom[Acts::eMom2]);
114 return std::make_pair(std::move(threeMom), energyToAthena(actsMom[Acts::eEnergy]));
115 }
constexpr double energyToAthena(const double actsE)
Converts an energy scalar from Acts to Athena units.
Eigen::Matrix< double, 3, 1 > Vector3D

◆ convertMomToActs()

Acts::Vector4 ActsTrk::convertMomToActs ( const Amg::Vector3D & threeMom,
const double mass = 0. )
inline

Converts a three momentum vector from Athena together with the associated particle mass into an Acts four-momentum vector.

Parameters
threeMomThree momentum vector in Athena units
massParticle's mass in Athena units

Definition at line 97 of file UnitConverters.h.

97 {
98 using namespace Acts::UnitLiterals;
99 Acts::Vector4 fourMom{Acts::Vector4::Zero()};
100 fourMom[Acts::eEnergy] = energyToActs(std::sqrt(threeMom.dot(threeMom) + mass*mass));
101 fourMom[Acts::eMom0] = energyToActs(threeMom.x());
102 fourMom[Acts::eMom1] = energyToActs(threeMom.y());
103 fourMom[Acts::eMom2] = energyToActs(threeMom.z());
104 return fourMom;
105 }
constexpr double energyToActs(const double athenaE)
Converts an energy scalar from Athena to Acts units.

◆ convertPosFromActs()

std::pair< Amg::Vector3D, double > ActsTrk::convertPosFromActs ( const Acts::Vector4 & actsPos)
inline

Converts an Acts 4-vector into a pair of an Athena spatial vector and the passed time.

Parameters
actsPosPosition from the Acts framework

Definition at line 86 of file UnitConverters.h.

86 {
87 Amg::Vector3D pos{Amg::Vector3D::Zero()};
88 pos[Amg::x] = lengthToAthena(actsPos[Acts::ePos0]);
89 pos[Amg::y] = lengthToAthena(actsPos[Acts::ePos1]);
90 pos[Amg::z] = lengthToAthena(actsPos[Acts::ePos2]);
91 return std::make_pair(std::move(pos), timeToAthena(actsPos[Acts::eTime]));
92 }
constexpr double timeToAthena(const double actsT)
Converts a time unit from Acts to Athena units.
constexpr double lengthToAthena(const double actsL)
Converts a length scalar from Acts to Athena units.

◆ convertPosToActs()

Acts::Vector4 ActsTrk::convertPosToActs ( const Amg::Vector3D & athenaPos,
const double athenaTime = 0. )
inline

Converts a position vector & time from Athena units into Acts units.

Parameters
athenaPos3D-spatial position vector to convert
athenaTimeTime counts to convert

Definition at line 74 of file UnitConverters.h.

75 {
76 Acts::Vector4 pos{Acts::Vector4::Zero()};
77 pos[Acts::eTime] = timeToActs(athenaTime);
78 pos[Acts::ePos0] = lengthToActs(athenaPos.x());
79 pos[Acts::ePos1] = lengthToActs(athenaPos.y());
80 pos[Acts::ePos2] = lengthToActs(athenaPos.z());
81 return pos;
82 }
constexpr double lengthToActs(const double athenaL)
Converts a length scalar from Acts to Athena units.
constexpr double timeToActs(const double athenaT)
Converts a time unit from Athena to Acts units.

◆ createDecoratorKeys()

template<class T_Parent, class T_Cont>
void ActsTrk::createDecoratorKeys ( T_Parent & parent,
const SG::ReadHandleKey< T_Cont > & container_key,
const std::string & prefix,
const std::vector< std::string > & decor_names,
std::vector< SG::WriteDecorHandleKey< T_Cont > > & decor_out )

Definition at line 49 of file decoratorUtils.h.

53 {
54 decor_out.clear();
55 decor_out.reserve(decor_names.size());
56 for (const std::string &a_decor_name : decor_names) {
57 assert( !a_decor_name.empty() );
58 decor_out.emplace_back(container_key.key()+"."+prefix+a_decor_name);
59 // need to declare handles, otherwise the scheduler would not pick up the data dependencies
60 // introduced by the decorations
61 parent.declare(decor_out.back());
62 decor_out.back().setOwner(&parent);
63 decor_out.back().initialize().ignore();
64 }
65 }
const std::string & key() const
Return the StoreGate ID for the referenced object.

◆ createDecorators()

template<class T_Cont, class T>
std::vector< SG::WriteDecorHandle< T_Cont, T > > ActsTrk::createDecorators ( const std::vector< SG::WriteDecorHandleKey< T_Cont > > & keys,
const EventContext & ctx )

Definition at line 31 of file decoratorUtils.h.

32 {
33 std::vector<SG::WriteDecorHandle<T_Cont,T> > out;
34 out.reserve(keys.size());
35 for( const SG::WriteDecorHandleKey<T_Cont> &a_key : keys) {
36 out.emplace_back(a_key,ctx);
37 if (not out.back().isValid()) {
38 std::stringstream msg;
39 msg << "Failed to create decorator handdle " << a_key.key();
40 throw std::runtime_error( msg.str() );
41 }
42 }
43 return out;
44 }
Property holding a SG store/key/clid/attr name from which a WriteDecorHandle is made.
MsgStream & msg
Definition testRead.cxx:32

◆ decodeSurface() [1/3]

std::shared_ptr< const Acts::Surface > ActsTrk::decodeSurface ( const xAOD::SurfaceType surfaceType,
const std::vector< float > & translation,
const std::vector< float > & rotation,
const std::vector< float > & boundValues )

Definition at line 91 of file SurfaceEncoding.cxx.

93 {
94
95 // Translation and rotation
96
97 // create the transformation matrix
98 Amg::Transform3D transform =
99 Amg::getTranslate3D(translation[0], translation[1], translation[2]) *
100 Amg::getRotateZ3D(rotation[0]) *
101 Amg::getRotateY3D(rotation[1]) *
102 Amg::getRotateX3D(rotation[2]);
103
104 switch (surfaceType) {
105 using enum xAOD::SurfaceType;
106 case Cone:
107 return Acts::Surface::makeShared<Acts::ConeSurface>(std::move(transform),
108 boundValues[0], boundValues[1], boundValues[2], boundValues[3]);
109 case Cylinder: {
110 // phi/2 must be slightly < Pi to avoid crashing
111 const float fixedPhi = boundValues[2] > M_PI - 0.001 ? M_PI - 0.001 : boundValues[2];
112 return Acts::Surface::makeShared<Acts::CylinderSurface>(std::move(transform),
113 boundValues[0], boundValues[1], fixedPhi, boundValues[3], boundValues[4]);
114 } case Disc:
115 return Acts::Surface::makeShared<Acts::DiscSurface>(std::move(transform),
116 boundValues[0], boundValues[1], boundValues[2]);
117 case Perigee:
118 return Acts::Surface::makeShared<Acts::PerigeeSurface>(std::move(transform));
119 case Plane: {
120 Acts::Vector2 min(boundValues[0], boundValues[1]),
121 max(boundValues[2], boundValues[3]);
122 auto rBounds = std::make_shared<const Acts::RectangleBounds>(min, max);
123 return Acts::Surface::makeShared<Acts::PlaneSurface>(std::move(transform), rBounds);
124 } case Straw:
125 return Acts::Surface::makeShared<Acts::StrawSurface>(std::move(transform),
126 boundValues[0], boundValues[1]);
127 case Curvilinear:
128 case Other:
129 THROW_EXCEPTION("EncodeSurface this type " <<static_cast<int>(surfaceType)<<
130 " of xAOD::surface cannot be converted into an Acts one");
131 }
132
133 return nullptr;
134}
#define M_PI
#define min(a, b)
Definition cfImp.cxx:40
#define max(a, b)
Definition cfImp.cxx:41
Amg::Transform3D getRotateX3D(double angle)
get a rotation transformation around X-axis
Amg::Transform3D getTranslate3D(const double X, const double Y, const double Z)
: Returns a shift transformation along an arbitrary axis
Amg::Transform3D getRotateZ3D(double angle)
get a rotation transformation around Z-axis
Eigen::Affine3d Transform3D
Amg::Transform3D getRotateY3D(double angle)
get a rotation transformation around Y-axis
SurfaceType
This enumerator simplifies the persistency & calculations, by saving a dynamic_cast,...
#define THROW_EXCEPTION(MESSAGE)
Definition throwExcept.h:10

◆ decodeSurface() [2/3]

std::shared_ptr< const Acts::Surface > ActsTrk::decodeSurface ( const xAOD::TrackSurface * backend)

Creates transient Acts Surface objects given a surface backend implementation should be exact mirror of encodeSurface.

Definition at line 136 of file SurfaceEncoding.cxx.

136 {
137 return decodeSurface(s->surfaceType(), s->translation(), s->rotation(),
138 s->boundValues());
139}
std::shared_ptr< const Acts::Surface > decodeSurface(const xAOD::TrackSurface *backend)
Creates transient Acts Surface objects given a surface backend implementation should be exact mirror ...

◆ decodeSurface() [3/3]

std::shared_ptr< const Acts::Surface > ActsTrk::decodeSurface ( const xAOD::TrackSurfaceAuxContainer * backend,
size_t i )

As above, but takes data from Aux container at an index i.

Definition at line 141 of file SurfaceEncoding.cxx.

142 {
143 return decodeSurface(s->surfaceType[i], s->translation[i], s->rotation[i],
144 s->boundValues[i]);
145}

◆ encodeSurface() [1/3]

void ActsTrk::encodeSurface ( xAOD::SurfaceType & surfaceType,
std::vector< float > & translation,
std::vector< float > & rotation,
std::vector< float > & boundValues,
const Acts::Surface * surface,
const Acts::GeometryContext & geoContext )

Definition at line 20 of file SurfaceEncoding.cxx.

25 {
26 // return if surf is a nullptr
27 if (!surface) {
28 return;
29 }
30 switch (surface->type()){
31 using enum Acts::Surface::SurfaceType;
32 case Cone:
33 surfaceType = xAOD::SurfaceType::Cone;
34 break;
35 case Cylinder:
36 surfaceType = xAOD::SurfaceType::Cylinder;
37 break;
38 case Disc:
39 surfaceType = xAOD::SurfaceType::Disc;
40 break;
41 case Perigee:
42 surfaceType = xAOD::SurfaceType::Perigee;
43 break;
44 case Plane:
45 surfaceType = xAOD::SurfaceType::Plane;
46 break;
47 case Straw:
48 surfaceType = xAOD::SurfaceType::Straw;
49 break;
50 case Curvilinear:
52 break;
53 case Other:
54 surfaceType = xAOD::SurfaceType::Other;
55 break;
56 }
57
58 Acts::RotationMatrix3 lRotation =
59 surface->transform(geoContext).rotation();
60 Acts::Vector3 eulerAngles = lRotation.eulerAngles(2, 1, 0);
61 Acts::Vector3 lTranslation = surface->center(geoContext);
62
63 for (int i = 0; i < 3; ++i) {
64 rotation.push_back(eulerAngles[i]);
65 translation.push_back(lTranslation[i]);
66 }
67 // copy and transform double->float
68 const std::vector<double>& values = surface->bounds().values();
69 boundValues.insert(boundValues.end(), values.begin(), values.end());
70}

◆ encodeSurface() [2/3]

void ActsTrk::encodeSurface ( xAOD::TrackSurface * backend,
const Acts::Surface * surface,
const Acts::GeometryContext & geoContext )

As above, but works on xAOD::TrackSurface object.

Definition at line 79 of file SurfaceEncoding.cxx.

80 {
81 xAOD::SurfaceType surfaceType;
82 std::vector<float> translation, rotation, bounds;
83 encodeSurface(surfaceType, translation, rotation, bounds, surface, geo);
84
85 s->setSurfaceType(surfaceType);
86 s->setTranslation(translation);
87 s->setRotation(rotation);
88 s->setBoundValues(bounds);
89}
void encodeSurface(xAOD::TrackSurfaceAuxContainer *backend, size_t index, const Acts::Surface *surface, const Acts::GeometryContext &geoContext)
Prepares persistifiable representation of surface into xAOD::TrackSurface object.

◆ encodeSurface() [3/3]

void ActsTrk::encodeSurface ( xAOD::TrackSurfaceAuxContainer * backend,
size_t index,
const Acts::Surface * surface,
const Acts::GeometryContext & geoContext )

Prepares persistifiable representation of surface into xAOD::TrackSurface object.

Warning
supports only few types, unhandled surface type results in a exception
  • backend - container to store surface data
  • index - index under which the data needs to be recorded

Definition at line 72 of file SurfaceEncoding.cxx.

74 {
75 encodeSurface(s->surfaceType[i], s->translation[i], s->rotation[i],
76 s->boundValues[i], surface, geo);
77}

◆ energyToActs()

double ActsTrk::energyToActs ( const double athenaE)
inlineconstexpr

Converts an energy scalar from Athena to Acts units.

Parameters
athenaEEnergy value to convert

Definition at line 21 of file UnitConverters.h.

21 {
22 using namespace Acts::UnitLiterals;
23 constexpr double energyCnv = 1_MeV / Gaudi::Units::MeV;
24 return energyCnv * athenaE;
25 }

◆ energyToAthena()

double ActsTrk::energyToAthena ( const double actsE)
inlineconstexpr

Converts an energy scalar from Acts to Athena units.

Parameters
athenaEEnergy value to convert

Definition at line 28 of file UnitConverters.h.

28 {
29 using namespace Acts::UnitLiterals;
30 constexpr double energyCnv = Gaudi::Units::MeV / 1_MeV;
31 return energyCnv * actsE;
32 }

◆ getCalibrationContext()

Acts::CalibrationContext ActsTrk::getCalibrationContext ( const EventContext & ctx)
inline

The Acts::Calibration context is piped through the Acts fitters to (re)calibrate the Acts::SourceLinks during the track State upate.

In ATLAS Athena, the EventContext is needed to access the calibration context from the conditions. This function packs the pointer of the current EventContext into a Acts::CalibrationContext

Parameters
ctxEventContext to transform into a Context

Definition at line 15 of file CalibrationContext.h.

15 {
16 return Acts::CalibrationContext{&ctx};
17 }

◆ getDepositedEnergy()

template<class T_Deposit>
float ActsTrk::getDepositedEnergy ( const T_Deposit & )

◆ getInTruthPropertyName()

template<class T_TruthEventCollection>
const char * ActsTrk::getInTruthPropertyName ( )
inline

◆ getRDOList()

template<class T>
auto ActsTrk::getRDOList ( const T & a)

Definition at line 109 of file MeasurementToTruthAssociationAlg.h.

109 {
110 if constexpr(has_rdoList<T>::value) {
111 return a.rdoList();
112 }
113 else {
114 return DummyRDOList(a);
115 }
116 }

◆ getSimDataDeposits()

template<class T_SimDataCollection, class T_SimDataIterator>
auto ActsTrk::getSimDataDeposits ( const T_SimDataCollection & sim_data_collection,
T_SimDataIterator sim_data_iter_for_identifier )

◆ getSurfaceGeometryIdOfMeasurement()

Acts::GeometryIdentifier ActsTrk::getSurfaceGeometryIdOfMeasurement ( const DetectorElementToActsGeometryIdMap & detector_element_to_geoid,
const xAOD::UncalibratedMeasurement & measurement )
inline

Definition at line 13 of file SurfaceOfMeasurementUtil.h.

16 {
17 DetectorElementToActsGeometryIdMap::const_iterator
18 geoid_iter = detector_element_to_geoid.find( makeDetectorElementKey(measurement.type(), measurement.identifierHash()) );
19 return geoid_iter != detector_element_to_geoid.end()
21 : Acts::GeometryIdentifier{};
22 }
DetectorIDHashType identifierHash() const
Returns the IdentifierHash of the measurement (corresponds to the detector element IdentifierHash)
virtual xAOD::UncalibMeasType type() const =0
Returns the type of the measurement type as a simple enumeration.
DetectorElementKey makeDetectorElementKey(xAOD::UncalibMeasType meas_type, unsigned int identifier_hash)
static const Acts::GeometryIdentifier & getValue(const value_type &element)

◆ getUncalibratedMeasurement()

const xAOD::UncalibratedMeasurement & ActsTrk::getUncalibratedMeasurement ( const ATLASUncalibSourceLink & source_link)
inline

Definition at line 26 of file ATLASSourceLink.h.

26 {
27 assert(source_link);
28 return *source_link;
29 }

◆ lengthToActs()

double ActsTrk::lengthToActs ( const double athenaL)
inlineconstexpr

Converts a length scalar from Acts to Athena units.

Parameters
athenaLLength value to convert

Definition at line 35 of file UnitConverters.h.

35 {
36 using namespace Acts::UnitLiterals;
37 constexpr double lengthCnv = 1_mm / Gaudi::Units::mm;
38 return lengthCnv * athenaL;
39 }

◆ lengthToAthena()

double ActsTrk::lengthToAthena ( const double actsL)
inlineconstexpr

Converts a length scalar from Acts to Athena units.

Parameters
athenaLLength value to convert

Definition at line 42 of file UnitConverters.h.

42 {
43 using namespace Acts::UnitLiterals;
44 constexpr double lengthCnv = Gaudi::Units::mm / 1_mm;
45 return lengthCnv * actsL;
46 }

◆ localXFromSourceLink()

float ActsTrk::localXFromSourceLink ( const ATLASUncalibSourceLink & source_link)
inline

Definition at line 53 of file ATLASSourceLink.h.

53 {
54 const xAOD::UncalibratedMeasurement &uncalib_meas = getUncalibratedMeasurement(source_link);
55 return uncalib_meas.type() == xAOD::UncalibMeasType::PixelClusterType
56 ? uncalib_meas.localPosition<2>()[Trk::locX]
57 : uncalib_meas.localPosition<1>()[Trk::locX];
58 }
ConstVectorMap< N > localPosition() const
Returns the local position of the measurement.
const xAOD::UncalibratedMeasurement & getUncalibratedMeasurement(const ATLASUncalibSourceLink &source_link)
Ensure that the ATLAS eigen extensions are properly loaded.
@ locX
Definition ParamDefs.h:37
UncalibratedMeasurement_v1 UncalibratedMeasurement
Define the version of the uncalibrated measurement class.

◆ localYFromSourceLink()

float ActsTrk::localYFromSourceLink ( const ATLASUncalibSourceLink & source_link)
inline

Definition at line 60 of file ATLASSourceLink.h.

60 {
61 const xAOD::UncalibratedMeasurement &uncalib_meas = getUncalibratedMeasurement(source_link);
62 assert(uncalib_meas.type() == xAOD::UncalibMeasType::PixelClusterType );
63 return uncalib_meas.localPosition<2>()[Trk::locY];
64 }
@ locY
local cartesian
Definition ParamDefs.h:38

◆ makeATLASUncalibSourceLink() [1/4]

ATLASUncalibSourceLink ActsTrk::makeATLASUncalibSourceLink ( const xAOD::UncalibratedMeasurement * measurement)
inline

Definition at line 49 of file ATLASSourceLink.h.

49 {
50 assert(measurement && measurement->container() && measurement->index() < measurement->container()->size_v());
51 return measurement;
52 }
const SG::AuxVectorData * container() const
Return the container holding this element.
size_t index() const
Return the index of this element within its container.
virtual size_t size_v() const =0
Return the size of the container.

◆ makeATLASUncalibSourceLink() [2/4]

ATLASUncalibSourceLink ActsTrk::makeATLASUncalibSourceLink ( const xAOD::UncalibratedMeasurementContainer * container,
const xAOD::UncalibratedMeasurement * measurement,
const EventContext & ctx )
inline

Definition at line 36 of file ATLASSourceLink.h.

38 {
39 assert( container == measurement->container());
40 assert( container && measurement->index() < container->size() );
41 return measurement;
42 }

◆ makeATLASUncalibSourceLink() [3/4]

ATLASUncalibSourceLink ActsTrk::makeATLASUncalibSourceLink ( const xAOD::UncalibratedMeasurementContainer * container,
std::size_t index )
inline

Definition at line 43 of file ATLASSourceLink.h.

44 {
45 assert(container && index < container->size());
46 return container->at(index);
47 }
Definition index.py:1

◆ makeATLASUncalibSourceLink() [4/4]

ATLASUncalibSourceLink ActsTrk::makeATLASUncalibSourceLink ( const xAOD::UncalibratedMeasurementContainer * container,
std::size_t index,
const EventContext & ctx )
inline

Definition at line 30 of file ATLASSourceLink.h.

32 {
33 assert(container && index < container->size());
34 return container->at(index);
35 }

◆ makeDepositToTruthParticleMap()

template<class T_TruthEventCollection>
auto ActsTrk::makeDepositToTruthParticleMap ( const T_TruthEventCollection * truth_particle_links)

◆ makeDetectorElementKey()

DetectorElementKey ActsTrk::makeDetectorElementKey ( xAOD::UncalibMeasType meas_type,
unsigned int identifier_hash )
inline

Definition at line 23 of file DetectorElementToActsGeometryIdMap.h.

23 {
24 assert( sizeof(xAOD::UncalibMeasType) <= sizeof(std::size_t) );
25 assert( static_cast<std::size_t>( to_underlying(meas_type)&((~DETELEMENT_HASH_MASK)>>DETELEMENT_TYPE_SHIFT)) == static_cast<std::size_t>(meas_type));
26 assert( (identifier_hash & DETELEMENT_HASH_MASK) == identifier_hash);
27 return (to_underlying(meas_type) << DETELEMENT_TYPE_SHIFT) | (identifier_hash & DETELEMENT_HASH_MASK);
28 }
constexpr unsigned int DETELEMENT_HASH_MASK
std::underlying_type_t< T > to_underlying(T val)
constexpr unsigned int DETELEMENT_TYPE_SHIFT
UncalibMeasType
Define the type of the uncalibrated measurement.

◆ makeInterfaceContainer()

template<typename IFACE, typename AUX>
std::unique_ptr< IFACE > ActsTrk::makeInterfaceContainer ( const AUX * aux)

helper to construct interface container for already filled Aux container TODO maybe should be moved to xAOD area

Definition at line 516 of file MultiTrajectory.h.

516 {
517 auto interface = std::make_unique<IFACE>();
518 for ( size_t i = 0, sz = aux->size(); i < sz; ++i) {
519 interface->emplace_back( new std::remove_pointer_t<typename IFACE::value_type>() );
520 }
521 interface->setStore(aux);
522 return interface;
523}

◆ operator<() [1/3]

bool ActsTrk::operator< ( const IdentifierHash & a,
const std::unique_ptr< SurfaceCache > & b )
inline

Definition at line 63 of file Tracking/Acts/ActsGeoUtils/ActsGeoUtils/SurfaceCache.h.

63 {
64 return a < b->hash();
65 }
TList * a

◆ operator<() [2/3]

bool ActsTrk::operator< ( const std::unique_ptr< SurfaceCache > & a,
const IdentifierHash & b )
inline

Definition at line 66 of file Tracking/Acts/ActsGeoUtils/ActsGeoUtils/SurfaceCache.h.

66 {
67 return a->hash() < b;
68 }

◆ operator<() [3/3]

bool ActsTrk::operator< ( const std::unique_ptr< SurfaceCache > & a,
const std::unique_ptr< SurfaceCache > & b )
inline

Comparison operators.

Definition at line 59 of file Tracking/Acts/ActsGeoUtils/ActsGeoUtils/SurfaceCache.h.

60 {
61 return a->hash() < b->hash();
62 }

◆ operator<<()

MsgStream & ActsTrk::operator<< ( MsgStream & out,
const ActsUtils::Stat & stat )
inline

Definition at line 25 of file TrackToTruthAssociationAlg.cxx.

25 {
26 ActsUtils::dumpStat(out, stat);
27 return out;
28 }
void dumpStat(T_Stream &out, const Stat &stat)
Dump the given statistics object to the given output stream.
Definition StatUtils.h:63

◆ prefixFromTrackContainerName()

std::string ActsTrk::prefixFromTrackContainerName ( const std::string & tracks)

Parse TrackContainer name to get the prefix for backends The name has to contain XYZTracks, the XYZ is returned.

Definition at line 20 of file TrackContainerHandlesHelper.cxx.

20 {
21 std::regex word_regex("(.*)Tracks$");
22 std::smatch match_regex;
23
24 if ( not std::regex_search(tracks, match_regex, word_regex) or match_regex.size() < 2) {
25 throw std::runtime_error(
26 std::string("prefixFromTrackContainerName: key does not contain "
27 "Tracks in the name ") + tracks);
28 }
29
30 return match_regex[1].str();
31}

◆ timeToActs()

double ActsTrk::timeToActs ( const double athenaT)
inlineconstexpr

Converts a time unit from Athena to Acts units.

Parameters
athenaTTime interval to convert

Definition at line 49 of file UnitConverters.h.

49 {
50 using namespace Acts::UnitLiterals;
51 constexpr double timeCnv = 1_ns / Gaudi::Units::ns;
52 return timeCnv * athenaT;
53 }

◆ timeToAthena()

double ActsTrk::timeToAthena ( const double actsT)
inlineconstexpr

Converts a time unit from Acts to Athena units.

Parameters
actsTTime interval to convert

Definition at line 56 of file UnitConverters.h.

56 {
57 using namespace Acts::UnitLiterals;
58 constexpr double timeCnv = Gaudi::Units::ns/ 1_ns;
59 return timeCnv * actsT;
60 }

◆ to_string()

std::string ActsTrk::to_string ( const DetectorType & type)
inline

Definition at line 34 of file GeometryDefs.h.

34 {
36 return "Pixel";
37 else if (type == DetectorType::Sct)
38 return "Sct";
39 else if (type == DetectorType::Trt)
40 return "Trt";
41 else if (type == DetectorType::Hgtd)
42 return "Hgtd";
43 else if (type == DetectorType::Mdt)
44 return "Mdt";
45 else if (type == DetectorType::Rpc)
46 return "Rpc";
47 else if (type == DetectorType::Tgc)
48 return "Tgc";
49 else if (type == DetectorType::Csc)
50 return "Csc";
51 else if (type == DetectorType::Mm)
52 return "Mm";
53 else if (type == DetectorType::sTgc)
54 return "sTgc";
55 return "Unknown";
56 }
@ Pixel
Inner detector legacy.

◆ to_underlying()

template<typename T>
std::underlying_type_t< T > ActsTrk::to_underlying ( T val)

Definition at line 14 of file ActsInspectTruthContentAlg.cxx.

15 { return static_cast< std::underlying_type_t<T> >(val); }

Variable Documentation

◆ DETELEMENT_HASH_MASK

unsigned int ActsTrk::DETELEMENT_HASH_MASK = ~(1u<<31|1u<<30|1u<<29|1u<<28)
constexpr

Definition at line 21 of file DetectorElementToActsGeometryIdMap.h.

◆ DETELEMENT_TYPE_SHIFT

unsigned int ActsTrk::DETELEMENT_TYPE_SHIFT = 28
constexpr

Definition at line 20 of file DetectorElementToActsGeometryIdMap.h.

◆ NHitCounter

unsigned int ActsTrk::NHitCounter = static_cast< std::underlying_type<xAOD::UncalibMeasType>::type >(xAOD::UncalibMeasType::nTypes)
constexpr

Definition at line 19 of file TrackToTruthParticleAssociation.h.

◆ NTruthParticlesPerMeasurement

unsigned int ActsTrk::NTruthParticlesPerMeasurement = 5
constexpr

Definition at line 14 of file MeasurementToTruthParticleAssociation.h.

◆ NTruthParticlesPerTrack

unsigned int ActsTrk::NTruthParticlesPerTrack = 5
constexpr

Definition at line 20 of file TrackToTruthParticleAssociation.h.

◆ ONE_TWELFTH

double ActsTrk::ONE_TWELFTH = 1./12.
constexpr

Definition at line 20 of file StripClusteringTool.cxx.

◆ oneStripSF

float ActsTrk::oneStripSF = 1.1025
constexpr

Definition at line 21 of file StripClusteringTool.cxx.

◆ TrackFindingValidationDebugHists

bool ActsTrk::TrackFindingValidationDebugHists = false
constexpr

Definition at line 41 of file TrackTruthMatchingBaseAlg.h.

◆ TrackFindingValidationDetailedStat

bool ActsTrk::TrackFindingValidationDetailedStat = true
constexpr

Definition at line 42 of file TrackTruthMatchingBaseAlg.h.

◆ TrackToTruthParticleAssociationDebugHists

bool ActsTrk::TrackToTruthParticleAssociationDebugHists = false
constexpr

Definition at line 42 of file TrackToTruthAssociationAlg.h.

◆ TruthParticleHitCountDebugHists

bool ActsTrk::TruthParticleHitCountDebugHists = false
constexpr

Definition at line 42 of file TruthParticleHitCountAlg.h.

◆ twoStripSF

float ActsTrk::twoStripSF = 0.0729
constexpr

Definition at line 22 of file StripClusteringTool.cxx.