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 > &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 |
Array of Propagators. More... | |
ToolHandle< IPropagator > | m_stepPropagator |
Array of Propagators. More... | |
ToolHandle< INavigator > | m_navigator |
Navigator for TrackingGeometry and magnetic fiels acces. More... | |
ToolHandleArray< ITimedMatEffUpdator > | m_updators |
Array of Material Updators. More... | |
ToolHandleArray< IMultipleScatteringUpdator > | m_msupdators |
Array of MultipleScattering Updators. More... | |
ToolHandle< IEnergyLossUpdator > | m_elossupdater |
EnergyLoss Updater. More... | |
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... | |
std::vector< std::string > | m_propNames |
configuration of subPropagators More... | |
std::vector< std::string > | m_updatNames |
configuration of subUpdators More... | |
unsigned int | m_meotpIndex |
if several meotps are available in a volume steer which one to use More... | |
unsigned int | m_configurationLevel |
see the supported levels of configuration above More... | |
bool | m_includeMaterialEffects |
boolean to switch on/off material effects More... | |
bool | m_requireMaterialDestinationHit |
require the destination surface hit for material collection More... | |
bool | m_stopWithNavigationBreak |
return 0 if navigation breaks - for validation reasons More... | |
bool | m_stopWithUpdateZero |
return 0 if update kills the trajectory More... | |
bool | m_skipInitialLayerUpdate |
skip the initial post-Update at the layer [Fatras conversion mode] More... | |
bool | m_referenceMaterial |
use the reference material for the update More... | |
bool | m_extendedLayerSearch |
extended layer search More... | |
unsigned int | m_initialLayerAttempts |
allowed layer intersection attempts at the start of a volume More... | |
unsigned int | m_successiveLayerAttempts |
layer intersection attemps after one layer has been hit sucessfully More... | |
double | m_tolerance |
surfacen & volume tolerance More... | |
bool | m_caloMsSecondary |
handling of secondaries beyond ID More... | |
bool | m_activeOverlap |
consider overlaps between active muon volumes More... | |
bool | m_robustSampling |
bool | m_useDenseVolumeDescription |
use dense volume description when available in ID/Calo More... | |
bool | m_useMuonMatApprox |
use approximative MS inert material More... | |
bool | m_checkForCompundLayers |
use the multi-layer tests for compound layers More... | |
bool | m_resolveActive |
bool | m_resolveMultilayers |
bool | m_printHelpOutputAtInitialize |
bool | m_printRzOutput |
bool | m_navigationStatistics |
steer the output for the navigaiton statistics More... | |
bool | m_navigationBreakDetails |
steer the output for the navigation break details More... | |
bool | m_materialEffectsOnTrackValidation |
mat effects on track validation More... | |
unsigned int | m_maxNavigSurf |
unsigned int | m_maxNavigVol |
bool | m_fastField |
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 1326 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 2466 of file TimedExtrapolator.cxx.
|
private |
Definition at line 355 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 276 of file TimedExtrapolator.cxx.
|
overridevirtual |
AlgTool finalize method.
Definition at line 270 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 152 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 1318 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 1133 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 1306 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 456 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 463 of file TimedExtrapolator.h.
|
inlineoverridevirtual |
Return the TrackingGeometry used by the Extrapolator (forward information from Navigator)
Implements Trk::ITimedExtrapolator.
Definition at line 434 of file TimedExtrapolator.h.
|
private |
Definition at line 2147 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 1360 of file TimedExtrapolator.cxx.
|
private |
Definition at line 1429 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 1351 of file TimedExtrapolator.cxx.
|
private |
consider overlaps between active muon volumes
Definition at line 341 of file TimedExtrapolator.h.
|
private |
handling of secondaries beyond ID
Definition at line 337 of file TimedExtrapolator.h.
|
private |
use the multi-layer tests for compound layers
Definition at line 346 of file TimedExtrapolator.h.
|
private |
see the supported levels of configuration above
Definition at line 318 of file TimedExtrapolator.h.
|
privateinherited |
Pointer to StoreGate (detector store by default)
Definition at line 393 of file AthCommonDataStore.h.
|
private |
EnergyLoss Updater.
Definition at line 300 of file TimedExtrapolator.h.
|
privateinherited |
Pointer to StoreGate (event store by default)
Definition at line 390 of file AthCommonDataStore.h.
|
private |
extended layer search
Definition at line 329 of file TimedExtrapolator.h.
|
private |
Definition at line 427 of file TimedExtrapolator.h.
|
private |
Definition at line 428 of file TimedExtrapolator.h.
|
private |
boolean to switch on/off material effects
Definition at line 320 of file TimedExtrapolator.h.
|
private |
allowed layer intersection attempts at the start of a volume
Definition at line 330 of file TimedExtrapolator.h.
|
private |
mat effects on track validation
Definition at line 363 of file TimedExtrapolator.h.
|
private |
Definition at line 365 of file TimedExtrapolator.h.
|
private |
Definition at line 366 of file TimedExtrapolator.h.
|
private |
if several meotps are available in a volume steer which one to use
Definition at line 316 of file TimedExtrapolator.h.
|
private |
Array of MultipleScattering Updators.
Definition at line 299 of file TimedExtrapolator.h.
|
private |
steer the output for the navigation break details
Definition at line 360 of file TimedExtrapolator.h.
|
private |
steer the output for the navigaiton statistics
Definition at line 358 of file TimedExtrapolator.h.
|
private |
Navigator for TrackingGeometry and magnetic fiels acces.
Definition at line 295 of file TimedExtrapolator.h.
|
private |
Definition at line 353 of file TimedExtrapolator.h.
|
private |
Definition at line 354 of file TimedExtrapolator.h.
|
private |
Array of Propagators.
Definition at line 293 of file TimedExtrapolator.h.
|
private |
configuration of subPropagators
Definition at line 311 of file TimedExtrapolator.h.
|
private |
use the reference material for the update
Definition at line 328 of file TimedExtrapolator.h.
|
private |
require the destination surface hit for material collection
Definition at line 321 of file TimedExtrapolator.h.
|
private |
Definition at line 348 of file TimedExtrapolator.h.
|
private |
Definition at line 349 of file TimedExtrapolator.h.
|
private |
Definition at line 342 of file TimedExtrapolator.h.
|
private |
skip the initial post-Update at the layer [Fatras conversion mode]
Definition at line 326 of file TimedExtrapolator.h.
|
private |
Array of Propagators.
Definition at line 294 of file TimedExtrapolator.h.
|
private |
return 0 if navigation breaks - for validation reasons
Definition at line 323 of file TimedExtrapolator.h.
|
private |
return 0 if update kills the trajectory
Definition at line 325 of file TimedExtrapolator.h.
|
private |
Propagators to chose from (steered by signature)
Definition at line 305 of file TimedExtrapolator.h.
|
private |
Updators to chose from (steered by signature)
Definition at line 307 of file TimedExtrapolator.h.
|
private |
layer intersection attemps after one layer has been hit sucessfully
Definition at line 332 of file TimedExtrapolator.h.
|
private |
surfacen & volume tolerance
Definition at line 335 of file TimedExtrapolator.h.
|
private |
configuration of subUpdators
Definition at line 312 of file TimedExtrapolator.h.
|
private |
Array of Material Updators.
Definition at line 297 of file TimedExtrapolator.h.
|
private |
use dense volume description when available in ID/Calo
Definition at line 343 of file TimedExtrapolator.h.
|
private |
use approximative MS inert material
Definition at line 345 of file TimedExtrapolator.h.
|
privateinherited |
Definition at line 399 of file AthCommonDataStore.h.
|
privateinherited |
Definition at line 398 of file AthCommonDataStore.h.