ATLAS Offline Software
|
#include <UTPCMMClusterBuilderTool.h>
Public Types | |
using | RIO_Author = MMClusterOnTrack::Author |
Refinement of the cluster position after the cluster calibration loop is ran with a complete external constraint (e.g. More... | |
Public Member Functions | |
UTPCMMClusterBuilderTool (const std::string &, const std::string &, const IInterface *) | |
Default constructor. More... | |
virtual | ~UTPCMMClusterBuilderTool ()=default |
Default destructor. More... | |
virtual StatusCode | initialize () override |
standard initialize method More... | |
virtual StatusCode | getClusters (const EventContext &ctx, std::vector< Muon::MMPrepData > &&stripsVect, std::vector< std::unique_ptr< Muon::MMPrepData >> &clustersVect) const override |
Standard Interface to produce Micromega clusters from raw Input hits without external contstaint. More... | |
virtual RIO_Author | getCalibratedClusterPosition (const EventContext &ctx, const std::vector< NSWCalib::CalibratedStrip > &calibratedStrips, const Amg::Vector3D &directionEstimate, Amg::Vector2D &clusterLocalPosition, Amg::MatrixX &covMatrix) const override |
DeclareInterfaceID (Muon::IMMClusterBuilderTool, 1, 0) | |
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 |
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 | |
using | LaySortedPrds = std::array< std::vector< Muon::MMPrepData >, 8 > |
typedef ServiceHandle< StoreGateSvc > | StoreGateSvc_t |
Private Member Functions | |
StatusCode | runHoughTrafo (const std::vector< Muon::MMPrepData > &mmPrd, std::vector< double > &xpos, std::vector< int > &flag, std::vector< int > &idx_selected) const |
StatusCode | fillHoughTrafo (const std::vector< Muon::MMPrepData > &mmPrd, std::vector< double > &xpos, std::vector< int > &flag, std::unique_ptr< TH2D > &h_hough) const |
StatusCode | houghInitCummulator (std::unique_ptr< TH2D > &cummulator, double xmax, double xmin) const |
StatusCode | findAlphaMax (std::unique_ptr< TH2D > &h_hough, std::vector< std::tuple< double, double >> &maxPos) const |
StatusCode | selectTrack (const std::vector< Muon::MMPrepData > &mmPrd, std::vector< double > &xpos, std::vector< int > &flag, std::vector< std::tuple< double, double >> &tracks, std::vector< int > &idxGoodStrips) const |
StatusCode | transformParameters (double alpha, double d, double dRMS, double &slope, double &intercept, double &interceptRMS) const |
StatusCode | applyCrossTalkCut (std::vector< int > &idxSelected, const std::vector< MMPrepData > &MMPrdsOfLayer, std::vector< int > &flag, int &nStripsCut) const |
StatusCode | finalFit (const std::vector< Identifier > &ids, const std::vector< float > &stripsPos, const std::vector< float > &driftDists, const std::vector< AmgVector(2)> &driftDistErrors, double &x0, double &sigmaX0, double &fitAngle, double &chiSqProb) 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 | |
ServiceHandle< Muon::IMuonIdHelperSvc > | m_idHelperSvc {this, "MuonIdHelperSvc", "Muon::MuonIdHelperSvc/MuonIdHelperSvc"} |
Muon Detector Descriptor. More... | |
Gaudi::Property< bool > | m_writeStripProperties {this, "writeStripProperties", true } |
Gaudi::Property< double > | m_alphaMin {this, "HoughAlphaMin", -90. } |
Gaudi::Property< double > | m_alphaMax {this, "HoughAlphaMax", 0. } |
Gaudi::Property< double > | m_alphaResolution {this, "HoughAlphaResolution", 1.} |
Gaudi::Property< double > | m_selectionCut {this, "HoughSelectionCut", 1. * Gaudi::Units::mm} |
Gaudi::Property< double > | m_dMin {this, "HoughDMin", 0.} |
Gaudi::Property< double > | m_dMax {this, "HoughDMax", 0.} |
Gaudi::Property< double > | m_dResolution {this, "HoughDResolution", 0.125} |
Gaudi::Property< double > | m_driftRange {this, "HoughExpectedDriftRange", 12.*Gaudi::Units::m} |
Gaudi::Property< unsigned > | m_houghMinCounts {this, "HoughMinCounts", 3} |
Gaudi::Property< double > | m_outerChargeRatioCut {this,"outerChargeRatioCut", 0.} |
charge ratio cut to supress cross talk More... | |
Gaudi::Property< int > | m_maxStripsCut {this, "maxStripRemove", 4} |
Gaudi::Property< bool > | m_digiHasNegativeAngles {this, "digiHasNegativeAngle", true} |
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 |
Definition at line 27 of file UTPCMMClusterBuilderTool.h.
|
private |
Definition at line 49 of file UTPCMMClusterBuilderTool.h.
|
inherited |
Refinement of the cluster position after the cluster calibration loop is ran with a complete external constraint (e.g.
from the track fit). The cluster local position and the associated covariance are updated during this procedure Returns the Author of the ClusterBuilderTool, in case that the calibrated strip passes all internal constraints of the ClusterBuilder, otherwise Unknown author is returned. In the latter case, the Cluster should not be transformed into a calibrated RIO object.
ctx | EventContext used for StoreGate access |
calibratedStrips | Cluster constitutents after the calibration stage |
directionEstimate | Estimate of the direction given in the local frame |
clusterLocalPosition | Vector to which the final cluster position is saved to |
covMatrix | Uncertainty associated with the local position |
Definition at line 48 of file IMMClusterBuilderTool.h.
|
privateinherited |
Definition at line 388 of file AthCommonDataStore.h.
Muon::UTPCMMClusterBuilderTool::UTPCMMClusterBuilderTool | ( | const std::string & | t, |
const std::string & | n, | ||
const IInterface * | p | ||
) |
Default constructor.
Definition at line 30 of file UTPCMMClusterBuilderTool.cxx.
|
virtualdefault |
Default destructor.
|
private |
Definition at line 348 of file UTPCMMClusterBuilderTool.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.
|
inherited |
|
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
|
private |
Definition at line 242 of file UTPCMMClusterBuilderTool.cxx.
|
private |
Definition at line 388 of file UTPCMMClusterBuilderTool.cxx.
|
private |
Definition at line 256 of file UTPCMMClusterBuilderTool.cxx.
|
overridevirtual |
Implements Muon::IMMClusterBuilderTool.
Definition at line 463 of file UTPCMMClusterBuilderTool.cxx.
|
overridevirtual |
Standard Interface to produce Micromega clusters from raw Input hits without external contstaint.
Executes the clusterization algorithm & fills the results in the clusterVect Returns a failure in case of conditions or unexpected problems
ctx | EventContext used for StoreGate access |
stripsVect | Vector of the single Micromega hits. |
clusterVect | Output vector of the merged clusters |
Implements Muon::IMMClusterBuilderTool.
Definition at line 40 of file UTPCMMClusterBuilderTool.cxx.
|
private |
Definition at line 225 of file UTPCMMClusterBuilderTool.cxx.
|
overridevirtual |
standard initialize method
Definition at line 35 of file UTPCMMClusterBuilderTool.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.
|
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.
|
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 204 of file UTPCMMClusterBuilderTool.cxx.
|
private |
Definition at line 277 of file UTPCMMClusterBuilderTool.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.
|
private |
Definition at line 338 of file UTPCMMClusterBuilderTool.cxx.
|
inlineinherited |
Definition at line 308 of file AthCommonDataStore.h.
|
private |
Definition at line 57 of file UTPCMMClusterBuilderTool.h.
|
private |
Definition at line 56 of file UTPCMMClusterBuilderTool.h.
|
private |
Definition at line 58 of file UTPCMMClusterBuilderTool.h.
|
privateinherited |
Pointer to StoreGate (detector store by default)
Definition at line 393 of file AthCommonDataStore.h.
|
private |
Definition at line 71 of file UTPCMMClusterBuilderTool.h.
|
private |
Definition at line 61 of file UTPCMMClusterBuilderTool.h.
|
private |
Definition at line 60 of file UTPCMMClusterBuilderTool.h.
|
private |
Definition at line 62 of file UTPCMMClusterBuilderTool.h.
|
private |
Definition at line 63 of file UTPCMMClusterBuilderTool.h.
|
privateinherited |
Pointer to StoreGate (event store by default)
Definition at line 390 of file AthCommonDataStore.h.
|
private |
Definition at line 64 of file UTPCMMClusterBuilderTool.h.
|
private |
Muon Detector Descriptor.
Definition at line 51 of file UTPCMMClusterBuilderTool.h.
|
private |
Definition at line 69 of file UTPCMMClusterBuilderTool.h.
|
private |
charge ratio cut to supress cross talk
Definition at line 67 of file UTPCMMClusterBuilderTool.h.
|
private |
Definition at line 59 of file UTPCMMClusterBuilderTool.h.
|
privateinherited |
Definition at line 399 of file AthCommonDataStore.h.
|
privateinherited |
Definition at line 398 of file AthCommonDataStore.h.
|
private |
Definition at line 53 of file UTPCMMClusterBuilderTool.h.