![]() |
ATLAS Offline Software
|
#include <TimedExtrapolator.h>
Classes | |
struct | Cache |
Public Member Functions | |
TimedExtrapolator (const std::string &, const std::string &, const IInterface *) | |
Constructor. More... | |
virtual | ~TimedExtrapolator () |
Destructor. More... | |
virtual StatusCode | initialize () override |
AlgTool initailize method. More... | |
virtual StatusCode | finalize () override |
AlgTool finalize method. More... | |
virtual std::unique_ptr< const Trk::TrackParameters > | extrapolateWithPathLimit (const Trk::TrackParameters &parm, Trk::PathLimit &pathLim, Trk::TimeLimit &time, Trk::PropDirection dir, Trk::ParticleHypothesis particle, std::vector< Trk::HitInfo > *&hitVector, Trk::GeometrySignature &nextGeoID, const Trk::TrackingVolume *boundaryVol=nullptr) const override |
Extrapolation method for charged, possibly unstable particles. More... | |
virtual std::unique_ptr< const Trk::TrackParameters > | transportNeutralsWithPathLimit (const Trk::TrackParameters &parm, Trk::PathLimit &pathLim, Trk::TimeLimit &time, Trk::PropDirection dir, Trk::ParticleHypothesis particle, std::vector< Trk::HitInfo > *&hitVector, Trk::GeometrySignature &nextGeoId, const Trk::TrackingVolume *boundaryVol=nullptr) const override |
Transport method for neutral, possibly unstable particles. More... | |
virtual const TrackingGeometry * | trackingGeometry () const override |
Return the TrackingGeometry used by the Extrapolator (forward information from Navigator) More... | |
virtual void | validationAction () const override |
Validation Action: Can be implemented optionally, outside access to internal validation steps. 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, V, H > &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 |
Static Public Member Functions | |
static const InterfaceID & | interfaceID () |
AlgTool 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 |
Static Private Member Functions | |
static std::string | momentumOutput (const Amg::Vector3D &mom) |
For the output - global momentum. More... | |
Private Attributes | |
ToolHandleArray< IPropagator > | m_propagators |
ToolHandle< IPropagator > | m_stepPropagator |
ToolHandle< INavigator > | m_navigator |
ToolHandleArray< ITimedMatEffUpdator > | m_updators |
ToolHandleArray< IMultipleScatteringUpdator > | m_msupdators |
ToolHandle< IEnergyLossUpdator > | m_elossupdater |
std::vector< const IPropagator * > | m_subPropagators |
Propagators to chose from (steered by signature) More... | |
std::vector< const ITimedMatEffUpdator * > | m_subUpdators |
Updators to chose from (steered by signature) More... | |
StringArrayProperty | m_propNames |
StringArrayProperty | m_updatNames |
UnsignedIntegerProperty | m_meotpIndex |
unsigned int | m_configurationLevel = 10 |
see the supported levels of configuration above More... | |
BooleanProperty | m_includeMaterialEffects |
BooleanProperty | m_stopWithNavigationBreak |
BooleanProperty | m_stopWithUpdateZero |
BooleanProperty | m_skipInitialLayerUpdate |
BooleanProperty | m_referenceMaterial |
UnsignedIntegerProperty | m_initialLayerAttempts |
UnsignedIntegerProperty | m_successiveLayerAttempts |
DoubleProperty | m_tolerance {this, "Tolerance", 0.002, "surface & volume tolerance"} |
BooleanProperty | m_caloMsSecondary |
BooleanProperty | m_robustSampling {this, "RobustSampling", true} |
BooleanProperty | m_useDenseVolumeDescription |
BooleanProperty | m_useMuonMatApprox |
BooleanProperty | m_resolveActive {this, "ResolveMuonStation", false} |
BooleanProperty | m_resolveMultilayers {this, "ResolveMultilayers", true} |
BooleanProperty | m_printHelpOutputAtInitialize {this, "HelpOutput", false} |
BooleanProperty | m_printRzOutput {this, "positionOutput", true} |
BooleanProperty | m_navigationStatistics |
BooleanProperty | m_navigationBreakDetails |
BooleanProperty | m_materialEffectsOnTrackValidation |
unsigned int | m_maxNavigSurf {} |
unsigned int | m_maxNavigVol {} |
BooleanProperty | m_fastField {this, "MagneticFieldProperties", false} |
Trk::MagneticFieldProperties | m_fieldProperties |
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 |
The TimedExtrapolator is to be used for the simulation purposes
The output level is as follows: INFO : initialize / finalize information DEBUG : Method call sequence VERBOSE : Method call sequence with values
Definition at line 161 of file TimedExtrapolator.h.
|
privateinherited |
Definition at line 388 of file AthCommonDataStore.h.
Trk::TimedExtrapolator::TimedExtrapolator | ( | const std::string & | t, |
const std::string & | n, | ||
const IInterface * | p | ||
) |
|
virtualdefault |
Destructor.
|
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 |
Private method for emptying the GarbageBin.
Definition at line 1234 of file TimedExtrapolator.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
|
private |
Definition at line 2351 of file TimedExtrapolator.cxx.
|
private |
Definition at line 272 of file TimedExtrapolator.cxx.
|
overridevirtual |
Extrapolation method for charged, possibly unstable particles.
The extrapolation is interrupted at subdetector boundary for surviving/stable particles.
Implements Trk::ITimedExtrapolator.
Definition at line 193 of file TimedExtrapolator.cxx.
|
overridevirtual |
AlgTool finalize method.
Definition at line 187 of file TimedExtrapolator.cxx.
|
overridevirtual |
AlgTool initailize method.
In this method the extrapolator should retrieve the Propagator of highest order which is then passed through the extrapolate method. The Propagator itself should be specified whether to use propagators of a lower hirarchy level or not.
Definition at line 69 of file TimedExtrapolator.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 interface methods.
Definition at line 47 of file ITimedExtrapolator.h.
|
staticprivate |
For the output - global momentum.
Definition at line 1226 of file TimedExtrapolator.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.
|
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.
|
private |
Private to search for overlap surfaces.
Definition at line 1041 of file TimedExtrapolator.cxx.
|
private |
Private method for conversion of the synchronized geometry signature to the natural subdetector ordering.
For the output - global position
Definition at line 1214 of file TimedExtrapolator.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.
|
inlineprivate |
Access the subPropagator to the given volume.
Definition at line 464 of file TimedExtrapolator.h.
|
inlineprivate |
|
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.
|
inlineprivate |
Private method for throwing into the GarbageBin.
Definition at line 471 of file TimedExtrapolator.h.
|
inlineoverridevirtual |
Return the TrackingGeometry used by the Extrapolator (forward information from Navigator)
Implements Trk::ITimedExtrapolator.
Definition at line 442 of file TimedExtrapolator.h.
|
private |
Definition at line 2047 of file TimedExtrapolator.cxx.
|
overridevirtual |
Transport method for neutral, possibly unstable particles.
The extrapolation is interrupted at subdetector boundary for surviving/stable particles.
Implements Trk::ITimedExtrapolator.
Definition at line 1268 of file TimedExtrapolator.cxx.
|
private |
Definition at line 1337 of file TimedExtrapolator.cxx.
|
inlineinherited |
Definition at line 308 of file AthCommonDataStore.h.
|
overridevirtual |
Validation Action: Can be implemented optionally, outside access to internal validation steps.
Implements Trk::ITimedExtrapolator.
Definition at line 1259 of file TimedExtrapolator.cxx.
|
private |
Definition at line 346 of file TimedExtrapolator.h.
|
private |
see the supported levels of configuration above
Definition at line 326 of file TimedExtrapolator.h.
|
privateinherited |
Pointer to StoreGate (detector store by default)
Definition at line 393 of file AthCommonDataStore.h.
|
private |
Definition at line 304 of file TimedExtrapolator.h.
|
privateinherited |
Pointer to StoreGate (event store by default)
Definition at line 390 of file AthCommonDataStore.h.
|
private |
Definition at line 435 of file TimedExtrapolator.h.
|
private |
Definition at line 436 of file TimedExtrapolator.h.
|
private |
Definition at line 328 of file TimedExtrapolator.h.
|
private |
Definition at line 338 of file TimedExtrapolator.h.
|
private |
Definition at line 371 of file TimedExtrapolator.h.
|
private |
Definition at line 373 of file TimedExtrapolator.h.
|
private |
Definition at line 374 of file TimedExtrapolator.h.
|
private |
Definition at line 323 of file TimedExtrapolator.h.
|
private |
Definition at line 302 of file TimedExtrapolator.h.
|
private |
Definition at line 369 of file TimedExtrapolator.h.
|
private |
Definition at line 367 of file TimedExtrapolator.h.
|
private |
Definition at line 297 of file TimedExtrapolator.h.
|
private |
Definition at line 362 of file TimedExtrapolator.h.
|
private |
Definition at line 363 of file TimedExtrapolator.h.
|
private |
Definition at line 293 of file TimedExtrapolator.h.
|
private |
Definition at line 316 of file TimedExtrapolator.h.
|
private |
Definition at line 336 of file TimedExtrapolator.h.
|
private |
Definition at line 357 of file TimedExtrapolator.h.
|
private |
Definition at line 358 of file TimedExtrapolator.h.
|
private |
Definition at line 351 of file TimedExtrapolator.h.
|
private |
Definition at line 334 of file TimedExtrapolator.h.
|
private |
Definition at line 295 of file TimedExtrapolator.h.
|
private |
Definition at line 330 of file TimedExtrapolator.h.
|
private |
Definition at line 332 of file TimedExtrapolator.h.
|
private |
Propagators to chose from (steered by signature)
Definition at line 310 of file TimedExtrapolator.h.
|
private |
Updators to chose from (steered by signature)
Definition at line 312 of file TimedExtrapolator.h.
|
private |
Definition at line 340 of file TimedExtrapolator.h.
|
private |
Definition at line 344 of file TimedExtrapolator.h.
|
private |
Definition at line 318 of file TimedExtrapolator.h.
|
private |
Definition at line 300 of file TimedExtrapolator.h.
|
private |
Definition at line 352 of file TimedExtrapolator.h.
|
private |
Definition at line 355 of file TimedExtrapolator.h.
|
privateinherited |
Definition at line 399 of file AthCommonDataStore.h.
|
privateinherited |
Definition at line 398 of file AthCommonDataStore.h.