ATLAS Offline Software
|
#include <STEP_Propagator.h>
Classes | |
struct | Cache |
stuct to pass information to the heavy lifting calculation internal methods More... | |
Public Member Functions | |
STEP_Propagator (const std::string &, const std::string &, const IInterface *) | |
virtual | ~STEP_Propagator () |
virtual StatusCode | initialize () override final |
AlgTool initialize method. More... | |
virtual StatusCode | finalize () override final |
AlgTool finalize method. More... | |
virtual std::unique_ptr< Trk::NeutralParameters > | propagate (const Trk::NeutralParameters &, const Trk::Surface &, Trk::PropDirection, const Trk::BoundaryCheck &, bool rC=false) const override final |
Main propagation method NeutralParameters. More... | |
virtual std::unique_ptr< Trk::TrackParameters > | propagate (const EventContext &ctx, const Trk::TrackParameters &trackParameters, const Trk::Surface &targetSurface, Trk::PropDirection propagationDirection, const Trk::BoundaryCheck &boundaryCheck, const MagneticFieldProperties &magneticFieldProperties, ParticleHypothesis particle, bool returnCurv=false, const Trk::TrackingVolume *tVol=nullptr) const override final |
Propagate parameters and covariance without returning the Jacobian. More... | |
virtual std::unique_ptr< Trk::TrackParameters > | propagate (const EventContext &ctx, const Trk::TrackParameters &trackParameters, std::vector< Trk::DestSurf > &targetSurfaces, Trk::PropDirection propagationDirection, const MagneticFieldProperties &magneticFieldProperties, ParticleHypothesis particle, std::vector< unsigned int > &solutions, double &path, bool usePathLimit=false, bool returnCurv=false, const Trk::TrackingVolume *tVol=nullptr) const override final |
Propagate parameters and covariance with search of closest surface. More... | |
virtual std::unique_ptr< Trk::TrackParameters > | propagateT (const EventContext &ctx, const Trk::TrackParameters &trackParameters, std::vector< Trk::DestSurf > &targetSurfaces, Trk::PropDirection propagationDirection, const MagneticFieldProperties &magneticFieldProperties, ParticleHypothesis particle, std::vector< unsigned int > &solutions, Trk::PathLimit &path, Trk::TimeLimit &time, bool returnCurv, const Trk::TrackingVolume *tVol, std::vector< Trk::HitInfo > *&hitVector) const override final |
Propagate parameters and covariance with search of closest surface time included. More... | |
virtual std::unique_ptr< Trk::TrackParameters > | propagateM (const EventContext &ctx, const Trk::TrackParameters &trackParameters, std::vector< Trk::DestSurf > &targetSurfaces, Trk::PropDirection propagationDirection, const MagneticFieldProperties &magneticFieldProperties, ParticleHypothesis particle, std::vector< unsigned int > &solutions, std::vector< const Trk::TrackStateOnSurface * > *&matstates, std::vector< std::pair< std::unique_ptr< Trk::TrackParameters >, int >> *intersections, double &path, bool usePathLimit=false, bool returnCurv=false, const Trk::TrackingVolume *tVol=nullptr, Trk::ExtrapolationCache *=nullptr) const override final |
Propagate parameters and covariance with search of closest surface and material collection. More... | |
virtual std::unique_ptr< Trk::TrackParameters > | propagate (const EventContext &ctx, const Trk::TrackParameters &trackParameters, const Trk::Surface &targetSurface, Trk::PropDirection propagationDirection, const Trk::BoundaryCheck &boundaryCheck, const MagneticFieldProperties &magneticFieldProperties, std::optional< Trk::TransportJacobian > &jacobian, double &pathLimit, ParticleHypothesis particle, bool returnCurv=false, const Trk::TrackingVolume *tVol=nullptr) const override final |
Propagate parameters and covariance, and return the Jacobian. More... | |
virtual std::unique_ptr< Trk::TrackParameters > | propagateParameters (const EventContext &ctx, const Trk::TrackParameters &trackParameters, const Trk::Surface &targetSurface, Trk::PropDirection propagationDirection, const Trk::BoundaryCheck &boundaryCheck, const MagneticFieldProperties &magneticFieldProperties, ParticleHypothesis particle, bool returnCurv=false, const Trk::TrackingVolume *tVol=nullptr) const override final |
Propagate parameters only. More... | |
virtual std::unique_ptr< Trk::TrackParameters > | propagateParameters (const EventContext &ctx, const Trk::TrackParameters &trackParameters, const Trk::Surface &targetSurface, Trk::PropDirection propagationDirection, const Trk::BoundaryCheck &boundaryCheck, const MagneticFieldProperties &magneticFieldProperties, std::optional< Trk::TransportJacobian > &jacobian, ParticleHypothesis particle, bool returnCurv=false, const Trk::TrackingVolume *tVol=nullptr) const override final |
Propagate parameters and return Jacobian. More... | |
virtual std::optional< TrackSurfaceIntersection > | intersect (const EventContext &ctx, const Trk::TrackParameters &trackParameters, const Trk::Surface &targetSurface, const Trk::MagneticFieldProperties &magneticFieldProperties, ParticleHypothesis particle, const Trk::TrackingVolume *tVol=nullptr) const override final |
Propagate parameters and return path (Similar to propagateParameters. More... | |
virtual std::optional< TrackSurfaceIntersection > | intersectSurface (const EventContext &ctx, const Surface &surface, const TrackSurfaceIntersection &trackIntersection, const double qOverP, const MagneticFieldProperties &mft, ParticleHypothesis particle) const override final |
Intersection and propagation: More... | |
virtual void | globalPositions (const EventContext &ctx, std::deque< Amg::Vector3D > &positionsList, const TrackParameters &trackParameters, const MagneticFieldProperties &magneticFieldProperties, const CylinderBounds &cylinderBounds, double maxStepSize, ParticleHypothesis particle, const Trk::TrackingVolume *tVol=0) const override final |
Return a list of positions along the track. More... | |
virtual Trk::MultiComponentState | multiStatePropagate (const EventContext &, const MultiComponentState &, const Surface &, const MagneticFieldProperties &, const PropDirection, const BoundaryCheck &, const ParticleHypothesis) const override final |
unimplemented multiStatePropagate More... | |
virtual Trk::ExtrapolationCode | propagate (const EventContext &, Trk::ExCellCharged &, Trk::TargetSurfaces &, Trk::TargetSurfaceVector &) const override final |
Propagation method needed for StepEngine. More... | |
virtual std::unique_ptr< NeutralParameters > | propagate (const NeutralParameters ¶meters, const Surface &sf, PropDirection dir, const BoundaryCheck &bcheck, bool returnCurv=false) const=0 |
Main propagation method for NeutralParameters. More... | |
virtual std::unique_ptr< TrackParameters > | propagate (const EventContext &ctx, const TrackParameters &parm, const Surface &sf, PropDirection dir, const BoundaryCheck &bcheck, const MagneticFieldProperties &mprop, ParticleHypothesis particle=pion, bool returnCurv=false, const TrackingVolume *tVol=nullptr) const=0 |
Main propagation method without transport jacobian production. More... | |
virtual std::unique_ptr< TrackParameters > | propagate (const EventContext &ctx, const TrackParameters &parm, std::vector< DestSurf > &sfs, PropDirection dir, const MagneticFieldProperties &mprop, ParticleHypothesis particle, std::vector< unsigned int > &solutions, double &path, bool usePathLim=false, bool returnCurv=false, const TrackingVolume *tVol=nullptr) const=0 |
Propagate parameters and covariance with search of closest surface. More... | |
virtual std::unique_ptr< TrackParameters > | propagate (const EventContext &ctx, const TrackParameters &parm, const Surface &sf, PropDirection dir, const BoundaryCheck &bcheck, const MagneticFieldProperties &mprop, std::optional< TransportJacobian > &jacob, double &pathLength, ParticleHypothesis particle=pion, bool returnCurv=false, const TrackingVolume *tVol=nullptr) const=0 |
Main propagation method with transport jacobian production. More... | |
virtual Trk::ExtrapolationCode | propagate (const EventContext &ctx, Trk::ExCellCharged &eCell, Trk::TargetSurfaces &sfs, Trk::TargetSurfaceVector &solutions) const=0 |
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 std::unique_ptr< TrackParameters > | propagate (const EventContext &ctx, const TrackParameters &parm, const Surface &sf, PropDirection dir, const BoundaryCheck &bcheck, const MagneticFieldProperties &mprop, std::optional< TransportJacobian > &jacob, double &pathLength, ParticleHypothesis particle=pion, bool returnCurv=false, const TrackingVolume *tVol=nullptr) const =0 |
Main propagation method with transport jacobian production. More... | |
virtual std::unique_ptr< TrackParameters > | propagateParameters (const EventContext &ctx, const TrackParameters &parm, const Surface &sf, PropDirection dir, const BoundaryCheck &bcheck, const MagneticFieldProperties &mprop, std::optional< TransportJacobian > &jacob, ParticleHypothesis particle=pion, bool returnCurv=false, const TrackingVolume *tVol=nullptr) const =0 |
Main propagation method for parameters only with transport jacobian production. More... | |
Static Public Member Functions | |
static const InterfaceID & | interfaceID () |
AlgTool and IAlgTool interface methods. 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< StoreGateSvc > | StoreGateSvc_t |
Private Member Functions | |
void | setCacheFromProperties (Cache &cache) const |
initialize cache with the variables we need to take from More... | |
std::unique_ptr< Trk::TrackParameters > | propagateRungeKutta (Cache &cache, bool errorPropagation, const Trk::TrackParameters &trackParameters, std::vector< DestSurf > &targetSurfaces, Trk::PropDirection propagationDirection, const MagneticFieldProperties &magneticFieldProperties, ParticleHypothesis particle, std::vector< unsigned int > &solutions, double &path, bool returnCurv=false) const |
bool | propagateWithJacobian (Cache &cache, bool errorPropagation, std::vector< DestSurf > &sfs, double *P, Trk::PropDirection propDir, std::vector< unsigned int > &solutions, double &path, double sumPath) const |
void | dumpMaterialEffects (Cache &cache, const Trk::CurvilinearParameters *trackParameters, double path) const |
void | smear (Cache &cache, double &phi, double &theta, const Trk::TrackParameters *parms, double radDist) const |
void | sampleBrem (Cache &cache, double mom) const |
void | getFieldCacheObject (Cache &cache, const EventContext &ctx) const |
CLHEP::HepRandomEngine * | getRandomEngine (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 | |
double | m_tolerance |
Error tolerance. More... | |
bool | m_materialEffects |
Switch material effects on or off. More... | |
bool | m_includeBgradients |
Include B-gradients in the error propagation. More... | |
bool | m_includeGgradient |
Include g-gradient in the error propagation. More... | |
double | m_momentumCutOff |
Stop propagation below this momentum. More... | |
bool | m_multipleScattering |
Switch multiple scattering on or off. More... | |
bool | m_energyLoss |
bool | m_detailedEloss |
bool | m_straggling |
bool | m_MPV |
double | m_stragglingScale |
double | m_scatteringScale |
double | m_maxPath |
double | m_maxSteps |
double | m_layXmax |
bool | m_simulation |
ToolHandle< ITimedMatEffUpdator > | m_simMatUpdator |
secondary interactions (brem photon emission) More... | |
ServiceHandle< IAthRNGSvc > | m_rndGenSvc |
Random Generator service. More... | |
ATHRNG::RNGWrapper * | m_rngWrapper = nullptr |
Random engine. More... | |
std::string | m_randomEngineName |
SG::ReadCondHandleKey< AtlasFieldCacheCondObj > | m_fieldCacheCondObjInputKey |
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 |
STEP (Simultaneous Track and Error Propagation ) is an algorithm for track parameters propagation through magnetic field.
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.
One can choose to perform the transport of the parameters only and omit the transport of the associated covariances (propagateParameters).
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.
The STEP_Propagator includes material effects in the equation of motion and applies corrections to the covariance matrices continuously during the parameter transport. It is designed for the propagation of a particle going through a dense block of material (e.g a muon transversing the calorimeter).
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 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 | | | | | | | | | |
| Local->Global transformation V Global position (Runge Kutta presentation) | | Propagation to next surface with or without jacobian |
| | | | | | | | | | V V V V V PlaneSurface StraightLineSurface DiscSurface CylinderSurface PerigeeSurface
For propagation using Runge Kutta method we use global coordinate, direction, inverse momentum and Jacobian of transformation. All this parameters we save in 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 local presentation
L0 - first local coordinate (surface dependent) L1 - second local coordinate (surface dependent) Phi - Azimuthal angle The - Polar angle CM - charge/momentum
in case global 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
The Runge-Kutta method:
The equations of motion are solved using an embedded pair of Runge-Kutta formulas. This method, Runge-Kutta-Fehlberg, calculates a number of points along the step and adds them up in different ways to get two different solutions, of different order, for the integration. The higher order solution is used for the propagation and the lower order solution for error control. The difference between these solutions is used to estimate the quality of the integration (propagation), and to calculate the step size for the next step. If the quality is below a given tolerance then the step is rejected and repeated with a shorter step length. This propagator uses the TP43 (Tsitouras-Papakostas 4th and 3rd order) Runge-Kutta pair.
The step size algoritm by L.P.Endresen and J.Myrheim was choosen for its low step rejection and effective step size calculation. The low step rejection is achieved by letting the step size oscillate around the optimal value instead of repeating steps every time they fall below the tolerance level.
Units are mm, MeV and kiloGauss.
Definition at line 164 of file STEP_Propagator.h.
|
privateinherited |
Definition at line 388 of file AthCommonDataStore.h.
Trk::STEP_Propagator::STEP_Propagator | ( | const std::string & | p, |
const std::string & | n, | ||
const IInterface * | t | ||
) |
Definition at line 1179 of file STEP_Propagator.cxx.
|
virtualdefault |
|
inlineprivateinherited |
specialization for handling Gaudi::Property<SG::VarHandleKeyArray>
Definition at line 170 of file AthCommonDataStore.h.
|
inlineprivateinherited |
specialization for handling Gaudi::Property<SG::VarHandleKey>
Definition at line 156 of file AthCommonDataStore.h.
|
inlineprivateinherited |
specialization for handling Gaudi::Property<SG::VarHandleBase>
Definition at line 184 of file AthCommonDataStore.h.
|
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.
|
inlineinherited |
Declare a new Gaudi property.
name | Name of the property. |
hndl | Object holding the property value. |
doc | Documentation 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.
|
inlineinherited |
Declare a new Gaudi property.
name | Name of the property. |
hndl | Object holding the property value. |
doc | Documentation 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.
|
inlineinherited |
Definition at line 259 of file AthCommonDataStore.h.
|
inlineinherited |
Declare a new Gaudi property.
name | Name of the property. |
property | Object holding the property value. |
doc | Documentation 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.
|
inlineinherited |
Declare a new Gaudi property.
name | Name of the property. |
property | Object holding the property value. |
doc | Documentation 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.
|
inlineinherited |
Definition at line 145 of file AthCommonDataStore.h.
|
inlineinherited |
The standard StoreGateSvc/DetectorStore
Returns (kind of) a pointer to the StoreGateSvc
.
Definition at line 95 of file AthCommonDataStore.h.
|
private |
Definition at line 2744 of file STEP_Propagator.cxx.
|
inlineinherited |
The standard StoreGateSvc
(event store) Returns (kind of) a pointer to the StoreGateSvc
.
Definition at line 85 of file AthCommonDataStore.h.
|
inlineinherited |
The standard StoreGateSvc
(event store) Returns (kind of) a pointer to the StoreGateSvc
.
Definition at line 90 of file AthCommonDataStore.h.
|
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
|
finaloverridevirtual |
AlgTool finalize method.
Definition at line 1256 of file STEP_Propagator.cxx.
|
private |
Definition at line 2842 of file STEP_Propagator.cxx.
|
private |
Definition at line 2854 of file STEP_Propagator.cxx.
|
finaloverridevirtual |
Return a list of positions along the track.
Implements Trk::IPropagator.
Definition at line 1816 of file STEP_Propagator.cxx.
|
finaloverridevirtual |
AlgTool initialize method.
Definition at line 1229 of file STEP_Propagator.cxx.
|
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.
|
inlinestaticinherited |
AlgTool and IAlgTool interface methods.
Definition at line 61 of file IPropagator.h.
|
finaloverridevirtual |
Propagate parameters and return path (Similar to propagateParameters.
Implements Trk::IPropagator.
Definition at line 1648 of file STEP_Propagator.cxx.
|
finaloverridevirtual |
Intersection and propagation:
Implements Trk::IPropagator.
Definition at line 1788 of file STEP_Propagator.cxx.
|
inlineinherited |
Definition at line 24 of file AthCommonMsg.h.
|
inlineinherited |
Definition at line 27 of file AthCommonMsg.h.
|
inlineinherited |
Definition at line 30 of file AthCommonMsg.h.
|
inlinefinaloverridevirtual |
unimplemented multiStatePropagate
Implements Trk::IPropagator.
Definition at line 326 of file STEP_Propagator.h.
|
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.
|
inlinefinaloverridevirtual |
Propagation method needed for StepEngine.
Implements Trk::IPropagator.
Definition at line 338 of file STEP_Propagator.h.
virtual std::unique_ptr<TrackParameters> Trk::IPropagator::propagate |
Main propagation method without transport jacobian production.
|
pure virtualinherited |
Main propagation method with transport jacobian production.
Implemented in Trk::IntersectorWrapper, and Trk::RungeKuttaPropagator.
virtual std::unique_ptr<TrackParameters> Trk::IPropagator::propagate |
Main propagation method with transport jacobian production.
virtual std::unique_ptr<TrackParameters> Trk::IPropagator::propagate |
Propagate parameters and covariance with search of closest surface.
|
finaloverridevirtual |
Propagate parameters and covariance without returning the Jacobian.
Implements Trk::IPropagator.
Definition at line 1274 of file STEP_Propagator.cxx.
|
finaloverridevirtual |
Propagate parameters and covariance, and return the Jacobian.
WARNING: Multiple Scattering is not included in the Jacobian!
Definition at line 1506 of file STEP_Propagator.cxx.
|
finaloverridevirtual |
Propagate parameters and covariance with search of closest surface.
Implements Trk::IPropagator.
Definition at line 1313 of file STEP_Propagator.cxx.
virtual Trk::ExtrapolationCode Trk::IPropagator::propagate |
Propagation method needed for StepEngine.
virtual std::unique_ptr<NeutralParameters> Trk::IPropagator::propagate |
Main propagation method for NeutralParameters.
|
finaloverridevirtual |
Main propagation method NeutralParameters.
It is not implemented for STEP propagator.
Use StraightLinePropagator for neutrals
Implements Trk::IPropagator.
Definition at line 1261 of file STEP_Propagator.cxx.
|
finaloverridevirtual |
Propagate parameters and covariance with search of closest surface and material collection.
Implements Trk::IPropagator.
Definition at line 1450 of file STEP_Propagator.cxx.
|
pure virtualinherited |
Main propagation method for parameters only with transport jacobian production.
Implemented in Trk::IntersectorWrapper, and Trk::RungeKuttaPropagator.
|
finaloverridevirtual |
Propagate parameters only.
Implements Trk::IPropagator.
Definition at line 1564 of file STEP_Propagator.cxx.
|
finaloverridevirtual |
Propagate parameters and return Jacobian.
WARNING: Multiple Scattering is not included in the Jacobian!
Definition at line 1595 of file STEP_Propagator.cxx.
|
private |
Check first that the jacobian does not have crazy entries
Definition at line 1926 of file STEP_Propagator.cxx.
|
finaloverridevirtual |
Propagate parameters and covariance with search of closest surface time included.
Implements Trk::IPropagator.
Definition at line 1364 of file STEP_Propagator.cxx.
|
private |
Definition at line 2136 of file STEP_Propagator.cxx.
|
inlineprotectedinherited |
Definition at line 380 of file AthCommonDataStore.h.
|
inlineprotectedinherited |
remove all handles from I/O resolution
Definition at line 364 of file AthCommonDataStore.h.
|
private |
Definition at line 2828 of file STEP_Propagator.cxx.
|
inlineprivate |
initialize cache with the variables we need to take from
Definition at line 431 of file STEP_Propagator.h.
|
private |
Definition at line 2791 of file STEP_Propagator.cxx.
|
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.
|
overridevirtualinherited |
Handle START transition.
We override this in order to make sure that conditions handle keys can cache a pointer to the conditions container.
|
inlineinherited |
Definition at line 308 of file AthCommonDataStore.h.
|
private |
Definition at line 503 of file STEP_Propagator.h.
|
privateinherited |
Pointer to StoreGate (detector store by default)
Definition at line 393 of file AthCommonDataStore.h.
|
private |
Definition at line 502 of file STEP_Propagator.h.
|
privateinherited |
Pointer to StoreGate (event store by default)
Definition at line 390 of file AthCommonDataStore.h.
|
private |
Definition at line 524 of file STEP_Propagator.h.
|
private |
Include B-gradients in the error propagation.
Definition at line 498 of file STEP_Propagator.h.
|
private |
Include g-gradient in the error propagation.
Definition at line 499 of file STEP_Propagator.h.
|
private |
Definition at line 510 of file STEP_Propagator.h.
|
private |
Switch material effects on or off.
Definition at line 497 of file STEP_Propagator.h.
|
private |
Definition at line 508 of file STEP_Propagator.h.
|
private |
Definition at line 509 of file STEP_Propagator.h.
|
private |
Stop propagation below this momentum.
Definition at line 500 of file STEP_Propagator.h.
|
private |
Definition at line 505 of file STEP_Propagator.h.
|
private |
Switch multiple scattering on or off.
Definition at line 501 of file STEP_Propagator.h.
|
private |
Definition at line 521 of file STEP_Propagator.h.
|
private |
Random Generator service.
Definition at line 518 of file STEP_Propagator.h.
|
private |
Random engine.
Definition at line 520 of file STEP_Propagator.h.
|
private |
Definition at line 507 of file STEP_Propagator.h.
|
private |
secondary interactions (brem photon emission)
Definition at line 516 of file STEP_Propagator.h.
|
private |
Definition at line 514 of file STEP_Propagator.h.
|
private |
Definition at line 504 of file STEP_Propagator.h.
|
private |
Definition at line 506 of file STEP_Propagator.h.
|
private |
Error tolerance.
Low tolerance gives high accuracy
Definition at line 496 of file STEP_Propagator.h.
|
privateinherited |
Definition at line 399 of file AthCommonDataStore.h.
|
privateinherited |
Definition at line 398 of file AthCommonDataStore.h.