ATLAS Offline Software
|
Main Fitter tool providing the implementation for the different fitting, extension and refitting use cases. More...
#include <MaterialAllocator.h>
Classes | |
class | compareByDistance |
Public Types | |
typedef std::vector< std::unique_ptr< const TrackStateOnSurface > > | Garbage_t |
Public Member Functions | |
MaterialAllocator (const std::string &type, const std::string &name, const IInterface *parent) | |
virtual | ~MaterialAllocator ()=default |
virtual StatusCode | initialize () override |
virtual StatusCode | finalize () override |
virtual void | addLeadingMaterial (std::vector< FitMeasurement * > &measurements, ParticleHypothesis particleHypothesis, FitParameters &fitParameters, Garbage_t &garbage) const override |
IMaterialAllocator interface: add leading material effects to fit measurements and parameters. More... | |
virtual void | allocateMaterial (std::vector< FitMeasurement * > &measurements, ParticleHypothesis particleHypothesis, FitParameters &fitParameters, const TrackParameters &startParameters, Garbage_t &garbage) const override |
IMaterialAllocator interface: allocate material. More... | |
virtual void | initializeScattering (std::vector< FitMeasurement * > &measurements) const override |
IMaterialAllocator interface: initialize scattering (needs to know X0 integral) More... | |
virtual std::vector< const TrackStateOnSurface * > * | leadingSpectrometerTSOS (const TrackParameters &spectrometerParameters, Garbage_t &garbage) const override |
IMaterialAllocator interface: material TSOS between spectrometer entrance surface and parameters given in spectrometer. More... | |
virtual void | orderMeasurements (std::vector< FitMeasurement * > &measurements, Amg::Vector3D startDirection, Amg::Vector3D startPosition) const override |
IMaterialAllocator interface: clear temporary TSOS. More... | |
virtual bool | reallocateMaterial (std::vector< FitMeasurement * > &measurements, FitParameters &fitParameters, Garbage_t &garbage) const override |
IMaterialAllocator interface: has material been reallocated? 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 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 | addSpectrometerDelimiters (std::vector< FitMeasurement * > &measurements) const |
const std::vector< const TrackStateOnSurface * > * | extrapolatedMaterial (const ToolHandle< IExtrapolator > &extrapolator, const TrackParameters ¶meters, const Surface &surface, PropDirection dir, const BoundaryCheck &boundsCheck, ParticleHypothesis particleHypothesis, Garbage_t &garbage) const |
void | indetMaterial (std::vector< FitMeasurement * > &measurements, ParticleHypothesis particleHypothesis, const TrackParameters &startParameters, Garbage_t &garbage) const |
std::pair< FitMeasurement *, FitMeasurement * > | materialAggregation (const std::vector< const TrackStateOnSurface * > &material, std::vector< FitMeasurement * > &measurements, double particleMass) const |
void | materialAggregation (std::vector< FitMeasurement * > &measurements, double particleMass) const |
void | printMeasurements (std::vector< FitMeasurement * > &measurements) const |
void | spectrometerMaterial (std::vector< FitMeasurement * > &measurements, ParticleHypothesis particleHypothesis, FitParameters &fitParameters, const TrackParameters &startParameters, Garbage_t &garbage) const |
const Trk::TrackingVolume * | getSpectrometerEntrance () 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... | |
Static Private Member Functions | |
static void | deleteMaterial (const std::vector< const TrackStateOnSurface * > *material, Garbage_t &garbage) |
static FitMeasurement * | measurementFromTSOS (const TrackStateOnSurface &tsos, double outwardsEnergy, double particleMass) |
Private Attributes | |
ToolHandle< IExtrapolator > | m_extrapolator |
ToolHandle< IIntersector > | m_intersector |
ServiceHandle< ITrackingGeometrySvc > | m_trackingGeometrySvc |
ServiceHandle< ITrackingVolumesSvc > | m_trackingVolumesSvc |
ToolHandle< IPropagator > | m_stepPropagator |
SG::ReadCondHandleKey< TrackingGeometry > | m_trackingGeometryReadKey |
bool | m_aggregateMaterial |
bool | m_allowReordering |
int | m_useStepPropagator |
unsigned | m_maxWarnings |
double | m_orderingTolerance |
double | m_scattererMinGap |
double | m_scatteringConstant |
double | m_scatteringLogCoeff |
double | m_sectorMaxPhi |
double | m_stationMaxGap |
const Trk::Volume * | m_calorimeterVolume |
const Trk::Volume * | m_indetVolume |
Trk::MagneticFieldProperties | m_stepField |
std::unique_ptr< MessageHelper > | m_messageHelper |
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 |
Main Fitter tool providing the implementation for the different fitting, extension and refitting use cases.
Definition at line 50 of file MaterialAllocator.h.
|
inherited |
Definition at line 40 of file IMaterialAllocator.h.
|
privateinherited |
Definition at line 388 of file AthCommonDataStore.h.
Trk::MaterialAllocator::MaterialAllocator | ( | const std::string & | type, |
const std::string & | name, | ||
const IInterface * | parent | ||
) |
Definition at line 38 of file MaterialAllocator.cxx.
|
virtualdefault |
|
overridevirtual |
IMaterialAllocator interface: add leading material effects to fit measurements and parameters.
Implements Trk::IMaterialAllocator.
Definition at line 133 of file MaterialAllocator.cxx.
|
private |
Definition at line 877 of file MaterialAllocator.cxx.
|
overridevirtual |
IMaterialAllocator interface: allocate material.
Implements Trk::IMaterialAllocator.
Definition at line 520 of file MaterialAllocator.cxx.
|
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.
|
staticprivate |
Definition at line 990 of file MaterialAllocator.cxx.
|
inlineinherited |
The standard StoreGateSvc/DetectorStore
Returns (kind of) a pointer to the StoreGateSvc
.
Definition at line 95 of file AthCommonDataStore.h.
|
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 1002 of file MaterialAllocator.cxx.
|
overridevirtual |
Definition at line 127 of file MaterialAllocator.cxx.
|
inlineprivate |
Good old way of retrieving the volume via the geometry service
Definition at line 158 of file MaterialAllocator.h.
|
private |
Definition at line 1053 of file MaterialAllocator.cxx.
|
overridevirtual |
Definition at line 74 of file MaterialAllocator.cxx.
|
overridevirtual |
IMaterialAllocator interface: initialize scattering (needs to know X0 integral)
Implements Trk::IMaterialAllocator.
Definition at line 537 of file MaterialAllocator.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 46 of file IMaterialAllocator.h.
|
overridevirtual |
IMaterialAllocator interface: material TSOS between spectrometer entrance surface and parameters given in spectrometer.
Implements Trk::IMaterialAllocator.
Definition at line 608 of file MaterialAllocator.cxx.
|
private |
Definition at line 1468 of file MaterialAllocator.cxx.
|
private |
Definition at line 1520 of file MaterialAllocator.cxx.
|
staticprivate |
Definition at line 1881 of file MaterialAllocator.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.
|
overridevirtual |
IMaterialAllocator interface: clear temporary TSOS.
Implements Trk::IMaterialAllocator.
Definition at line 696 of file MaterialAllocator.cxx.
|
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 |
Definition at line 1899 of file MaterialAllocator.cxx.
|
overridevirtual |
IMaterialAllocator interface: has material been reallocated?
Implements Trk::IMaterialAllocator.
Definition at line 752 of file MaterialAllocator.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 2009 of file MaterialAllocator.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 174 of file MaterialAllocator.h.
|
private |
Definition at line 175 of file MaterialAllocator.h.
|
private |
Definition at line 189 of file MaterialAllocator.h.
|
privateinherited |
Pointer to StoreGate (detector store by default)
Definition at line 393 of file AthCommonDataStore.h.
|
privateinherited |
Pointer to StoreGate (event store by default)
Definition at line 390 of file AthCommonDataStore.h.
|
private |
Definition at line 141 of file MaterialAllocator.h.
|
private |
Definition at line 190 of file MaterialAllocator.h.
|
private |
Definition at line 143 of file MaterialAllocator.h.
|
private |
Definition at line 177 of file MaterialAllocator.h.
|
private |
Definition at line 195 of file MaterialAllocator.h.
|
private |
Definition at line 181 of file MaterialAllocator.h.
|
private |
Definition at line 182 of file MaterialAllocator.h.
|
private |
Definition at line 183 of file MaterialAllocator.h.
|
private |
Definition at line 184 of file MaterialAllocator.h.
|
private |
Definition at line 185 of file MaterialAllocator.h.
|
private |
Definition at line 186 of file MaterialAllocator.h.
|
private |
Definition at line 192 of file MaterialAllocator.h.
|
private |
Definition at line 151 of file MaterialAllocator.h.
|
private |
Definition at line 154 of file MaterialAllocator.h.
|
private |
Definition at line 146 of file MaterialAllocator.h.
|
private |
Definition at line 148 of file MaterialAllocator.h.
|
private |
Definition at line 176 of file MaterialAllocator.h.
|
privateinherited |
Definition at line 399 of file AthCommonDataStore.h.
|
privateinherited |
Definition at line 398 of file AthCommonDataStore.h.