ATLAS Offline Software
Loading...
Searching...
No Matches
Trk::PropagationEngine Class Reference

Wrapper around the IPropagator interface, the neutral propagation is solved by using the surface::straightLineIntersection mehtod. More...

#include <PropagationEngine.h>

Inheritance diagram for Trk::PropagationEngine:
Collaboration diagram for Trk::PropagationEngine:

Public Member Functions

 PropagationEngine (const std::string &, const std::string &, const IInterface *)
 Constructor.
 ~PropagationEngine ()
 Destructor.
StatusCode initialize ()
 AlgTool initialize method.
StatusCode finalize ()
 AlgTool finalize method.
virtual ExtrapolationCode propagate (ExCellCharged &ecCell, const Surface &sf, PropDirection dir=alongMomentum, BoundaryCheck bcheck=true, bool returnCurvilinear=true) const
 resolve the boundary situation - for charged particles
virtual ExtrapolationCode propagate (ExCellNeutral &enCell, const Surface &sf, PropDirection dir=alongMomentum, BoundaryCheck bcheck=true, bool returnCurvilinear=true) const
 resolve the boundary situation - for neutral particles
ServiceHandle< StoreGateSvc > & evtStore ()
 The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.
const ServiceHandle< StoreGateSvc > & detStore () const
 The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.
virtual StatusCode sysInitialize () override
 Perform system initialization for an algorithm.
virtual StatusCode sysStart () override
 Handle START transition.
virtual std::vector< Gaudi::DataHandle * > inputHandles () const override
 Return this algorithm's input handles.
virtual std::vector< Gaudi::DataHandle * > outputHandles () const override
 Return this algorithm's output handles.
Gaudi::Details::PropertyBase & declareProperty (Gaudi::Property< T, V, H > &t)
void updateVHKA (Gaudi::Details::PropertyBase &)
MsgStream & msg () const
bool msgLvl (const MSG::Level lvl) const

Static Public Member Functions

static const InterfaceID & interfaceID ()
 AlgTool interface methods.

Protected Member Functions

void renounceArray (SG::VarHandleKeyArray &handlesArray)
 remove all handles from I/O resolution
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.

Protected Attributes

ToolHandle< IPropagatorm_propagator {this, "Propagator", "Trk::RungeKuttaPropagator/AtlasRungeKuttaPropagator"}
DoubleProperty m_pathLimitTolerance {this, "PathLimitTolerance", 0.01}
StringProperty m_sopPrefix_prop {this, "OutputPrefix", ""}
StringProperty m_sopPostfix_prop {this, "OutputPostfix", ""}
std::string m_sopPrefix
 < SCREEN output formatting (SOP) - unify amongst extrapolation engines
std::string m_sopPostfix
 prefix for screen output

Private Types

typedef ServiceHandle< StoreGateSvcStoreGateSvc_t

Private Member Functions

Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
 specialization for handling Gaudi::Property<SG::VarHandleKey>

Private Attributes

StoreGateSvc_t m_evtStore
 Pointer to StoreGate (event store by default)
StoreGateSvc_t m_detStore
 Pointer to StoreGate (detector store by default)
std::vector< SG::VarHandleKeyArray * > m_vhka
bool m_varHandleArraysDeclared

Detailed Description

Wrapper around the IPropagator interface, the neutral propagation is solved by using the surface::straightLineIntersection mehtod.

Author
Andreas Salzburger -at - cern.ch

Definition at line 36 of file PropagationEngine.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

◆ PropagationEngine()

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

Constructor.

Definition at line 19 of file PropagationEngine.cxx.

20: AthAlgTool(t,n,p)
21{
22 declareInterface<Trk::IPropagationEngine>(this);
23}
AthAlgTool()
Default constructor:

◆ ~PropagationEngine()

Trk::PropagationEngine::~PropagationEngine ( )
default

Destructor.

Member Function Documentation

◆ declareGaudiProperty()

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

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

Definition at line 156 of file AthCommonDataStore.h.

158 {
160 hndl.value(),
161 hndl.documentation());
162
163 }
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T, V, H > &t)

◆ declareProperty()

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

Definition at line 145 of file AthCommonDataStore.h.

145 {
146 typedef typename SG::HandleClassifier<T>::type htype;
148 }
Gaudi::Details::PropertyBase & declareGaudiProperty(Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
specialization for handling Gaudi::Property<SG::VarHandleKey>

◆ 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.

◆ evtStore()

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.

◆ 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

◆ finalize()

StatusCode Trk::PropagationEngine::finalize ( )

AlgTool finalize method.

Definition at line 47 of file PropagationEngine.cxx.

48{
49 EX_MSG_DEBUG( "", "finalize", "", "successful" );
50 return StatusCode::SUCCESS;
51}
#define EX_MSG_DEBUG(navstep, step, idx, x)

◆ initialize()

StatusCode Trk::PropagationEngine::initialize ( )

AlgTool initialize method.

Definition at line 31 of file PropagationEngine.cxx.

32{
35
36 if (m_propagator.retrieve().isFailure()){
37 EX_MSG_FATAL( "", "initialize", "", "failed to retrieve propagator '"<< m_propagator << "'. Aborting." );
38 return StatusCode::FAILURE;
39 } else
40 EX_MSG_DEBUG( "", "initialize", "", "successfully retrieved '" << m_propagator << "'." );
41
42 EX_MSG_DEBUG( "", "initialize", "", "successful" );
43 return StatusCode::SUCCESS;
44}
#define EX_MSG_FATAL(navstep, step, idx, x)
std::string m_sopPostfix
prefix for screen output
std::string m_sopPrefix
< SCREEN output formatting (SOP) - unify amongst extrapolation engines
StringProperty m_sopPostfix_prop
ToolHandle< IPropagator > m_propagator
StringProperty m_sopPrefix_prop

◆ 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()

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

AlgTool interface methods.

Definition at line 48 of file IPropagationEngine.h.

48{ return IID_IPropagationEngine; }
static const InterfaceID IID_IPropagationEngine("IPropagationEngine", 1, 0)

◆ msg()

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

Definition at line 24 of file AthCommonMsg.h.

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

◆ 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 }

◆ 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/2]

Trk::ExtrapolationCode Trk::PropagationEngine::propagate ( Trk::ExCellCharged & eCell,
const Surface & sf,
Trk::PropDirection pDir = alongMomentum,
Trk::BoundaryCheck bcheck = true,
bool returnCurvilinear = true ) const
virtual

resolve the boundary situation - for charged particles

Implements Trk::IPropagationEngine.

Definition at line 55 of file PropagationEngine.cxx.

60{
61 EX_MSG_DEBUG(++eCell.navigationStep, "propagate", "char", "propagation engine called with charged parameters with propagation direction " << pDir );
62
63 double propLength = -1.;
65 // the path limit
66 propLength = eCell.pathLimit > 0 ? (eCell.pathLimit-eCell.pathLength) : eCell.pathLimit;
67 EX_MSG_VERBOSE(eCell.navigationStep, "propagate", "char", "available step length for this propagation " << propLength );
68 }
69 // it is the final propagation if it is the endSurface
70 bool finalPropagation = (eCell.endSurface == (&sf));
71
72 std::optional<Trk::TransportJacobian> tjac{};
73 // we need to first fill the propagation parameters in order to be able to updates & fallbacks
74 //release, otherwise need to change the Trk::ExCell code
75 auto *pParameters = m_propagator->propagate(
76 Gaudi::Hive::currentContext(),
77 *eCell.leadParameters,
78 sf,
79 pDir,
80 bcheck,
81 eCell.mFieldMode,
82 tjac,
83 propLength,
84 eCell.pHypothesis,
85 returnCurvilinear).release();
86 // set the return type according to how the propagation went
87 if (pParameters){
88 // cache the last lead parameters, useful in case a navigation error occured
90 // assign the lead and end parameters
91 eCell.leadParameters = pParameters;
92 // check what to do with the path Length
94 // add the new propagation length to the path length
95 eCell.pathLength += propLength;
96 // check if Limit reached
98 EX_MSG_VERBOSE(eCell.navigationStep, "propagate", "char", "path limit of " << eCell.pathLimit << " successfully reached -> stopping." );
100 }
101 }
102
103 // check if the propagation was called with directly, then lead parameters become end parameters
105 eCell.endParameters = eCell.leadParameters;
106
107 // return Success only if it is the final propagation - the extrapolation engine knows that
109 }
110 // return - recovered means that the leadParameters are the input ones
112}
#define EX_MSG_VERBOSE(navstep, step, idx, x)
MagneticFieldProperties mFieldMode
what magnetic field mode to be used, default : fullField
T * lastLeadParameters
this is for caching the last valid
const Surface * endSurface
keep track of the destination surface - can be optionally 0
T * endParameters
by pointer - are newly created and can be optionally 0
int navigationStep
a counter of the navigation Step
T * leadParameters
the one last truely valid parameter in the stream
bool pathLimitReached(double tolerance=0.001) const
the materialLimitReached
double pathLimit
the maximal limit of the extrapolation
bool checkConfigurationMode(ExtrapolationMode::eMode em) const
check the configuration mode
ParticleHypothesis pHypothesis
what particle hypothesis to be used, default : pion
double pathLength
the path length accumulated
DoubleProperty m_pathLimitTolerance

◆ propagate() [2/2]

Trk::ExtrapolationCode Trk::PropagationEngine::propagate ( Trk::ExCellNeutral & eCell,
const Surface & sf,
Trk::PropDirection pDir = alongMomentum,
Trk::BoundaryCheck bcheck = true,
bool returnCurvilinear = true ) const
virtual

resolve the boundary situation - for neutral particles

Implements Trk::IPropagationEngine.

Definition at line 115 of file PropagationEngine.cxx.

120{
121 EX_MSG_DEBUG(++eCell.navigationStep, "propagate", "neut", "propagation engine called with neutral parameters with propagation direction " << pDir );
122 // leave this for the moment, can re replaced by an appropriate propagator call later
123 if (eCell.leadParameters->covariance()){
124 EX_MSG_VERBOSE(eCell.navigationStep,"propagate", "neut", "propagation of neutral parameters with covariances requested. This is not supported for the moment.");
125 }
126 // the pathLimit cache so far
127 double cPath = eCell.pathLength;
128 // it is the final propagation if it is the endSurface
129 bool finalPropagation = (eCell.endSurface == (&sf));
130 // intersect the surface
131 Trk::Intersection sfIntersection = (pDir!=Trk::anyDirection) ? sf.straightLineIntersection(eCell.leadParameters->position(),
132 pDir*eCell.leadParameters->momentum().unit(),
133 true, bcheck) :
134 sf.straightLineIntersection(eCell.leadParameters->position(),
135 eCell.leadParameters->momentum().unit(),
136 false, bcheck);
137 // we have a valid intersection
138 if (sfIntersection.valid){
139 // fill the transport information - only if the propation direction is not 0 ('anyDirection')
140 if (pDir!=Trk::anyDirection){
141 double pLength = (sfIntersection.position-eCell.leadParameters->position()).mag();
142 EX_MSG_VERBOSE(eCell.navigationStep,"propagate", "neut", "path length of " << pLength << " added to the extrapolation cell (limit = " << eCell.pathLimit << ")" );
143 eCell.stepTransport(sf,pLength);
144 }
145 // now check if it is valud it's further away than the pathLimit
147 // cache the last lead parameters
149 // create new neutral curvilinear parameters at the path limit reached
150 double pDiff = eCell.pathLimit - cPath;
152 eCell.leadParameters->momentum(),
153 0.);
154 EX_MSG_VERBOSE(eCell.navigationStep,"propagate", "neut", "path limit of " << eCell.pathLimit << " reached. Stopping extrapolation.");
156 }
157 // cache the last lead parameters
159 // now exchange the lead parameters
160 // create the new curvilinear paramters at the surface intersection -> if so, trigger the success
161 eCell.leadParameters = returnCurvilinear ? new Trk::NeutralCurvilinearParameters(sfIntersection.position, eCell.leadParameters->momentum(), 0.) :
162 sf.createUniqueNeutralParameters(sfIntersection.position, eCell.leadParameters->momentum(), 0.).release();
163
164 // check if the propagation was called with directly, then lead parameters become end parameters
166 eCell.endParameters = eCell.leadParameters;
167
168 // return success for the final destination or in progress
170
171 } else {
172 // give some screen output
173 EX_MSG_VERBOSE(eCell.navigationStep,"propagate", "neut", "intersection with the surface did not succeed.");
174 }
175 // return - recovered means that the leadParameters are the input ones
177}
void stepTransport(const Surface &sf, double pathLength=0., const TransportJacobian *tjac=nullptr)
fill transport information - path length and TransportJacobian
const Amg::Vector3D & momentum() const
Access method for the momentum.
const Amg::Vector3D & position() const
Access method for the position.
static std::string release
Definition computils.h:50
@ anyDirection
CurvilinearParametersT< NeutralParametersDim, Neutral, PlaneSurface > NeutralCurvilinearParameters
Amg::Vector3D position

◆ 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();
384 }
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)

◆ 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 {
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 asg::AsgMetadataTool, AthCheckedComponent< AthAlgTool >, AthCheckedComponent<::AthAlgTool >, and DerivationFramework::CfAthAlgTool.

◆ 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) {
313 for (auto k : keys) {
314 k->setOwner(this);
315 }
316 }
317 }
std::vector< SG::VarHandleKeyArray * > m_vhka

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_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_pathLimitTolerance

DoubleProperty Trk::PropagationEngine::m_pathLimitTolerance {this, "PathLimitTolerance", 0.01}
protected

Definition at line 70 of file PropagationEngine.h.

70{this, "PathLimitTolerance", 0.01};

◆ m_propagator

ToolHandle<IPropagator> Trk::PropagationEngine::m_propagator {this, "Propagator", "Trk::RungeKuttaPropagator/AtlasRungeKuttaPropagator"}
protected

Definition at line 69 of file PropagationEngine.h.

69{this, "Propagator", "Trk::RungeKuttaPropagator/AtlasRungeKuttaPropagator"};

◆ m_sopPostfix

std::string Trk::IPropagationEngine::m_sopPostfix
protectedinherited

prefix for screen output

Definition at line 79 of file IPropagationEngine.h.

◆ m_sopPostfix_prop

StringProperty Trk::PropagationEngine::m_sopPostfix_prop {this, "OutputPostfix", ""}
protected

Definition at line 72 of file PropagationEngine.h.

72{this, "OutputPostfix", ""};

◆ m_sopPrefix

std::string Trk::IPropagationEngine::m_sopPrefix
protectedinherited

< SCREEN output formatting (SOP) - unify amongst extrapolation engines

prefix for screen output

Definition at line 78 of file IPropagationEngine.h.

◆ m_sopPrefix_prop

StringProperty Trk::PropagationEngine::m_sopPrefix_prop {this, "OutputPrefix", ""}
protected

Definition at line 71 of file PropagationEngine.h.

71{this, "OutputPrefix", ""};

◆ 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: