ATLAS Offline Software
|
Main Fitter tool providing the implementation for the different fitting, extension and refitting use cases. More...
#include <iPatFitter.h>
Classes | |
class | FitState |
Public Types | |
typedef IMaterialAllocator::Garbage_t | Garbage_t |
Public Member Functions | |
iPatFitter (const std::string &type, const std::string &name, const IInterface *parent, bool isGlobalFit=false) | |
virtual | ~iPatFitter ()=default |
virtual StatusCode | initialize () override |
virtual StatusCode | finalize () override |
virtual std::unique_ptr< Track > | fit (const EventContext &ctx, const Track &, const RunOutlierRemoval runOutlier=false, const ParticleHypothesis particleHypothesis=Trk::nonInteracting) const override |
RE-FIT A TRACK. More... | |
virtual std::unique_ptr< Track > | fit (const EventContext &ctx, const Track &, const PrepRawDataSet &, const RunOutlierRemoval runOutlier=false, const ParticleHypothesis particleHypothesis=Trk::nonInteracting) const override |
RE-FIT A TRACK, ADDING A PRD SET. More... | |
virtual std::unique_ptr< Track > | fit (const EventContext &ctx, const PrepRawDataSet &, const TrackParameters &perigeeStartValue, const RunOutlierRemoval runOutlier=false, const ParticleHypothesis particleHypothesis=Trk::nonInteracting) const override |
FIT A TRACK TO A SET OF PrepRawData. More... | |
virtual std::unique_ptr< Track > | fit (const EventContext &ctx, const Track &, const MeasurementSet &, const RunOutlierRemoval runOutlier=false, const ParticleHypothesis particleHypothesis=Trk::nonInteracting) const override |
RE-FIT A TRACK, ADDING A FITTABLE MEASUREMENT SET. More... | |
virtual std::unique_ptr< Track > | fit (const EventContext &ctx, const MeasurementSet &, const TrackParameters &perigeeStartValue, const RunOutlierRemoval runOutlier=false, const ParticleHypothesis particleHypothesis=Trk::nonInteracting) const override |
FIT A TRACK TO A SET OF MEASUREMENTBASE. More... | |
virtual std::unique_ptr< Track > | fit (const EventContext &ctx, const Track &, const Track &, const RunOutlierRemoval runOutlier=false, const ParticleHypothesis particleHypothesis=Trk::nonInteracting) const override |
COMBINE TWO TRACKS BY REFITTING. 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 () |
Protected Member Functions | |
std::pair< std::unique_ptr< Track >, std::unique_ptr< FitState > > | fitWithState (const EventContext &ctx, const Track &, const RunOutlierRemoval runOutlier=false, const ParticleHypothesis particleHypothesis=Trk::nonInteracting) const |
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... | |
Protected Attributes | |
std::unique_ptr< FitProcedure > | m_fitProcedure |
std::mutex | m_fitProcedureMutex |
const bool | m_globalFit = false |
Private Types | |
typedef ServiceHandle< StoreGateSvc > | StoreGateSvc_t |
Private Member Functions | |
void | addMeasurements (const EventContext &ctx, std::vector< FitMeasurement * > &measurements, const MeasurementSet &measurementSet, const FitParameters ¶meters) const |
bool | addMeasurements (const EventContext &ctx, std::vector< FitMeasurement * > &measurements, const FitParameters ¶meters, ParticleHypothesis particleHypothesis, const Trk::TrackStates &trackTSOS) const |
std::unique_ptr< Track > | performFit (FitState &fitState, const ParticleHypothesis particleHypothesis, const TrackInfo &trackInfo, const Trk::TrackStates *leadingTSOS, const FitQuality *perigeeQuality, Garbage_t &garbage) const |
void | printTSOS (const Track &) const |
void | refit (const EventContext &ctx, FitState &fitState, const Track &track, const RunOutlierRemoval runOutlier, const ParticleHypothesis particleHypothesis) 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 | |
Gaudi::Property< bool > | m_aggregateMaterial {this, "AggregateMaterial", true} |
Gaudi::Property< bool > | m_asymmetricCaloEnergy |
Gaudi::Property< bool > | m_fullCombinedFit {this, "FullCombinedFit", true} |
Gaudi::Property< bool > | m_lineFit {this, "LineFit", false} |
Gaudi::Property< double > | m_lineMomentum |
ToolHandle< IMaterialAllocator > | m_materialAllocator |
ToolHandle< IIntersector > | m_rungeKuttaIntersector |
ToolHandle< IIntersector > | m_solenoidalIntersector |
ToolHandle< IPropagator > | m_stepPropagator |
ToolHandle< IIntersector > | m_straightLineIntersector |
ServiceHandle< ITrackingVolumesSvc > | m_trackingVolumesSvc |
ToolHandle< Trk::IExtendedTrackSummaryTool > | m_trackSummaryTool |
Gaudi::Property< double > | m_orderingTolerance |
Gaudi::Property< unsigned > | m_maxWarnings |
Gaudi::Property< bool > | m_constrainedAlignmentEffects |
Gaudi::Property< bool > | m_extendedDebug {this, "ExtendedDebug", false} |
Gaudi::Property< int > | m_forcedRefitsForValidation |
Gaudi::Property< int > | m_maxIterations {this, "MaxIterations", 25} |
std::unique_ptr< Trk::Volume > | m_calorimeterVolume |
std::unique_ptr< Trk::Volume > | m_indetVolume |
Trk::MagneticFieldProperties | m_stepField |
std::atomic< unsigned > | m_countFitAttempts = 0 |
std::atomic< unsigned > | m_countGoodFits = 0 |
std::atomic< unsigned > | m_countIterations = 0 |
std::atomic< unsigned > | m_countRefitAttempts = 0 |
std::atomic< unsigned > | m_countGoodRefits = 0 |
std::atomic< unsigned > | m_countRefitIterations = 0 |
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 37 of file iPatFitter.h.
Definition at line 39 of file iPatFitter.h.
|
privateinherited |
Definition at line 388 of file AthCommonDataStore.h.
Trk::iPatFitter::iPatFitter | ( | const std::string & | type, |
const std::string & | name, | ||
const IInterface * | parent, | ||
bool | isGlobalFit = false |
||
) |
Definition at line 40 of file iPatFitter.cxx.
|
virtualdefault |
|
private |
Definition at line 593 of file iPatFitter.cxx.
|
private |
Definition at line 520 of file iPatFitter.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.
|
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
|
overridevirtual |
Definition at line 135 of file iPatFitter.cxx.
|
overridevirtual |
FIT A TRACK TO A SET OF MEASUREMENTBASE.
Main fit method. The TrackParameters is a first estimate for the track, represented close to the origin.
Implements Trk::ITrackFitter.
Definition at line 346 of file iPatFitter.cxx.
|
overridevirtual |
FIT A TRACK TO A SET OF PrepRawData.
Main fit method. The TrackParameters is a first estimate for the track, represented close to the origin. Use-cases can be thought of that make it necessary to control toggling outlier removal and material effects not via job options (once-per-job) but at each call (toggle within event, large set of fast fit followed by one final full fit).
Implements Trk::ITrackFitter.
Definition at line 283 of file iPatFitter.cxx.
|
overridevirtual |
RE-FIT A TRACK, ADDING A FITTABLE MEASUREMENT SET.
this method will use the vector of measurements from the existing track and refit adding the new measurements. The code is in this class, but can be overwritten by inheriting classes.
Implements Trk::ITrackFitter.
Definition at line 294 of file iPatFitter.cxx.
|
overridevirtual |
RE-FIT A TRACK, ADDING A PRD SET.
this method will disintegrate the track back to PRD and call the fit(PRDset) method.
Implements Trk::ITrackFitter.
Definition at line 272 of file iPatFitter.cxx.
|
overridevirtual |
|
overridevirtual |
COMBINE TWO TRACKS BY REFITTING.
Specifically designed for combined muon fits, allowing to extract extra informations (ID-exit & MS-entrance parameters, layers, Mefos) from already fitted tracks.
Implements Trk::ITrackFitter.
Definition at line 385 of file iPatFitter.cxx.
|
protected |
Definition at line 179 of file iPatFitter.cxx.
|
overridevirtual |
Definition at line 49 of file iPatFitter.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 |
Definition at line 45 of file ITrackFitter.h.
|
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 |
Definition at line 1093 of file iPatFitter.cxx.
|
private |
Definition at line 1131 of file iPatFitter.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.
|
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 183 of file iPatFitter.h.
|
private |
Definition at line 184 of file iPatFitter.h.
|
private |
Definition at line 225 of file iPatFitter.h.
|
private |
Definition at line 217 of file iPatFitter.h.
|
mutableprivate |
Definition at line 230 of file iPatFitter.h.
|
mutableprivate |
Definition at line 231 of file iPatFitter.h.
|
mutableprivate |
Definition at line 234 of file iPatFitter.h.
|
mutableprivate |
Definition at line 232 of file iPatFitter.h.
|
mutableprivate |
Definition at line 233 of file iPatFitter.h.
|
mutableprivate |
Definition at line 235 of file iPatFitter.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 219 of file iPatFitter.h.
|
protected |
Definition at line 148 of file iPatFitter.h.
|
mutableprotected |
Definition at line 149 of file iPatFitter.h.
|
private |
Definition at line 220 of file iPatFitter.h.
|
private |
Definition at line 186 of file iPatFitter.h.
|
protected |
Definition at line 152 of file iPatFitter.h.
|
private |
Definition at line 226 of file iPatFitter.h.
|
private |
Definition at line 187 of file iPatFitter.h.
|
private |
Definition at line 188 of file iPatFitter.h.
|
private |
Definition at line 191 of file iPatFitter.h.
|
private |
Definition at line 222 of file iPatFitter.h.
|
private |
Definition at line 212 of file iPatFitter.h.
|
private |
Definition at line 238 of file iPatFitter.h.
|
private |
Definition at line 210 of file iPatFitter.h.
|
private |
Definition at line 193 of file iPatFitter.h.
|
private |
Definition at line 196 of file iPatFitter.h.
|
private |
Definition at line 227 of file iPatFitter.h.
|
private |
Definition at line 199 of file iPatFitter.h.
|
private |
Definition at line 201 of file iPatFitter.h.
|
private |
Definition at line 204 of file iPatFitter.h.
|
private |
Definition at line 206 of file iPatFitter.h.
|
privateinherited |
Definition at line 399 of file AthCommonDataStore.h.
|
privateinherited |
Definition at line 398 of file AthCommonDataStore.h.