ATLAS Offline Software
Classes | Public Member Functions | Static Public Member Functions | Protected Member Functions | Private Types | Private Member Functions | Private Attributes | List of all members
Trk::RungeKuttaPropagator Class Referencefinalabstract

#include <RungeKuttaPropagator.h>

Inheritance diagram for Trk::RungeKuttaPropagator:
Collaboration diagram for Trk::RungeKuttaPropagator:

Classes

struct  Cache
 

Public Member Functions

 RungeKuttaPropagator (const std::string &, const std::string &, const IInterface *)
 
virtual StatusCode initialize () override final
 
virtual ~RungeKuttaPropagator ()=default
 
virtual std::unique_ptr< NeutralParameterspropagate (const NeutralParameters &, const Surface &, PropDirection, const BoundaryCheck &, bool) const override final
 Main propagation method for NeutralParameters. More...
 
virtual std::unique_ptr< TrackParameterspropagate (const EventContext &ctx, const TrackParameters &, const Surface &, const PropDirection, const BoundaryCheck &, const MagneticFieldProperties &, ParticleHypothesis, bool, const TrackingVolume *) const override final
 Main propagation method without transport jacobian production. More...
 
virtual Trk::MultiComponentState multiStatePropagate (const EventContext &ctx, const MultiComponentState &multiComponentState, const Surface &surface, const MagneticFieldProperties &fieldProperties, const PropDirection direction=Trk::anyDirection, const BoundaryCheck &boundaryCheck=true, const ParticleHypothesis particleHypothesis=nonInteracting) const override final
 Main propagation method for Multi Component state. More...
 
virtual std::unique_ptr< TrackParameterspropagate (const EventContext &ctx, const TrackParameters &, const Surface &, const PropDirection, const BoundaryCheck &, const MagneticFieldProperties &, std::optional< TransportJacobian > &, double &, ParticleHypothesis, bool, const TrackingVolume *) const override final
 Main propagation method with transport jacobian production. More...
 
virtual std::unique_ptr< TrackParameterspropagate (const EventContext &ctx, const TrackParameters &, std::vector< DestSurf > &, PropDirection, const MagneticFieldProperties &, ParticleHypothesis, std::vector< unsigned int > &, double &, bool, bool, const TrackingVolume *) const override final
 The propagation method finds the closest surface. More...
 
virtual std::unique_ptr< TrackParameterspropagateParameters (const EventContext &ctx, const TrackParameters &, const Surface &, const PropDirection, const BoundaryCheck &, const MagneticFieldProperties &, ParticleHypothesis, bool, const TrackingVolume *) const override final
 Main propagation method for parameters only. More...
 
virtual std::unique_ptr< TrackParameterspropagateParameters (const EventContext &ctx, const TrackParameters &, const Surface &, const PropDirection, const BoundaryCheck &, const MagneticFieldProperties &, std::optional< TransportJacobian > &, ParticleHypothesis, bool, const TrackingVolume *) const override final
 Main propagation method for parameters only with transport jacobian production. More...
 
virtual std::optional< Trk::TrackSurfaceIntersectionintersect (const EventContext &ctx, const TrackParameters &, const Surface &, const MagneticFieldProperties &, ParticleHypothesis, const TrackingVolume *tvol=nullptr) const override final
 Global position together with direction of the trajectory on the surface. More...
 
virtual void globalPositions (const EventContext &ctx, std::deque< Amg::Vector3D > &, const TrackParameters &, const MagneticFieldProperties &, const CylinderBounds &, double, ParticleHypothesis, const TrackingVolume *tvol=nullptr) const override final
 GlobalPositions list interface: More...
 
virtual bool propagate (const EventContext &ctx, PatternTrackParameters &, const Surface &, PatternTrackParameters &, PropDirection, const MagneticFieldProperties &, ParticleHypothesis particle=pion) const override final
 Main propagation method. More...
 
virtual bool propagate (const EventContext &ctx, PatternTrackParameters &, const Surface &, PatternTrackParameters &, PropDirection, const MagneticFieldProperties &, double &, ParticleHypothesis particle=pion) const override final
 Main propagation method with step to surface calculation. More...
 
virtual bool propagateParameters (const EventContext &ctx, PatternTrackParameters &, const Surface &, PatternTrackParameters &, PropDirection, const MagneticFieldProperties &, ParticleHypothesis particle=pion) const override final
 Main propagation method for parameters only. More...
 
virtual bool propagateParameters (const EventContext &ctx, PatternTrackParameters &, const Surface &, PatternTrackParameters &, PropDirection, const MagneticFieldProperties &, double &, ParticleHypothesis particle=pion) const override final
 Main propagation method for parameters only with step to surface calculation. More...
 
virtual void globalPositions (const EventContext &ctx, const PatternTrackParameters &, std::vector< const Surface * > &, std::vector< std::pair< Amg::Vector3D, double >> &, const MagneticFieldProperties &, ParticleHypothesis particle=pion) const override final
 
virtual std::unique_ptr< Trk::TrackParameterspropagateT (const EventContext &, const TrackParameters &, std::vector< DestSurf > &, PropDirection, const MagneticFieldProperties &, ParticleHypothesis, std::vector< unsigned int > &, PathLimit &, TimeLimit &, bool, const Trk::TrackingVolume *, std::vector< Trk::HitInfo > *&) const override final
 unimplemented propagateT More...
 
virtual std::unique_ptr< Trk::TrackParameterspropagateM (const EventContext &, const TrackParameters &, std::vector< DestSurf > &, PropDirection, const MagneticFieldProperties &, ParticleHypothesis, std::vector< unsigned int > &, std::vector< const Trk::TrackStateOnSurface * > *&, std::vector< std::pair< std::unique_ptr< Trk::TrackParameters >, int >> *, double &, bool, bool, const Trk::TrackingVolume *, Trk::ExtrapolationCache *) const override final
 unimplemented propagateM More...
 
virtual std::optional< Trk::TrackSurfaceIntersectionintersectSurface (const EventContext &, const Surface &, const TrackSurfaceIntersection &, const double, const MagneticFieldProperties &, ParticleHypothesis) const override final
 unimplemented intersectSurface More...
 
virtual Trk::ExtrapolationCode propagate (const EventContext &, Trk::ExCellCharged &, Trk::TargetSurfaces &, Trk::TargetSurfaceVector &) const override final
 Propagation method needed for StepEngine. More...
 
ServiceHandle< StoreGateSvc > & evtStore ()
 The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc. More...
 
const ServiceHandle< StoreGateSvc > & evtStore () const
 The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc. More...
 
const ServiceHandle< StoreGateSvc > & detStore () const
 The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc. More...
 
virtual StatusCode sysInitialize () override
 Perform system initialization for an algorithm. More...
 
virtual StatusCode sysStart () override
 Handle START transition. More...
 
virtual std::vector< Gaudi::DataHandle * > inputHandles () const override
 Return this algorithm's input handles. More...
 
virtual std::vector< Gaudi::DataHandle * > outputHandles () const override
 Return this algorithm's output handles. More...
 
Gaudi::Details::PropertyBase & declareProperty (Gaudi::Property< T > &t)
 
Gaudi::Details::PropertyBase * declareProperty (const std::string &name, SG::VarHandleKey &hndl, const std::string &doc, const SG::VarHandleKeyType &)
 Declare a new Gaudi property. More...
 
Gaudi::Details::PropertyBase * declareProperty (const std::string &name, SG::VarHandleBase &hndl, const std::string &doc, const SG::VarHandleType &)
 Declare a new Gaudi property. More...
 
Gaudi::Details::PropertyBase * declareProperty (const std::string &name, SG::VarHandleKeyArray &hndArr, const std::string &doc, const SG::VarHandleKeyArrayType &)
 
Gaudi::Details::PropertyBase * declareProperty (const std::string &name, T &property, const std::string &doc, const SG::NotHandleType &)
 Declare a new Gaudi property. More...
 
Gaudi::Details::PropertyBase * declareProperty (const std::string &name, T &property, const std::string &doc="none")
 Declare a new Gaudi property. More...
 
void updateVHKA (Gaudi::Details::PropertyBase &)
 
MsgStream & msg () const
 
MsgStream & msg (const MSG::Level lvl) const
 
bool msgLvl (const MSG::Level lvl) const
 
virtual bool propagate (const ::EventContext &ctx, PatternTrackParameters &, const Surface &, PatternTrackParameters &, PropDirection, const MagneticFieldProperties &, ParticleHypothesis particle=pion) const =0
 Interfaces WITH EventContext (new) More...
 
virtual bool propagate (const ::EventContext &ctx, PatternTrackParameters &, const Surface &, PatternTrackParameters &, PropDirection, const MagneticFieldProperties &, double &, ParticleHypothesis particle=pion) const =0
 Main propagation method with step to surface calculation. More...
 
virtual bool propagateParameters (const ::EventContext &ctx, PatternTrackParameters &, const Surface &, PatternTrackParameters &, PropDirection, const MagneticFieldProperties &, ParticleHypothesis particle=pion) const =0
 Main propagation method for parameters only. More...
 
virtual bool propagateParameters (const ::EventContext &ctx, PatternTrackParameters &, const Surface &, PatternTrackParameters &, PropDirection, const MagneticFieldProperties &, double &, ParticleHypothesis particle=pion) const =0
 Main propagation method for parameters only with step to surface calculation. More...
 
virtual void globalPositions (const ::EventContext &ctx, const PatternTrackParameters &, std::vector< const Surface * > &, std::vector< std::pair< Amg::Vector3D, double > > &, const MagneticFieldProperties &, ParticleHypothesis particle=pion) const =0
 

Static Public Member Functions

static const InterfaceID & interfaceID ()
 AlgTool and IAlgTool interface methods. More...
 
static const InterfaceID & interfaceID ()
 framework method providing the abstract interface More...
 

Protected Member Functions

void renounceArray (SG::VarHandleKeyArray &handlesArray)
 remove all handles from I/O resolution More...
 
std::enable_if_t< std::is_void_v< std::result_of_t< decltype(&T::renounce)(T)> > &&!std::is_base_of_v< SG::VarHandleKeyArray, T > &&std::is_base_of_v< Gaudi::DataHandle, T >, void > renounce (T &h)
 
void extraDeps_update_handler (Gaudi::Details::PropertyBase &ExtraDeps)
 Add StoreName to extra input/output deps as needed. More...
 

Private Types

typedef ServiceHandle< StoreGateSvcStoreGateSvc_t
 

Private Member Functions

Cache getInitializedCache (const EventContext &ctx) const
 
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T > &hndl, const SG::VarHandleKeyType &)
 specialization for handling Gaudi::Property<SG::VarHandleKey> More...
 
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T > &hndl, const SG::VarHandleKeyArrayType &)
 specialization for handling Gaudi::Property<SG::VarHandleKeyArray> More...
 
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T > &hndl, const SG::VarHandleType &)
 specialization for handling Gaudi::Property<SG::VarHandleBase> More...
 
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T > &t, const SG::NotHandleType &)
 specialization for handling everything that's not a Gaudi::Property<SG::VarHandleKey> or a <SG::VarHandleKeyArray> More...
 

Private Attributes

SG::ReadCondHandleKey< AtlasFieldCacheCondObjm_fieldCondObjInputKey
 
double m_dlt
 
double m_helixStep
 
double m_straightStep
 
bool m_usegradient
 
StoreGateSvc_t m_evtStore
 Pointer to StoreGate (event store by default) More...
 
StoreGateSvc_t m_detStore
 Pointer to StoreGate (detector store by default) More...
 
std::vector< SG::VarHandleKeyArray * > m_vhka
 
bool m_varHandleArraysDeclared
 

Detailed Description

Trk::RungeKuttaPropagator is an algorithm for track parameters propagation through magnetic field.

The implementation performs the propagation in global coordinates and uses Jacobian matrices (see RungeKuttaUtils) for the transformations between the global frame and local surface-attached coordinate systems.

One can choose to perform the transport of the parameters only and omit the transport of the associated covariances (propagateParameters).

The algorithm can produce the Jacobian that transports the covariance matrix from one set of track parameters at the initial surface to another set of track parameters at the destination surface. This is useful for Chi2 fitting.

It does NOT include material effects (unlike the STEP propagator). As a result the ParticleHypothesis argument is not really used. It is assumed that in the client code , the propagation, transport of the track parameters and their associated covariances, is decoupled from the actual corrections due to interaction with the detector material.

The algorithm contains three steps :

1.The first step of the algorithm is track parameters transformation from local presentation for given start surface to global Runge Kutta coordinates.

2.The second step is propagation through the magnetic field with or without jacobian.

3.Third step is transformation from global Runge Kutta presentation to local presentation of given output surface.

AtaPlane AtaStraightLine AtaDisc AtaCylinder Perigee | | | | | | | | | |

V V V V V

| Local->Global transformation V Global position (Runge Kutta presentation) | | Propagation to next surface with or without jacobian using Nystroem algorithm (See Handbook Net. Bur. of Standards, procedure 25.5.20) |

V Global->Local transformation

| | | | | | | | | | V V V V V PlaneSurface StraightLineSurface DiscSurface CylinderSurface PerigeeSurface

For propagation using Runge Kutta method we use global coordinates, direction, inverse momentum and Jacobian of transformation. All these parameters we save in an array P[42]

/dL0 /dL1 /dPhi /dThe /dCM X ->P[0] dX / P[ 7] P[14] P[21] P[28] P[35] Y ->P[1] dY / P[ 8] P[15] P[22] P[29] P[36] Z ->P[2] dZ / P[ 9] P[16] P[23] P[30] P[37] Ax ->P[3] dAx/ P[10] P[17] P[24] P[31] P[38] Ay ->P[4] dAy/ P[11] P[18] P[25] P[32] P[39] Az ->P[5] dAz/ P[12] P[19] P[26] P[33] P[40] CM ->P[6] dCM/ P[13] P[20] P[27] P[34] P[41]

where in case of local re-presentation

L0 - first local coordinate (surface dependent) L1 - second local coordinate (surface dependent) Phi - Azimuthal angle The - Polar angle CM - charge/momentum

in case of global re-presentation

X - global x-coordinate = surface dependent Y - global y-coordinate = surface dependent Z - global z-coordinate = sutface dependent Ax - direction cosine to x-axis = Sin(The)*Cos(Phi) Ay - direction cosine to y-axis = Sin(The)*Sin(Phi) Az - direction cosine to z-axis = Cos(The) CM - charge/momentum = local CM

Author
Igor..nosp@m.Gavr.nosp@m.ilenk.nosp@m.o@ce.nosp@m.rn.ch
Authors
RD Schaffer C Anastopoulos AthenaMT modifications

Definition at line 130 of file RungeKuttaPropagator.h.

Member Typedef Documentation

◆ StoreGateSvc_t

typedef ServiceHandle<StoreGateSvc> AthCommonDataStore< AthCommonMsg< AlgTool > >::StoreGateSvc_t
privateinherited

Definition at line 388 of file AthCommonDataStore.h.

Constructor & Destructor Documentation

◆ RungeKuttaPropagator()

Trk::RungeKuttaPropagator::RungeKuttaPropagator ( const std::string &  p,
const std::string &  n,
const IInterface *  t 
)

Definition at line 1380 of file RungeKuttaPropagator.cxx.

1383  : AthAlgTool(p, n, t),
1384  m_dlt(.000200),
1385  m_helixStep(1.),
1386  m_straightStep(.01),
1387  m_usegradient(false) {
1388 
1389  declareInterface<Trk::IPropagator>(this);
1390  declareInterface<Trk::IPatternParametersPropagator>(this);
1391  declareProperty("AccuracyParameter", m_dlt);
1392  declareProperty("MaxHelixStep", m_helixStep);
1393  declareProperty("MaxStraightLineStep", m_straightStep);
1394  declareProperty("IncludeBgradients", m_usegradient);
1395 }

◆ ~RungeKuttaPropagator()

virtual Trk::RungeKuttaPropagator::~RungeKuttaPropagator ( )
virtualdefault

Member Function Documentation

◆ declareGaudiProperty() [1/4]

Gaudi::Details::PropertyBase& AthCommonDataStore< AthCommonMsg< AlgTool > >::declareGaudiProperty ( Gaudi::Property< T > &  hndl,
const SG::VarHandleKeyArrayType  
)
inlineprivateinherited

specialization for handling Gaudi::Property<SG::VarHandleKeyArray>

Definition at line 170 of file AthCommonDataStore.h.

172  {
173  return *AthCommonDataStore<PBASE>::declareProperty(hndl.name(),
174  hndl.value(),
175  hndl.documentation());
176 
177  }

◆ declareGaudiProperty() [2/4]

Gaudi::Details::PropertyBase& AthCommonDataStore< AthCommonMsg< AlgTool > >::declareGaudiProperty ( Gaudi::Property< T > &  hndl,
const SG::VarHandleKeyType  
)
inlineprivateinherited

specialization for handling Gaudi::Property<SG::VarHandleKey>

Definition at line 156 of file AthCommonDataStore.h.

158  {
159  return *AthCommonDataStore<PBASE>::declareProperty(hndl.name(),
160  hndl.value(),
161  hndl.documentation());
162 
163  }

◆ declareGaudiProperty() [3/4]

Gaudi::Details::PropertyBase& AthCommonDataStore< AthCommonMsg< AlgTool > >::declareGaudiProperty ( Gaudi::Property< T > &  hndl,
const SG::VarHandleType  
)
inlineprivateinherited

specialization for handling Gaudi::Property<SG::VarHandleBase>

Definition at line 184 of file AthCommonDataStore.h.

186  {
187  return *AthCommonDataStore<PBASE>::declareProperty(hndl.name(),
188  hndl.value(),
189  hndl.documentation());
190  }

◆ declareGaudiProperty() [4/4]

Gaudi::Details::PropertyBase& AthCommonDataStore< AthCommonMsg< AlgTool > >::declareGaudiProperty ( Gaudi::Property< T > &  t,
const SG::NotHandleType  
)
inlineprivateinherited

specialization for handling everything that's not a Gaudi::Property<SG::VarHandleKey> or a <SG::VarHandleKeyArray>

Definition at line 199 of file AthCommonDataStore.h.

200  {
201  return PBASE::declareProperty(t);
202  }

◆ declareProperty() [1/6]

Gaudi::Details::PropertyBase* AthCommonDataStore< AthCommonMsg< AlgTool > >::declareProperty ( const std::string &  name,
SG::VarHandleBase hndl,
const std::string &  doc,
const SG::VarHandleType  
)
inlineinherited

Declare a new Gaudi property.

Parameters
nameName of the property.
hndlObject holding the property value.
docDocumentation string for the property.

This is the version for types that derive from SG::VarHandleBase. The property value object is put on the input and output lists as appropriate; then we forward to the base class.

Definition at line 245 of file AthCommonDataStore.h.

249  {
250  this->declare(hndl.vhKey());
251  hndl.vhKey().setOwner(this);
252 
253  return PBASE::declareProperty(name,hndl,doc);
254  }

◆ declareProperty() [2/6]

Gaudi::Details::PropertyBase* AthCommonDataStore< AthCommonMsg< AlgTool > >::declareProperty ( const std::string &  name,
SG::VarHandleKey hndl,
const std::string &  doc,
const SG::VarHandleKeyType  
)
inlineinherited

Declare a new Gaudi property.

Parameters
nameName of the property.
hndlObject holding the property value.
docDocumentation string for the property.

This is the version for types that derive from SG::VarHandleKey. The property value object is put on the input and output lists as appropriate; then we forward to the base class.

Definition at line 221 of file AthCommonDataStore.h.

225  {
226  this->declare(hndl);
227  hndl.setOwner(this);
228 
229  return PBASE::declareProperty(name,hndl,doc);
230  }

◆ declareProperty() [3/6]

Gaudi::Details::PropertyBase* AthCommonDataStore< AthCommonMsg< AlgTool > >::declareProperty ( const std::string &  name,
SG::VarHandleKeyArray hndArr,
const std::string &  doc,
const SG::VarHandleKeyArrayType  
)
inlineinherited

Definition at line 259 of file AthCommonDataStore.h.

263  {
264 
265  // std::ostringstream ost;
266  // ost << Algorithm::name() << " VHKA declareProp: " << name
267  // << " size: " << hndArr.keys().size()
268  // << " mode: " << hndArr.mode()
269  // << " vhka size: " << m_vhka.size()
270  // << "\n";
271  // debug() << ost.str() << endmsg;
272 
273  hndArr.setOwner(this);
274  m_vhka.push_back(&hndArr);
275 
276  Gaudi::Details::PropertyBase* p = PBASE::declareProperty(name, hndArr, doc);
277  if (p != 0) {
278  p->declareUpdateHandler(&AthCommonDataStore<PBASE>::updateVHKA, this);
279  } else {
280  ATH_MSG_ERROR("unable to call declareProperty on VarHandleKeyArray "
281  << name);
282  }
283 
284  return p;
285 
286  }

◆ declareProperty() [4/6]

Gaudi::Details::PropertyBase* AthCommonDataStore< AthCommonMsg< AlgTool > >::declareProperty ( const std::string &  name,
T &  property,
const std::string &  doc,
const SG::NotHandleType  
)
inlineinherited

Declare a new Gaudi property.

Parameters
nameName of the property.
propertyObject holding the property value.
docDocumentation string for the property.

This is the generic version, for types that do not derive from SG::VarHandleKey. It just forwards to the base class version of declareProperty.

Definition at line 333 of file AthCommonDataStore.h.

337  {
338  return PBASE::declareProperty(name, property, doc);
339  }

◆ declareProperty() [5/6]

Gaudi::Details::PropertyBase* AthCommonDataStore< AthCommonMsg< AlgTool > >::declareProperty ( const std::string &  name,
T &  property,
const std::string &  doc = "none" 
)
inlineinherited

Declare a new Gaudi property.

Parameters
nameName of the property.
propertyObject holding the property value.
docDocumentation string for the property.

This dispatches to either the generic declareProperty or the one for VarHandle/Key/KeyArray.

Definition at line 352 of file AthCommonDataStore.h.

355  {
356  typedef typename SG::HandleClassifier<T>::type htype;
357  return declareProperty (name, property, doc, htype());
358  }

◆ declareProperty() [6/6]

Gaudi::Details::PropertyBase& AthCommonDataStore< AthCommonMsg< AlgTool > >::declareProperty ( Gaudi::Property< T > &  t)
inlineinherited

Definition at line 145 of file AthCommonDataStore.h.

145  {
146  typedef typename SG::HandleClassifier<T>::type htype;
148  }

◆ detStore()

const ServiceHandle<StoreGateSvc>& AthCommonDataStore< AthCommonMsg< AlgTool > >::detStore ( ) const
inlineinherited

The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.

Definition at line 95 of file AthCommonDataStore.h.

95 { return m_detStore; }

◆ evtStore() [1/2]

ServiceHandle<StoreGateSvc>& AthCommonDataStore< AthCommonMsg< AlgTool > >::evtStore ( )
inlineinherited

The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.

Definition at line 85 of file AthCommonDataStore.h.

85 { return m_evtStore; }

◆ evtStore() [2/2]

const ServiceHandle<StoreGateSvc>& AthCommonDataStore< AthCommonMsg< AlgTool > >::evtStore ( ) const
inlineinherited

The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.

Definition at line 90 of file AthCommonDataStore.h.

90 { return m_evtStore; }

◆ extraDeps_update_handler()

void AthCommonDataStore< AthCommonMsg< AlgTool > >::extraDeps_update_handler ( Gaudi::Details::PropertyBase &  ExtraDeps)
protectedinherited

Add StoreName to extra input/output deps as needed.

use the logic of the VarHandleKey to parse the DataObjID keys supplied via the ExtraInputs and ExtraOuputs Properties to add the StoreName if it's not explicitly given

◆ getInitializedCache()

Cache Trk::RungeKuttaPropagator::getInitializedCache ( const EventContext &  ctx) const
private

Definition at line 1922 of file RungeKuttaPropagator.cxx.

1923 {
1925  ctx};
1926  const AtlasFieldCacheCondObj* fieldCondObj{*readHandle};
1927  Cache cache{};
1928  fieldCondObj->getInitializedCache(cache.m_fieldCache);
1929  cache.m_dlt = m_dlt;
1930  cache.m_helixStep = m_helixStep;
1931  cache.m_straightStep = m_straightStep;
1932  cache.m_usegradient = m_usegradient;
1933  return cache;
1934 }

◆ globalPositions() [1/3]

virtual void Trk::IPatternParametersPropagator::globalPositions ( const ::EventContext &  ctx,
const PatternTrackParameters ,
std::vector< const Surface * > &  ,
std::vector< std::pair< Amg::Vector3D, double > > &  ,
const MagneticFieldProperties ,
ParticleHypothesis  particle = pion 
) const
pure virtualinherited

◆ globalPositions() [2/3]

virtual void Trk::RungeKuttaPropagator::globalPositions ( const EventContext &  ctx,
const PatternTrackParameters ,
std::vector< const Surface * > &  ,
std::vector< std::pair< Amg::Vector3D, double >> &  ,
const MagneticFieldProperties ,
ParticleHypothesis  particle = pion 
) const
finaloverridevirtual

◆ globalPositions() [3/3]

virtual void Trk::RungeKuttaPropagator::globalPositions ( const EventContext &  ctx,
std::deque< Amg::Vector3D > &  ,
const TrackParameters ,
const MagneticFieldProperties ,
const CylinderBounds ,
double  ,
ParticleHypothesis  ,
const TrackingVolume tvol = nullptr 
) const
finaloverridevirtual

GlobalPositions list interface:

Implements Trk::IPropagator.

◆ initialize()

StatusCode Trk::RungeKuttaPropagator::initialize ( )
finaloverridevirtual

Definition at line 1398 of file RungeKuttaPropagator.cxx.

1399 {
1400  // Read handle for AtlasFieldCacheCondObj
1402  ATH_MSG_DEBUG("initialize() init key: " << m_fieldCondObjInputKey.key());
1403  return StatusCode::SUCCESS;
1404 }

◆ inputHandles()

virtual std::vector<Gaudi::DataHandle*> AthCommonDataStore< AthCommonMsg< AlgTool > >::inputHandles ( ) const
overridevirtualinherited

Return this algorithm's input handles.

We override this to include handle instances from key arrays if they have not yet been declared. See comments on updateVHKA.

◆ interfaceID() [1/2]

const InterfaceID & Trk::IPatternParametersPropagator::interfaceID ( )
inlinestaticinherited

framework method providing the abstract interface

Definition at line 107 of file IPatternParametersPropagator.h.

108 {
109  return IID_IPatternParametersPropagator;
110 }

◆ interfaceID() [2/2]

static const InterfaceID& Trk::IPropagator::interfaceID ( )
inlinestaticinherited

AlgTool and IAlgTool interface methods.

Definition at line 61 of file IPropagator.h.

61 { return IID_IPropagator; }

◆ intersect()

std::optional< Trk::TrackSurfaceIntersection > Trk::RungeKuttaPropagator::intersect ( const EventContext &  ctx,
const TrackParameters ,
const Surface ,
const MagneticFieldProperties ,
ParticleHypothesis  ,
const TrackingVolume tvol = nullptr 
) const
finaloverridevirtual

Global position together with direction of the trajectory on the surface.

Implements Trk::IPropagator.

Definition at line 1804 of file RungeKuttaPropagator.cxx.

1810 {
1811  bool nJ = false;
1812  const Trk::Surface* su = &Su;
1813  Cache cache = getInitializedCache(ctx);
1814  cache.m_direction = 0.;
1815  cache.m_needgradient = false;
1816 
1817  M.magneticFieldMode() == Trk::FastField ? cache.m_solenoid = true : cache.m_solenoid = false;
1818  M.magneticFieldMode() != Trk::NoField ? cache.m_mcondition = true : cache.m_mcondition = false;
1819 
1820  double P[64];
1822  return std::nullopt;
1823  }
1824  double Step = 0.;
1825  if (!propagateWithJacobianSwitch(cache, (*su), nJ, P, Step)) {
1826  return std::nullopt;
1827  }
1828 
1829  const Amg::Vector3D Glo(P[0], P[1], P[2]);
1830  const Amg::Vector3D Dir(P[3], P[4], P[5]);
1831  return std::make_optional<Trk::TrackSurfaceIntersection>(Glo, Dir, Step);
1832 }

◆ intersectSurface()

virtual std::optional<Trk::TrackSurfaceIntersection> Trk::RungeKuttaPropagator::intersectSurface ( const EventContext &  ,
const Surface ,
const TrackSurfaceIntersection ,
const double  ,
const MagneticFieldProperties ,
ParticleHypothesis   
) const
inlinefinaloverridevirtual

unimplemented intersectSurface

Implements Trk::IPropagator.

Definition at line 346 of file RungeKuttaPropagator.h.

353  {
354  ATH_MSG_ERROR("Call to non-implemented intersectSurface");
355  return std::nullopt;
356  }

◆ msg() [1/2]

MsgStream& AthCommonMsg< AlgTool >::msg ( ) const
inlineinherited

Definition at line 24 of file AthCommonMsg.h.

24  {
25  return this->msgStream();
26  }

◆ msg() [2/2]

MsgStream& AthCommonMsg< AlgTool >::msg ( const MSG::Level  lvl) const
inlineinherited

Definition at line 27 of file AthCommonMsg.h.

27  {
28  return this->msgStream(lvl);
29  }

◆ msgLvl()

bool AthCommonMsg< AlgTool >::msgLvl ( const MSG::Level  lvl) const
inlineinherited

Definition at line 30 of file AthCommonMsg.h.

30  {
31  return this->msgLevel(lvl);
32  }

◆ multiStatePropagate()

Trk::MultiComponentState Trk::RungeKuttaPropagator::multiStatePropagate ( const EventContext &  ctx,
const MultiComponentState multiComponentState,
const Surface surface,
const MagneticFieldProperties fieldProperties,
const PropDirection  direction = Trk::anyDirection,
const BoundaryCheck boundaryCheck = true,
const ParticleHypothesis  particleHypothesis = nonInteracting 
) const
finaloverridevirtual

Main propagation method for Multi Component state.

Implements Trk::IPropagator.

Definition at line 1449 of file RungeKuttaPropagator.cxx.

1457 {
1458  Cache cache = getInitializedCache(ctx);
1459 
1460  Trk::MultiComponentState propagatedState{};
1461  propagatedState.reserve(multiComponentState.size());
1462  double sumw(0); // sum of the weights of the propagated parameters
1463  double J[25];
1464  Trk::MultiComponentState::const_iterator component =
1465  multiComponentState.begin();
1466  for (; component != multiComponentState.end(); ++component) {
1467  const Trk::TrackParameters* currentParameters = component->params.get();
1468  if (!currentParameters) {
1469  continue;
1470  }
1471  auto propagatedParameters =
1472  propagateRungeKutta(cache, true, *currentParameters, surface, direction,
1473  boundaryCheck, fieldProperties, J, false);
1474 
1475  if (!propagatedParameters) {
1476  continue;
1477  }
1478  sumw += component->weight;
1479  // Propagation does not affect the weightings of the states
1480  propagatedState.push_back({std::move(propagatedParameters),
1481  component->weight});
1482  }
1483  // Protect low weight propagation
1484  constexpr double minPropWeight = (1./12.);
1485  if (sumw < minPropWeight) {
1486  propagatedState.clear();
1487  }
1488  return propagatedState;
1489 }

◆ outputHandles()

virtual std::vector<Gaudi::DataHandle*> AthCommonDataStore< AthCommonMsg< AlgTool > >::outputHandles ( ) const
overridevirtualinherited

Return this algorithm's output handles.

We override this to include handle instances from key arrays if they have not yet been declared. See comments on updateVHKA.

◆ propagate() [1/9]

virtual bool Trk::IPatternParametersPropagator::propagate ( const ::EventContext &  ctx,
PatternTrackParameters ,
const Surface ,
PatternTrackParameters ,
PropDirection  ,
const MagneticFieldProperties ,
double &  ,
ParticleHypothesis  particle = pion 
) const
pure virtualinherited

Main propagation method with step to surface calculation.

◆ propagate() [2/9]

virtual bool Trk::IPatternParametersPropagator::propagate ( const ::EventContext &  ctx,
PatternTrackParameters ,
const Surface ,
PatternTrackParameters ,
PropDirection  ,
const MagneticFieldProperties ,
ParticleHypothesis  particle = pion 
) const
pure virtualinherited

Interfaces WITH EventContext (new)

Main propagation method

◆ propagate() [3/9]

virtual Trk::ExtrapolationCode Trk::RungeKuttaPropagator::propagate ( const EventContext &  ctx,
Trk::ExCellCharged eCell,
Trk::TargetSurfaces sfs,
Trk::TargetSurfaceVector solutions 
) const
inlinefinaloverridevirtual

Propagation method needed for StepEngine.

Implements Trk::IPropagator.

Definition at line 358 of file RungeKuttaPropagator.h.

363  {
365  }

◆ propagate() [4/9]

virtual std::unique_ptr<TrackParameters> Trk::RungeKuttaPropagator::propagate ( const EventContext &  ctx,
const TrackParameters ,
const Surface ,
const  PropDirection,
const BoundaryCheck ,
const MagneticFieldProperties ,
ParticleHypothesis  ,
bool  ,
const TrackingVolume  
) const
finaloverridevirtual

Main propagation method without transport jacobian production.

Implements Trk::IPropagator.

◆ propagate() [5/9]

virtual std::unique_ptr<TrackParameters> Trk::RungeKuttaPropagator::propagate ( const EventContext &  ctx,
const TrackParameters ,
const Surface ,
const  PropDirection,
const BoundaryCheck ,
const MagneticFieldProperties ,
std::optional< TransportJacobian > &  ,
double &  ,
ParticleHypothesis  ,
bool  ,
const TrackingVolume  
) const
finaloverridevirtual

Main propagation method with transport jacobian production.

Implements Trk::IPropagator.

◆ propagate() [6/9]

virtual std::unique_ptr<TrackParameters> Trk::RungeKuttaPropagator::propagate ( const EventContext &  ctx,
const TrackParameters ,
std::vector< DestSurf > &  ,
PropDirection  ,
const MagneticFieldProperties ,
ParticleHypothesis  ,
std::vector< unsigned int > &  ,
double &  ,
bool  ,
bool  ,
const TrackingVolume  
) const
finaloverridevirtual

The propagation method finds the closest surface.

Implements Trk::IPropagator.

◆ propagate() [7/9]

virtual bool Trk::RungeKuttaPropagator::propagate ( const EventContext &  ctx,
PatternTrackParameters ,
const Surface ,
PatternTrackParameters ,
PropDirection  ,
const MagneticFieldProperties ,
double &  ,
ParticleHypothesis  particle = pion 
) const
finaloverridevirtual

Main propagation method with step to surface calculation.

◆ propagate() [8/9]

virtual bool Trk::RungeKuttaPropagator::propagate ( const EventContext &  ctx,
PatternTrackParameters ,
const Surface ,
PatternTrackParameters ,
PropDirection  ,
const MagneticFieldProperties ,
ParticleHypothesis  particle = pion 
) const
finaloverridevirtual

Main propagation method.

◆ propagate() [9/9]

std::unique_ptr< Trk::NeutralParameters > Trk::RungeKuttaPropagator::propagate ( const NeutralParameters Tp,
const Surface Su,
Trk::PropDirection  D,
const BoundaryCheck B,
bool  returnCurv 
) const
finaloverridevirtual

Main propagation method for NeutralParameters.

Implements Trk::IPropagator.

Definition at line 1410 of file RungeKuttaPropagator.cxx.

1415 {
1416  double J[25];
1417  Cache cache{};
1418  cache.m_dlt = m_dlt;
1419  cache.m_helixStep = m_helixStep;
1420  cache.m_straightStep = m_straightStep;
1421  cache.m_usegradient = m_usegradient;
1422  return propagateStraightLine(cache, true, Tp, Su, D, B, J, returnCurv);
1423 }

◆ propagateM()

virtual std::unique_ptr<Trk::TrackParameters> Trk::RungeKuttaPropagator::propagateM ( const EventContext &  ,
const TrackParameters ,
std::vector< DestSurf > &  ,
PropDirection  ,
const MagneticFieldProperties ,
ParticleHypothesis  ,
std::vector< unsigned int > &  ,
std::vector< const Trk::TrackStateOnSurface * > *&  ,
std::vector< std::pair< std::unique_ptr< Trk::TrackParameters >, int >> *  ,
double &  ,
bool  ,
bool  ,
const Trk::TrackingVolume ,
Trk::ExtrapolationCache  
) const
inlinefinaloverridevirtual

unimplemented propagateM

Implements Trk::IPropagator.

Definition at line 325 of file RungeKuttaPropagator.h.

340  {
341  ATH_MSG_ERROR("Call to non-implemented propagateM");
342  return nullptr;
343  }

◆ propagateParameters() [1/6]

virtual bool Trk::IPatternParametersPropagator::propagateParameters ( const ::EventContext &  ctx,
PatternTrackParameters ,
const Surface ,
PatternTrackParameters ,
PropDirection  ,
const MagneticFieldProperties ,
double &  ,
ParticleHypothesis  particle = pion 
) const
pure virtualinherited

Main propagation method for parameters only with step to surface calculation.

◆ propagateParameters() [2/6]

virtual bool Trk::IPatternParametersPropagator::propagateParameters ( const ::EventContext &  ctx,
PatternTrackParameters ,
const Surface ,
PatternTrackParameters ,
PropDirection  ,
const MagneticFieldProperties ,
ParticleHypothesis  particle = pion 
) const
pure virtualinherited

Main propagation method for parameters only.

◆ propagateParameters() [3/6]

virtual std::unique_ptr<TrackParameters> Trk::RungeKuttaPropagator::propagateParameters ( const EventContext &  ctx,
const TrackParameters ,
const Surface ,
const  PropDirection,
const BoundaryCheck ,
const MagneticFieldProperties ,
ParticleHypothesis  ,
bool  ,
const TrackingVolume  
) const
finaloverridevirtual

Main propagation method for parameters only.

Without transport jacobian production

Implements Trk::IPropagator.

◆ propagateParameters() [4/6]

virtual std::unique_ptr<TrackParameters> Trk::RungeKuttaPropagator::propagateParameters ( const EventContext &  ctx,
const TrackParameters ,
const Surface ,
const  PropDirection,
const BoundaryCheck ,
const MagneticFieldProperties ,
std::optional< TransportJacobian > &  ,
ParticleHypothesis  ,
bool  ,
const TrackingVolume  
) const
finaloverridevirtual

Main propagation method for parameters only with transport jacobian production.

Implements Trk::IPropagator.

◆ propagateParameters() [5/6]

virtual bool Trk::RungeKuttaPropagator::propagateParameters ( const EventContext &  ctx,
PatternTrackParameters ,
const Surface ,
PatternTrackParameters ,
PropDirection  ,
const MagneticFieldProperties ,
double &  ,
ParticleHypothesis  particle = pion 
) const
finaloverridevirtual

Main propagation method for parameters only with step to surface calculation.

◆ propagateParameters() [6/6]

virtual bool Trk::RungeKuttaPropagator::propagateParameters ( const EventContext &  ctx,
PatternTrackParameters ,
const Surface ,
PatternTrackParameters ,
PropDirection  ,
const MagneticFieldProperties ,
ParticleHypothesis  particle = pion 
) const
finaloverridevirtual

Main propagation method for parameters only.

◆ propagateT()

virtual std::unique_ptr<Trk::TrackParameters> Trk::RungeKuttaPropagator::propagateT ( const EventContext &  ,
const TrackParameters ,
std::vector< DestSurf > &  ,
PropDirection  ,
const MagneticFieldProperties ,
ParticleHypothesis  ,
std::vector< unsigned int > &  ,
PathLimit ,
TimeLimit ,
bool  ,
const Trk::TrackingVolume ,
std::vector< Trk::HitInfo > *&   
) const
inlinefinaloverridevirtual

unimplemented propagateT

Implements Trk::IPropagator.

Definition at line 306 of file RungeKuttaPropagator.h.

319  {
320  ATH_MSG_ERROR("Call to non-implemented propagateT");
321  return nullptr;
322  }

◆ renounce()

std::enable_if_t<std::is_void_v<std::result_of_t<decltype(&T::renounce)(T)> > && !std::is_base_of_v<SG::VarHandleKeyArray, T> && std::is_base_of_v<Gaudi::DataHandle, T>, void> AthCommonDataStore< AthCommonMsg< AlgTool > >::renounce ( T &  h)
inlineprotectedinherited

Definition at line 380 of file AthCommonDataStore.h.

381  {
382  h.renounce();
383  PBASE::renounce (h);
384  }

◆ renounceArray()

void AthCommonDataStore< AthCommonMsg< AlgTool > >::renounceArray ( SG::VarHandleKeyArray handlesArray)
inlineprotectedinherited

remove all handles from I/O resolution

Definition at line 364 of file AthCommonDataStore.h.

364  {
365  handlesArray.renounce();
366  }

◆ sysInitialize()

virtual StatusCode AthCommonDataStore< AthCommonMsg< AlgTool > >::sysInitialize ( )
overridevirtualinherited

Perform system initialization for an algorithm.

We override this to declare all the elements of handle key arrays at the end of initialization. See comments on updateVHKA.

Reimplemented in DerivationFramework::CfAthAlgTool, AthCheckedComponent< AthAlgTool >, AthCheckedComponent<::AthAlgTool >, and asg::AsgMetadataTool.

◆ sysStart()

virtual StatusCode AthCommonDataStore< AthCommonMsg< AlgTool > >::sysStart ( )
overridevirtualinherited

Handle START transition.

We override this in order to make sure that conditions handle keys can cache a pointer to the conditions container.

◆ updateVHKA()

void AthCommonDataStore< AthCommonMsg< AlgTool > >::updateVHKA ( Gaudi::Details::PropertyBase &  )
inlineinherited

Definition at line 308 of file AthCommonDataStore.h.

308  {
309  // debug() << "updateVHKA for property " << p.name() << " " << p.toString()
310  // << " size: " << m_vhka.size() << endmsg;
311  for (auto &a : m_vhka) {
312  std::vector<SG::VarHandleKey*> keys = a->keys();
313  for (auto k : keys) {
314  k->setOwner(this);
315  }
316  }
317  }

Member Data Documentation

◆ m_detStore

StoreGateSvc_t AthCommonDataStore< AthCommonMsg< AlgTool > >::m_detStore
privateinherited

Pointer to StoreGate (detector store by default)

Definition at line 393 of file AthCommonDataStore.h.

◆ m_dlt

double Trk::RungeKuttaPropagator::m_dlt
private

Definition at line 403 of file RungeKuttaPropagator.h.

◆ m_evtStore

StoreGateSvc_t AthCommonDataStore< AthCommonMsg< AlgTool > >::m_evtStore
privateinherited

Pointer to StoreGate (event store by default)

Definition at line 390 of file AthCommonDataStore.h.

◆ m_fieldCondObjInputKey

SG::ReadCondHandleKey<AtlasFieldCacheCondObj> Trk::RungeKuttaPropagator::m_fieldCondObjInputKey
private
Initial value:
{
this,
"AtlasFieldCacheCondObj",
"fieldCondObj",
"Name of the Magnetic Field conditions object key"
}

Definition at line 396 of file RungeKuttaPropagator.h.

◆ m_helixStep

double Trk::RungeKuttaPropagator::m_helixStep
private

Definition at line 404 of file RungeKuttaPropagator.h.

◆ m_straightStep

double Trk::RungeKuttaPropagator::m_straightStep
private

Definition at line 405 of file RungeKuttaPropagator.h.

◆ m_usegradient

bool Trk::RungeKuttaPropagator::m_usegradient
private

Definition at line 406 of file RungeKuttaPropagator.h.

◆ m_varHandleArraysDeclared

bool AthCommonDataStore< AthCommonMsg< AlgTool > >::m_varHandleArraysDeclared
privateinherited

Definition at line 399 of file AthCommonDataStore.h.

◆ m_vhka

std::vector<SG::VarHandleKeyArray*> AthCommonDataStore< AthCommonMsg< AlgTool > >::m_vhka
privateinherited

Definition at line 398 of file AthCommonDataStore.h.


The documentation for this class was generated from the following files:
SG::ReadCondHandle
Definition: ReadCondHandle.h:44
AtlasFieldCacheCondObj
Definition: AtlasFieldCacheCondObj.h:19
AthCommonDataStore< AthCommonMsg< AlgTool > >::declareProperty
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T > &t)
Definition: AthCommonDataStore.h:145
DMTest::P
P_v1 P
Definition: P.h:23
AthCommonDataStore< AthCommonMsg< AlgTool > >::m_evtStore
StoreGateSvc_t m_evtStore
Pointer to StoreGate (event store by default)
Definition: AthCommonDataStore.h:390
AthCommonDataStore< AthCommonMsg< AlgTool > >::m_vhka
std::vector< SG::VarHandleKeyArray * > m_vhka
Definition: AthCommonDataStore.h:398
read_hist_ntuple.t
t
Definition: read_hist_ntuple.py:5
plotBeamSpotVxVal.sumw
int sumw
Definition: plotBeamSpotVxVal.py:236
SG::VarHandleKey::key
const std::string & key() const
Return the StoreGate ID for the referenced object.
Definition: AthToolSupport/AsgDataHandles/Root/VarHandleKey.cxx:141
Trk::RungeKuttaUtils::transformLocalToGlobal
bool transformLocalToGlobal(bool, const Trk::TrackParameters &, double *ATH_RESTRICT)
SG::VarHandleKeyArray::setOwner
virtual void setOwner(IDataHandleHolder *o)=0
IDTPMcnv.htype
htype
Definition: IDTPMcnv.py:29
Trk::FastField
@ FastField
call the fast field access method of the FieldSvc
Definition: MagneticFieldMode.h:20
AtlasFieldCacheCondObj::getInitializedCache
void getInitializedCache(MagField::AtlasFieldCache &cache) const
get B field cache for evaluation as a function of 2-d or 3-d position.
Definition: AtlasFieldCacheCondObj.h:32
python.utils.AtlRunQueryDQUtils.p
p
Definition: AtlRunQueryDQUtils.py:210
AthCommonDataStore
Definition: AthCommonDataStore.h:52
ATH_MSG_ERROR
#define ATH_MSG_ERROR(x)
Definition: AthMsgStreamMacros.h:33
beamspotman.n
n
Definition: beamspotman.py:731
ATH_MSG_DEBUG
#define ATH_MSG_DEBUG(x)
Definition: AthMsgStreamMacros.h:29
Trk::MultiComponentState
std::vector< ComponentParameters > MultiComponentState
Definition: ComponentParameters.h:27
ATH_CHECK
#define ATH_CHECK
Definition: AthCheckMacros.h:40
AthCommonDataStore< AthCommonMsg< AlgTool > >::m_detStore
StoreGateSvc_t m_detStore
Pointer to StoreGate (detector store by default)
Definition: AthCommonDataStore.h:393
Trk::ParametersBase
Definition: ParametersBase.h:55
AthAlgTool::AthAlgTool
AthAlgTool()
Default constructor:
SG::VarHandleKeyArray::renounce
virtual void renounce()=0
SG::HandleClassifier::type
std::conditional< std::is_base_of< SG::VarHandleKeyArray, T >::value, VarHandleKeyArrayType, type2 >::type type
Definition: HandleClassifier.h:54
Trk::NoField
@ NoField
Field is set to 0., 0., 0.,.
Definition: MagneticFieldMode.h:18
Trk::RungeKuttaPropagator::m_usegradient
bool m_usegradient
Definition: RungeKuttaPropagator.h:406
merge_scale_histograms.doc
string doc
Definition: merge_scale_histograms.py:9
name
std::string name
Definition: Control/AthContainers/Root/debug.cxx:228
SG::CondHandleKey::initialize
StatusCode initialize(bool used=true)
Trk::RungeKuttaPropagator::m_straightStep
double m_straightStep
Definition: RungeKuttaPropagator.h:405
Amg::Vector3D
Eigen::Matrix< double, 3, 1 > Vector3D
Definition: GeoPrimitives.h:47
Trk::ExtrapolationCode::FailureConfiguration
@ FailureConfiguration
Definition: ExtrapolationCell.h:124
Trk::RungeKuttaPropagator::m_dlt
double m_dlt
Definition: RungeKuttaPropagator.h:403
Trk::RungeKuttaPropagator::m_helixStep
double m_helixStep
Definition: RungeKuttaPropagator.h:404
Trk::RungeKuttaPropagator::m_fieldCondObjInputKey
SG::ReadCondHandleKey< AtlasFieldCacheCondObj > m_fieldCondObjInputKey
Definition: RungeKuttaPropagator.h:396
a
TList * a
Definition: liststreamerinfos.cxx:10
h
SG::VarHandleBase::vhKey
SG::VarHandleKey & vhKey()
Return a non-const reference to the HandleKey.
Definition: StoreGate/src/VarHandleBase.cxx:623
python.Bindings.keys
keys
Definition: Control/AthenaPython/python/Bindings.py:798
Trk::Surface
Definition: Tracking/TrkDetDescr/TrkSurfaces/TrkSurfaces/Surface.h:75
python.exampleDriverScript.Dir
Dir
Definition: exampleDriverScript.py:20
AthCommonDataStore::declareGaudiProperty
Gaudi::Details::PropertyBase & declareGaudiProperty(Gaudi::Property< T > &hndl, const SG::VarHandleKeyType &)
specialization for handling Gaudi::Property<SG::VarHandleKey>
Definition: AthCommonDataStore.h:156
fitman.k
k
Definition: fitman.py:528
Trk::RungeKuttaPropagator::getInitializedCache
Cache getInitializedCache(const EventContext &ctx) const
Definition: RungeKuttaPropagator.cxx:1922