ATLAS Offline Software
Loading...
Searching...
No Matches
MuonCalib::MuonSegmentReader Class Reference

#include <MuonSegmentReader.h>

Inheritance diagram for MuonCalib::MuonSegmentReader:

Public Member Functions

virtual StatusCode initialize () override
virtual StatusCode execute () override
virtual StatusCode finalize () override
unsigned int cardinality () const override final
 AthHistogramAlgorithm (const std::string &name, ISvcLocator *pSvcLocator)
 Constructor with parameters:
virtual StatusCode sysInitialize ()
 Initialization method invoked by the framework.
const ServiceHandle< ITHistSvc > & histSvc () const
 The standard THistSvc (for writing histograms and TTrees and more to a root file) Returns (kind of) a pointer to the THistSvc.
virtual const DataObjIDColl & extraOutputDeps () const override
 Return the list of extra output dependencies.
ServiceHandle< StoreGateSvc > & evtStore ()
 The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.
const ServiceHandle< StoreGateSvc > & detStore () const
 The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.
virtual StatusCode sysStart () override
 Handle START transition.
virtual std::vector< Gaudi::DataHandle * > inputHandles () const override
 Return this algorithm's input handles.
virtual std::vector< Gaudi::DataHandle * > outputHandles () const override
 Return this algorithm's output handles.
Gaudi::Details::PropertyBase & declareProperty (Gaudi::Property< T, V, H > &t)
void updateVHKA (Gaudi::Details::PropertyBase &)
MsgStream & msg () const
bool msgLvl (const MSG::Level lvl) const

Protected Member Functions

void renounceArray (SG::VarHandleKeyArray &handlesArray)
 remove all handles from I/O resolution
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.
StatusCode configAthHistogramming (const ServiceHandle< ITHistSvc > &histSvc, const std::string &prefix, const std::string &rootDir, const std::string &histNamePrefix, const std::string &histNamePostfix, const std::string &histTitlePrefix, const std::string &histTitlePostfix)
 To be called by the derived classes to fill the internal configuration.
TH1 * bookGetPointer (const TH1 &hist, const std::string &tDir="", const std::string &stream="")
 Simplify the booking and registering (into THistSvc) of histograms.
TH1 * bookGetPointer (TH1 *hist, const std::string &tDir="", const std::string &stream="")
 Simplify the booking and registering (into THistSvc) of histograms.
TH1 * bookGetPointer (TH1 &histRef, std::string tDir="", std::string stream="")
 Simplify the booking and registering (into THistSvc) of histograms.
TTree * bookGetPointer (const TTree &treeRef, std::string tDir="", std::string stream="")
 Simplify the booking and registering (into THistSvc) of TTrees.
TGraph * bookGetPointer (const TGraph &graphRef, std::string tDir="", std::string stream="")
 Simplify the booking and registering (into THistSvc) of TGraphs.
TEfficiency * bookGetPointer (const TEfficiency &eff, const std::string &tDir="", const std::string &stream="")
 Simplify the booking and registering (into THistSvc) of TEfficiency.
TEfficiency * bookGetPointer (TEfficiency *eff, const std::string &tDir="", const std::string &stream="")
 Simplify the booking and registering (into THistSvc) of TEfficiency.
TEfficiency * bookGetPointer (TEfficiency &effRef, std::string tDir="", std::string stream="")
 Simplify the booking and registering (into THistSvc) of TEfficiency.
StatusCode book (const TH1 &hist, const std::string &tDir="", const std::string &stream="")
 Simplify the booking and registering (into THistSvc) of histograms.
StatusCode book (TH1 *hist, const std::string &tDir="", const std::string &stream="")
 Simplify the booking and registering (into THistSvc) of histograms.
StatusCode book (TH1 &histRef, const std::string &tDir="", const std::string &stream="")
 Simplify the booking and registering (into THistSvc) of histograms.
StatusCode book (const TTree &treeRef, const std::string &tDir="", const std::string &stream="")
 Simplify the booking and registering (into THistSvc) of TTrees.
StatusCode book (const TGraph &graphRef, const std::string &tDir="", const std::string &stream="")
 Simplify the booking and registering (into THistSvc) of TGraphs.
StatusCode book (const TEfficiency &eff, const std::string &tDir="", const std::string &stream="")
 Simplify the booking and registering (into THistSvc) of TEfficiency.
StatusCode book (TEfficiency *eff, const std::string &tDir="", const std::string &stream="")
 Simplify the booking and registering (into THistSvc) of TEfficiency.
StatusCode book (TEfficiency &effRef, const std::string &tDir="", const std::string &stream="")
 Simplify the booking and registering (into THistSvc) of TEfficiency.
TH1 * hist (const std::string &histName, const std::string &tDir="", const std::string &stream="")
 Simplify the retrieval of registered histograms of any type.
TH2 * hist2d (const std::string &histName, const std::string &tDir="", const std::string &stream="")
 Simplify the retrieval of registered 2-d histograms.
TH3 * hist3d (const std::string &histName, const std::string &tDir="", const std::string &stream="")
 Simplify the retrieval of registered 3-d histograms.
TTree * tree (const std::string &treeName, const std::string &tDir="", const std::string &stream="")
 Simplify the retrieval of registered TTrees.
TGraph * graph (const std::string &graphName, const std::string &tDir="", const std::string &stream="")
 Simplify the retrieval of registered TGraphs.
TEfficiency * efficiency (const std::string &effName, const std::string &tDir="", const std::string &stream="")
 Simplify the retrieval of registered TEfficiency.

Private Types

typedef ServiceHandle< StoreGateSvcStoreGateSvc_t
typedef uint32_t hash_t
 typedef for the internal hash
typedef std::map< const hash_t, TH1 * > HistMap_t
 Typedef for convenience.
typedef std::map< const hash_t, TEfficiency * > EffMap_t
 Typedef for convenience.
typedef std::map< const hash_t, TTree * > TreeMap_t
 Typedef for convenience.
typedef std::map< const hash_t, TGraph * > GraphMap_t
 Typedef for convenience.

Private Member Functions

void storeMeasurement (const EventContext &ctx, const MuonGM::MuonDetectorManager *MuonDetMgr, unsigned int itrk, const Trk::TrackStateOnSurface *trk_state, const Trk::MeasurementBase *measurement)
void storeHole (const Trk::TrackStateOnSurface *trk_state, unsigned int itrk)
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
 specialization for handling Gaudi::Property<SG::VarHandleKey>
void buildBookingString (std::string &bookingString, std::string &histName, std::string &tDir, std::string &stream, bool usePrefixPostfix=false)
 Method to build individual booking string.
void myReplace (std::string &str, const std::string &oldStr, const std::string &newStr)
 Helper method to replace sub-string.
hash_t hash (const std::string &histName) const
 Method to calculate a 32-bit hash from a string.

Private Attributes

SG::ReadHandleKey< xAOD::EventInfom_evtKey {this, "EventInfoKey", "EventInfo", "xAOD::EventInfo ReadHandleKey"}
SG::ReadHandleKey< TrackCollectionm_TrkKey {this, "MuonTrackLocations", "MuonSpectrometerTracks"}
SG::ReadHandleKey< Muon::MdtPrepDataContainerm_MdtPrepDataKey {this, "MdtPrepData", "MDT_DriftCircles","MDT DriftCircles"}
SG::ReadHandleKey< Muon::RpcPrepDataContainerm_RpcPrepDataKey {this,"RpcPrdCollection","RPC_Measurements","RPC PRD Container"}
SG::ReadHandleKey< Muon::TgcPrepDataContainerm_TgcPrepDataKey {this,"TgcPrdCollection","TGC_Measurements","TGC PRD Container"}
SG::ReadCondHandleKey< MuonGM::MuonDetectorManagerm_DetectorManagerKey
 MuonDetectorManager from the conditions store.
ServiceHandle< Muon::IMuonIdHelperSvcm_MuonIdHelper
ToolHandle< IMdtCalibrationToolm_calibrationTool {this, "CalibrationTool", "MdtCalibrationTool"}
 pointer to MdtCalibSvc
PublicToolHandle< Trk::IResidualPullCalculatorm_pullCalculator
ToolHandle< MuonCalib::IIdToFixedIdToolm_idToFixedIdTool {this, "IdToFixedIdTool", "MuonCalib::IdToFixedIdTool/MuonCalib_IdToFixedIdTool"}
PublicToolHandle< Muon::MuonEDMPrinterToolm_printer {this, "Printer", "Muon::MuonEDMPrinterTool/MuonEDMPrinterTool"}
MuonTesterTree m_tree {"Segments", "CALIBNTUPLESTREAM"}
ScalarBranch< int > & m_runNumber {m_tree.newScalar<int>("event_runNumber")}
ScalarBranch< int > & m_eventNumber {m_tree.newScalar<int>("event_eventNumber")}
ScalarBranch< int > & m_lumiBlock {m_tree.newScalar<int>("event_lumiBlock")}
ScalarBranch< int > & m_bcId {m_tree.newScalar<int>("event_bcId")}
ScalarBranch< int > & m_timeStamp {m_tree.newScalar<int>("event_timeStamp")}
ScalarBranch< float > & m_pt {m_tree.newScalar<float>("event_LVL2Pt")}
ScalarBranch< int > & m_rawMdt_nRMdt {m_tree.newScalar<int>("rawMdt_nRMdt")}
VectorBranch< unsigned int > & m_rawMdt_id {m_tree.newVector<unsigned int>("rawMdt_id")}
VectorBranch< int > & m_rawMdt_tdc {m_tree.newVector<int>("rawMdt_tdc")}
VectorBranch< int > & m_rawMdt_adc {m_tree.newVector<int>("rawMdt_adc")}
ThreeVectorBranch m_rawMdt_gPos {m_tree,"rawMdt_gPos"}
ScalarBranch< int > & m_rawRpc_nRRpc {m_tree.newScalar<int>("rawRpc_nRRpc")}
VectorBranch< unsigned int > & m_rawRpc_id {m_tree.newVector<unsigned int>("rawRpc_id")}
VectorBranch< float > & m_rawRpc_time {m_tree.newVector<float>("rawRpc_time")}
ThreeVectorBranch m_rawRpc_gPos {m_tree,"rawRpc_gPos"}
ScalarBranch< int > & m_rawTgc_nRTgc {m_tree.newScalar<int>("rawTgc_nRTgc")}
VectorBranch< unsigned int > & m_rawTgc_id {m_tree.newVector<unsigned int>("rawTgc_id")}
VectorBranch< int > & m_rawTgc_bcBitMap {m_tree.newVector<int>("rawTgc_bcBitMap")}
ThreeVectorBranch m_rawTgc_gPos {m_tree,"rawTgc_gPos"}
ScalarBranch< int > & m_trk_nTracks {m_tree.newScalar<int>("trk_nTracks")}
VectorBranch< float > & m_trk_d0 {m_tree.newVector<float>("trk_d0")}
VectorBranch< float > & m_trk_z0 {m_tree.newVector<float>("trk_z0")}
VectorBranch< float > & m_trk_phi {m_tree.newVector<float>("trk_phi")}
VectorBranch< float > & m_trk_theta {m_tree.newVector<float>("trk_theta")}
VectorBranch< float > & m_trk_eta {m_tree.newVector<float>("trk_eta")}
VectorBranch< float > & m_trk_qOverP {m_tree.newVector<float>("trk_qOverP")}
VectorBranch< float > & m_trk_pt {m_tree.newVector<float>("trk_pt")}
VectorBranch< float > & m_trk_chi2 {m_tree.newVector<float>("trk_chi2")}
VectorBranch< int > & m_trk_ndof {m_tree.newVector<int>("trk_ndof")}
VectorBranch< int > & m_trk_author {m_tree.newVector<int>("trk_author")}
ThreeVectorBranch m_trk_perigee {m_tree,"trk_perigee"}
VectorBranch< int > & m_trk_nMdtHits {m_tree.newVector<int>("trk_nMdtHits")}
VectorBranch< int > & m_trk_nMdtHoles {m_tree.newVector<int>("trk_nMdtHoles")}
VectorBranch< int > & m_trk_nOutliersHits {m_tree.newVector<int>("trk_nOutliersHits")}
VectorBranch< int > & m_trk_nRpcPhiHits {m_tree.newVector<int>("trk_nRpcPhiHits")}
VectorBranch< int > & m_trk_nRpcEtaHits {m_tree.newVector<int>("trk_nRpcEtaHits")}
VectorBranch< int > & m_trk_nTgcPhiHits {m_tree.newVector<int>("trk_nTgcPhiHits")}
VectorBranch< int > & m_trk_nTgcEtaHits {m_tree.newVector<int>("trk_nTgcEtaHits")}
ScalarBranch< int > & m_trkHit_nMdtHits {m_tree.newScalar<int>("trkHit_nMdtHits")}
VectorBranch< int > & m_trkHit_trackIndex {m_tree.newVector<int>("trkHit_trackIndex")}
ThreeVectorBranch m_trkHit_gPos {m_tree,"trkHit_gPos"}
ThreeVectorBranch m_trkHit_pos {m_tree,"trkHit_pos"}
ThreeVectorBranch m_trkHit_closestApproach {m_tree,"trkHit_closestApproach"}
ThreeVectorBranch m_trkHit_gClosestApproach {m_tree,"trkHit_gClosestApproach"}
ThreeVectorBranch m_trkHit_center {m_tree,"trkHit_center"}
VectorBranch< int > & m_trkHit_adc {m_tree.newVector<int>("trkHit_adc")}
VectorBranch< int > & m_trkHit_type {m_tree.newVector<int>("trkHit_type")}
VectorBranch< int > & m_trkHit_tdc {m_tree.newVector<int>("trkHit_tdc")}
VectorBranch< float > & m_trkHit_resi {m_tree.newVector<float>("trkHit_resi")}
VectorBranch< float > & m_trkHit_pull {m_tree.newVector<float>("trkHit_pull")}
VectorBranch< unsigned int > & m_trkHit_id {m_tree.newVector<unsigned int>("trkHit_id")}
VectorBranch< float > & m_trkHit_driftRadius {m_tree.newVector<float>("trkHit_driftRadius")}
VectorBranch< float > & m_trkHit_error {m_tree.newVector<float>("trkHit_error")}
VectorBranch< float > & m_trkHit_rTrk {m_tree.newVector<float>("trkHit_rTrk")}
VectorBranch< float > & m_trkHit_driftTime {m_tree.newVector<float>("trkHit_driftTime")}
VectorBranch< float > & m_trkHit_distRO {m_tree.newVector<float>("trkHit_distRO")}
VectorBranch< float > & m_trkHit_localAngle {m_tree.newVector<float>("trkHit_localAngle")}
VectorBranch< float > & m_trkHit_tubeT0 {m_tree.newVector<float>("trkHit_tubeT0")}
VectorBranch< float > & m_trkHit_triggerTime {m_tree.newVector<float>("trkHit_triggerTime")}
VectorBranch< float > & m_trkHit_tubeMeanAdc {m_tree.newVector<float>("trkHit_tubeMeanAdc")}
VectorBranch< float > & m_trkHit_slewTime {m_tree.newVector<float>("trkHit_slewTime")}
VectorBranch< float > & m_trkHit_lorTime {m_tree.newVector<float>("trkHit_lorTime")}
VectorBranch< float > & m_trkHit_propTime {m_tree.newVector<float>("trkHit_propTime")}
VectorBranch< float > & m_trkHit_tempTime {m_tree.newVector<float>("trkHit_tempTime")}
VectorBranch< float > & m_trkHit_bkgTime {m_tree.newVector<float>("trkHit_bkgTime")}
VectorBranch< float > & m_trkHit_tof {m_tree.newVector<float>("trkHit_tof")}
VectorBranch< int > & m_trkHit_calibStatus {m_tree.newVector<int>("trkHit_calibStatus")}
ScalarBranch< int > & m_trkHole_nHoles {m_tree.newScalar<int>("trkHole_nHoles")}
VectorBranch< int > & m_trkHole_trackIndex {m_tree.newVector<int>("trkHole_trackIndex")}
VectorBranch< int > & m_trkHole_type {m_tree.newVector<int>("trkHole_type")}
ThreeVectorBranch m_trkHole_gPos {m_tree,"trkHole_gPos"}
VectorBranch< unsigned int > & m_trkHole_id {m_tree.newVector<unsigned int>("trkHole_id")}
VectorBranch< float > & m_trkHole_driftRadius {m_tree.newVector<float>("trkHole_driftRadius")}
ScalarBranch< int > & m_trkTriggerHit_nHits {m_tree.newScalar<int>("trkTriggerHit_nHits")}
VectorBranch< int > & m_trkTriggerHit_trackIndex {m_tree.newVector<int>("trkTriggerHit_trackIndex")}
VectorBranch< int > & m_trkTriggerHit_type {m_tree.newVector<int>("trkTriggerHit_type")}
ThreeVectorBranch m_trkTriggerHit_gPos {m_tree,"trkTriggerHit_gPos"}
VectorBranch< unsigned int > & m_trkTriggerHit_id {m_tree.newVector<unsigned int>("trkTriggerHit_id")}
VectorBranch< float > & m_trkTriggerHit_time {m_tree.newVector<float>("trkTriggerHit_time")}
ServiceHandle< ITHistSvc > m_histSvc
 Default constructor: AthHistogramAlgorithm();.
std::string m_prefix
 Name of the ROOT output stream (file)
std::string m_rootDir
 Name of the ROOT directory.
std::string m_histNamePrefix
 The prefix for the histogram THx name.
std::string m_histNamePostfix
 The postfix for the histogram THx name.
std::string m_histTitlePrefix
 The prefix for the histogram THx title.
std::string m_histTitlePostfix
 The postfix for the histogram THx title.
DataObjIDColl m_extendedExtraObjects
StoreGateSvc_t m_evtStore
 Pointer to StoreGate (event store by default)
StoreGateSvc_t m_detStore
 Pointer to StoreGate (detector store by default)
std::vector< SG::VarHandleKeyArray * > m_vhka
bool m_varHandleArraysDeclared
HistMap_t m_histMap
 The map of histogram names to their pointers.
EffMap_t m_effMap
 The map of histogram names to their pointers.
TreeMap_t m_treeMap
 The map of TTree names to their pointers.
GraphMap_t m_graphMap
 The map of TGraph names to their pointers.
std::string m_streamName
 Name of the ROOT output stream (file)
std::string m_name
 Instance name.
MsgStream m_msg
 Cached Message Stream.

Detailed Description

Definition at line 39 of file MuonSegmentReader.h.

Member Typedef Documentation

◆ EffMap_t

typedef std::map< const hash_t, TEfficiency* > AthHistogramming::EffMap_t
privateinherited

Typedef for convenience.

Definition at line 205 of file AthHistogramming.h.

◆ GraphMap_t

typedef std::map< const hash_t, TGraph* > AthHistogramming::GraphMap_t
privateinherited

Typedef for convenience.

Definition at line 219 of file AthHistogramming.h.

◆ hash_t

typedef uint32_t AthHistogramming::hash_t
privateinherited

typedef for the internal hash

Definition at line 169 of file AthHistogramming.h.

◆ HistMap_t

typedef std::map< const hash_t, TH1* > AthHistogramming::HistMap_t
privateinherited

Typedef for convenience.

Definition at line 198 of file AthHistogramming.h.

◆ StoreGateSvc_t

typedef ServiceHandle<StoreGateSvc> AthCommonDataStore< AthCommonMsg< Algorithm > >::StoreGateSvc_t
privateinherited

Definition at line 388 of file AthCommonDataStore.h.

◆ TreeMap_t

typedef std::map< const hash_t, TTree* > AthHistogramming::TreeMap_t
privateinherited

Typedef for convenience.

Definition at line 212 of file AthHistogramming.h.

Member Function Documentation

◆ AthHistogramAlgorithm()

AthHistogramAlgorithm::AthHistogramAlgorithm ( const std::string & name,
ISvcLocator * pSvcLocator )

Constructor with parameters:

Definition at line 40 of file AthHistogramAlgorithm.cxx.

32 :
33 ::AthAlgorithm( name, pSvcLocator ),
34 ::AthHistogramming( name ),
35 m_histSvc ( "THistSvc/THistSvc", name )
36{
37 //
38 // Property declaration
39 //
40 // The histogram service
41 declareProperty("THistSvc",
42 m_histSvc = ServiceHandle<ITHistSvc>("THistSvc/THistSvc", name),
43 "Handle to a THistSvc instance: it will be used to write "
44 "ROOT objects to ROOT files" );
45 // declareProperty("THistService", m_histSvc, "The THistSvc" );
46
47 declareProperty("RootStreamName", m_prefix = "/ANALYSIS", "Name of the output ROOT stream (file) that the THistSvc uses");
48 declareProperty("RootDirName", m_rootDir = "",
49 "Name of the ROOT directory inside the ROOT file where the histograms will go");
50
51 declareProperty( "HistNamePrefix", m_histNamePrefix = "", "The prefix for the histogram THx name" );
52 declareProperty( "HistNamePostfix", m_histNamePostfix = "", "The postfix for the histogram THx name" );
53
54 declareProperty( "HistTitlePrefix", m_histTitlePrefix = "", "The prefix for the histogram THx title" );
55 declareProperty( "HistTitlePostfix", m_histTitlePostfix = "", "The postfix for the histogram THx title" );
56}
AthAlgorithm()
Default constructor:
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T, V, H > &t)
std::string m_histNamePrefix
The prefix for the histogram THx name.
ServiceHandle< ITHistSvc > m_histSvc
Default constructor: AthHistogramAlgorithm();.
std::string m_prefix
Name of the ROOT output stream (file)
std::string m_histNamePostfix
The postfix for the histogram THx name.
std::string m_histTitlePostfix
The postfix for the histogram THx title.
std::string m_rootDir
Name of the ROOT directory.
std::string m_histTitlePrefix
The prefix for the histogram THx title.
AthHistogramming(const std::string &name)
Constructor with parameters:

◆ book() [1/8]

StatusCode AthHistogramming::book ( const TEfficiency & eff,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the booking and registering (into THistSvc) of TEfficiency.

Definition at line 335 of file AthHistogramming.h.

336{
337 // We need to create a non-const clone
338 TEfficiency* effClone = dynamic_cast< TEfficiency* >( eff.Clone() );
339 if ( !effClone ) {
340 m_msg << MSG::ERROR << "Couldn't create a TEfficiency clone" << endmsg;
341 return StatusCode::FAILURE;
342 }
343 return this->book( *effClone, tDir, stream );
344}
#define endmsg
StatusCode book(const TH1 &hist, const std::string &tDir="", const std::string &stream="")
Simplify the booking and registering (into THistSvc) of histograms.
MsgStream m_msg
Cached Message Stream.

◆ book() [2/8]

StatusCode AthHistogramming::book ( const TGraph & graphRef,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the booking and registering (into THistSvc) of TGraphs.

◆ book() [3/8]

StatusCode AthHistogramming::book ( const TH1 & hist,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the booking and registering (into THistSvc) of histograms.

Definition at line 303 of file AthHistogramming.h.

304{
305 // We need to create a non-const clone
306 TH1* histClone = dynamic_cast< TH1* >( hist.Clone() );
307 if ( !histClone ) {
308 m_msg << MSG::ERROR << "Couldn't create a TH1 clone" << endmsg;
309 return StatusCode::FAILURE;
310 }
311 return this->book( *histClone, tDir, stream );
312}
TH1 * hist(const std::string &histName, const std::string &tDir="", const std::string &stream="")
Simplify the retrieval of registered histograms of any type.

◆ book() [4/8]

StatusCode AthHistogramming::book ( const TTree & treeRef,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the booking and registering (into THistSvc) of TTrees.

Definition at line 403 of file AthHistogramming.h.

404{
405 // Call the other Book method and see if it returns a valid pointer
406 TTree* treePointer = this->bookGetPointer( treeRef, tDir, stream );
407 if ( treePointer )
408 {
409 return StatusCode::SUCCESS;
410 }
411 else
412 {
413 return StatusCode::FAILURE;
414 }
415}
TH1 * bookGetPointer(const TH1 &hist, const std::string &tDir="", const std::string &stream="")
Simplify the booking and registering (into THistSvc) of histograms.

◆ book() [5/8]

StatusCode AthHistogramming::book ( TEfficiency & effRef,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the booking and registering (into THistSvc) of TEfficiency.

Definition at line 356 of file AthHistogramming.h.

357{
358 // Call the other Book method and see if it returns a valid pointer
359 TEfficiency* effPointer = this->bookGetPointer( effRef, tDir, stream );
360 if ( !effPointer ) {
361 m_msg << MSG::ERROR << "Couldn't book a TEfficiency" << endmsg;
362 return StatusCode::FAILURE;
363 }
364 return StatusCode::SUCCESS;
365}

◆ book() [6/8]

StatusCode AthHistogramming::book ( TEfficiency * eff,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the booking and registering (into THistSvc) of TEfficiency.

Definition at line 346 of file AthHistogramming.h.

347{
348 if ( !eff ) {
349 m_msg << MSG::ERROR << "Got a zero pointer to a TEfficiency" << endmsg;
350 return StatusCode::FAILURE;
351 }
352 return this->book( *eff, tDir, stream );
353}

◆ book() [7/8]

StatusCode AthHistogramming::book ( TH1 & histRef,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the booking and registering (into THistSvc) of histograms.

Definition at line 324 of file AthHistogramming.h.

325{
326 // Call the other Book method and see if it returns a valid pointer
327 TH1* histPointer = this->bookGetPointer( histRef, tDir, stream );
328 if ( !histPointer ) {
329 m_msg << MSG::ERROR << "Couldn't book a TH1" << endmsg;
330 return StatusCode::FAILURE;
331 }
332 return StatusCode::SUCCESS;
333}

◆ book() [8/8]

StatusCode AthHistogramming::book ( TH1 * hist,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the booking and registering (into THistSvc) of histograms.

Definition at line 314 of file AthHistogramming.h.

315{
316 if ( !hist ) {
317 m_msg << MSG::ERROR << "Got a zero pointer to a TH1" << endmsg;
318 return StatusCode::FAILURE;
319 }
320 return this->book( *hist, tDir, stream );
321}

◆ bookGetPointer() [1/8]

TEfficiency * AthHistogramming::bookGetPointer ( const TEfficiency & eff,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the booking and registering (into THistSvc) of TEfficiency.

Definition at line 281 of file AthHistogramming.h.

282{
283 // We need to create a non-const clone
284 TEfficiency* histClone = dynamic_cast< TEfficiency* >( hist.Clone() );
285 if ( !histClone ) {
286 m_msg << MSG::ERROR << "Couldn't create a TEfficiency clone in bookGetPointer" << endmsg;
287 return 0;
288 }
289 return this->bookGetPointer( *histClone, tDir, stream );
290
291}

◆ bookGetPointer() [2/8]

TGraph * AthHistogramming::bookGetPointer ( const TGraph & graphRef,
std::string tDir = "",
std::string stream = "" )
protectedinherited

Simplify the booking and registering (into THistSvc) of TGraphs.

Definition at line 427 of file AthHistogramming.cxx.

428{
429 // Get a pointer
430 const TGraph* graphPointer = &graphRef;
431
432 // Check that we got a valid pointer
433 if ( !graphPointer )
434 {
435 m_msg << MSG::WARNING
436 << "We got an invalid TGraph pointer in the BookGetPointer(TGraph*) method of the class" << m_name
437 << "!" << endmsg;
438 return NULL;
439 }
440
441 // Modify the name and title according to the prefixes of this classes instance
442 std::string graphName = graphPointer->GetName();
443 const std::string graphTitle = graphPointer->GetTitle();
444
445 // Check if the hash for this graphName already exists, i.e., if we have a hash collision
446 const hash_t graphHash = this->hash(graphName);
447 GraphMap_t::const_iterator it = m_graphMap.find( graphHash );
448 if ( it != m_graphMap.end() ) // It does exist!
449 {
450 m_msg << MSG::WARNING
451 << "Detected a hash collision. The hash for the TGraph with name=" << graphName
452 << " already exists and points to a TGraph with name=" << it->second->GetName()
453 << " NOT going to book the new histogram and returning a NULL pointer!" << endmsg;
454 return NULL;
455 }
456
457 // Create a clone that has the new name
458 TGraph* graphClone = dynamic_cast< TGraph* >( graphPointer->Clone((m_histNamePrefix+graphName+m_histNamePostfix).c_str()) );
459 if( !graphClone )
460 {
461 m_msg << MSG::WARNING
462 << "We couldn't clone the TGraph in the BookGetPointer(TGraph&) method of the class" << m_name
463 << "!" << endmsg;
464 return NULL;
465 }
466 graphClone->SetTitle ((m_histTitlePrefix+graphTitle+m_histTitlePostfix).c_str());
467
468 // Massage the final string to book things
469 std::string bookingString("");
470 this->buildBookingString( bookingString, graphName, tDir, stream );
471
472 // Register the TGraph into the THistSvc
473 if ( !((histSvc()->regGraph(bookingString, graphClone)).isSuccess()) )
474 {
475 m_msg << MSG::WARNING
476 << "Problem registering TGraph with name " << graphName
477 << ", title " << graphTitle
478 << " in " << m_name << "!" << endmsg;
479 return NULL;
480 }
481
482 // Also register it in the local map of string to pointer
483 m_graphMap.insert( m_graphMap.end(), std::pair< const hash_t, TGraph* >( graphHash, graphClone ) );
484
485 return graphClone;
486}
const ServiceHandle< ITHistSvc > & histSvc() const
The standard THistSvc (for writing histograms and TTrees and more to a root file) Returns (kind of) a...
std::string m_histNamePostfix
The postfix for the histogram THx name.
hash_t hash(const std::string &histName) const
Method to calculate a 32-bit hash from a string.
uint32_t hash_t
typedef for the internal hash
std::string m_histTitlePostfix
The postfix for the histogram THx title.
std::string m_histTitlePrefix
The prefix for the histogram THx title.
std::string m_name
Instance name.
void buildBookingString(std::string &bookingString, std::string &histName, std::string &tDir, std::string &stream, bool usePrefixPostfix=false)
Method to build individual booking string.
std::string m_histNamePrefix
The prefix for the histogram THx name.
GraphMap_t m_graphMap
The map of TGraph names to their pointers.

◆ bookGetPointer() [3/8]

TH1 * AthHistogramming::bookGetPointer ( const TH1 & hist,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the booking and registering (into THistSvc) of histograms.

Definition at line 260 of file AthHistogramming.h.

261{
262 // We need to create a non-const clone
263 TH1* histClone = dynamic_cast< TH1* >( hist.Clone() );
264 if ( !histClone ) {
265 m_msg << MSG::ERROR << "Couldn't create a TH1 clone in bookGetPointer" << endmsg;
266 return 0;
267 }
268 return this->bookGetPointer( *histClone, tDir, stream );
269
270}

◆ bookGetPointer() [4/8]

TTree * AthHistogramming::bookGetPointer ( const TTree & treeRef,
std::string tDir = "",
std::string stream = "" )
protectedinherited

Simplify the booking and registering (into THistSvc) of TTrees.

Definition at line 312 of file AthHistogramming.cxx.

313{
314 // Get a pointer
315 const TTree* treePointer = &treeRef;
316
317 // Check that we got a valid pointer
318 if ( !treePointer )
319 {
320 m_msg << MSG::WARNING
321 << "We got an invalid TTree pointer in the BookGetPointer(TTree*) method of the class" << m_name
322 << "!" << endmsg;
323 return NULL;
324 }
325
326 // Modify the name and title according to the prefixes of this classes instance
327 std::string treeName = treePointer->GetName();
328 const std::string treeTitle = treePointer->GetTitle();
329
330 // Check if the hash for this treeName already exists, i.e., if we have a hash collision
331 const hash_t treeHash = this->hash(treeName);
332 TreeMap_t::const_iterator it = m_treeMap.find( treeHash );
333 if ( it != m_treeMap.end() ) // It does exist!
334 {
335 m_msg << MSG::WARNING
336 << "Detected a hash collision. The hash for the TTree with name=" << treeName
337 << " already exists and points to a TTree with name=" << it->second->GetName()
338 << " NOT going to book the new histogram and returning a NULL pointer!" << endmsg;
339 return NULL;
340 }
341
342 // Create a clone that has the new name
343 TTree* treeClone = dynamic_cast< TTree* >( treePointer->Clone(treeName.c_str()) );
344 if( !treeClone )
345 {
346 m_msg << MSG::WARNING
347 << "We couldn't clone the TTree in the BookGetPointer(TTree&) method of the class" << m_name
348 << "!" << endmsg;
349 return NULL;
350 }
351 treeClone->SetTitle (treeTitle.c_str());
352
353 // Massage the final string to book things
354 std::string bookingString("");
355 this->buildBookingString( bookingString, treeName, tDir, stream );
356
357 // Register the TTree into the THistSvc
358 if ( !((histSvc()->regTree(bookingString, treeClone)).isSuccess()) )
359 {
360 m_msg << MSG::WARNING
361 << "Problem registering TTree with name " << treeName
362 << ", title " << treeTitle
363 << " in " << m_name << "!" << endmsg;
364 return NULL;
365 }
366
367 // Also register it in the local map of string to pointer
368 m_treeMap.insert( m_treeMap.end(), std::pair< const hash_t, TTree* >( treeHash, treeClone ) );
369
370 return treeClone;
371}
TreeMap_t m_treeMap
The map of TTree names to their pointers.

◆ bookGetPointer() [5/8]

TEfficiency * AthHistogramming::bookGetPointer ( TEfficiency & effRef,
std::string tDir = "",
std::string stream = "" )
protectedinherited

Simplify the booking and registering (into THistSvc) of TEfficiency.

Definition at line 146 of file AthHistogramming.cxx.

147{
148 // Modify the name and title according to the prefixes of this classes instance
149 std::string effName(effRef.GetName());
150 const std::string effTitle(effRef.GetTitle());
151 std::string bookingString("");
152
153 this->buildBookingString( bookingString, effName, tDir, stream );
154 effRef.SetTitle((m_histTitlePrefix+effTitle+m_histTitlePostfix).c_str() );
155 effRef.SetName(effName.c_str());
156
157 // Check if the hash for this effName already exists, i.e., if we have a hash collision
158 const hash_t effHash = this->hash(effName);
159 EffMap_t::const_iterator it = m_effMap.find( effHash );
160 if ( it != m_effMap.end() ) // It does exist!
161 {
162 m_msg << MSG::WARNING
163 << "Detected a hash collision. The hash for the TEfficiency with name=" << effName
164 << " already exists and points to a TEfficiency with name=" << it->second->GetName()
165 << " NOT going to book the new TEfficiency and returning a NULL pointer!" << endmsg;
166 return NULL;
167 }
168
169 // Set the new name and title for the TEfficiency, based on the prefixes that the user set for this class instance
170 // Create a clone that has the new name
171
172 // Massage the final string to book things
173
174 // Register the TEfficiency into the THistSvc
175 if ( !((histSvc()->regEfficiency(bookingString, &effRef)).isSuccess()) )
176 {
177 m_msg << MSG::WARNING
178 << "Problem registering TEfficiency with name " << effName
179 << ", name prefix " << m_histNamePrefix
180 << ", title " << effTitle
181 << ", tile prefix " << m_histTitlePrefix
182 << ", and tile postfix " << m_histTitlePostfix
183 << " in " << m_name << "!" << endmsg;
184 return NULL;
185 }
186
187 // Also register it in the local map of string to pointer
188 m_effMap.insert( m_effMap.end(), std::pair< const hash_t, TEfficiency* >( effHash, &effRef ) );
189
190 return &effRef;
191}
EffMap_t m_effMap
The map of histogram names to their pointers.

◆ bookGetPointer() [6/8]

TEfficiency * AthHistogramming::bookGetPointer ( TEfficiency * eff,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the booking and registering (into THistSvc) of TEfficiency.

Definition at line 293 of file AthHistogramming.h.

294{
295 if ( !hist ) {
296 m_msg << MSG::ERROR << "Got a zero pointer to a TEfficiency in bookGetPointer" << endmsg;
297 return 0;
298 }
299 return this->bookGetPointer( *hist, tDir, stream );
300}

◆ bookGetPointer() [7/8]

TH1 * AthHistogramming::bookGetPointer ( TH1 & histRef,
std::string tDir = "",
std::string stream = "" )
protectedinherited

Simplify the booking and registering (into THistSvc) of histograms.

Definition at line 98 of file AthHistogramming.cxx.

99{
100 // Modify the name and title according to the prefixes of this classes instance
101 std::string histName(histRef.GetName());
102 const std::string histTitle(histRef.GetTitle());
103 std::string bookingString("");
104
105 this->buildBookingString( bookingString, histName, tDir, stream );
106 histRef.SetTitle((m_histTitlePrefix+histTitle+m_histTitlePostfix).c_str() );
107 histRef.SetName(histName.c_str());
108
109 // Check if the hash for this histName already exists, i.e., if we have a hash collision
110 const hash_t histHash = this->hash(histName);
111 HistMap_t::const_iterator it = m_histMap.find( histHash );
112 if ( it != m_histMap.end() ) // It does exist!
113 {
114 m_msg << MSG::WARNING
115 << "Detected a hash collision. The hash for the histogram with name=" << histName
116 << " already exists and points to a histogram with name=" << it->second->GetName()
117 << " NOT going to book the new histogram and returning a NULL pointer!" << endmsg;
118 return NULL;
119 }
120
121 // Set the new name and title for the histogram, based on the prefixes that the user set for this class instance
122 // Create a clone that has the new name
123
124 // Massage the final string to book things
125
126 // Register the histogram into the THistSvc
127 if ( !((histSvc()->regHist(bookingString, &histRef)).isSuccess()) )
128 {
129 m_msg << MSG::WARNING
130 << "Problem registering histogram with name " << histName
131 << ", name prefix " << m_histNamePrefix
132 << ", title " << histTitle
133 << ", tile prefix " << m_histTitlePrefix
134 << ", and tile postfix " << m_histTitlePostfix
135 << " in " << m_name << "!" << endmsg;
136 return NULL;
137 }
138
139 // Also register it in the local map of string to pointer
140 m_histMap.insert( m_histMap.end(), std::pair< const hash_t, TH1* >( histHash, &histRef ) );
141
142 return &histRef;
143}
HistMap_t m_histMap
The map of histogram names to their pointers.

◆ bookGetPointer() [8/8]

TH1 * AthHistogramming::bookGetPointer ( TH1 * hist,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the booking and registering (into THistSvc) of histograms.

Definition at line 272 of file AthHistogramming.h.

273{
274 if ( !hist ) {
275 m_msg << MSG::ERROR << "Got a zero pointer to a TH1 in bookGetPointer" << endmsg;
276 return 0;
277 }
278 return this->bookGetPointer( *hist, tDir, stream );
279}

◆ buildBookingString()

void AthHistogramming::buildBookingString ( std::string & bookingString,
std::string & histName,
std::string & tDir,
std::string & stream,
bool usePrefixPostfix = false )
privateinherited

Method to build individual booking string.

Definition at line 560 of file AthHistogramming.cxx.

565{
566 // Massage the final string to book things
567 if(tDir.empty()) tDir = m_rootDir;
568 size_t pos = histName.rfind('/');
569 if(pos != std::string::npos){
570 tDir+='/';
571 tDir.append(histName, 0,pos);
572 histName.erase(0,pos+1);
573 };
574 if(stream.empty()) stream = m_streamName;
575
576 if(usePrefixPostfix){
577 bookingString = "/"+stream+"/"+tDir+"/"+m_histNamePrefix+histName+m_histNamePostfix;
578 } else {
579 bookingString = "/"+stream+"/"+tDir+"/"+histName;
580 }
581 while(bookingString.find("//") != std::string::npos){
582 this->myReplace(bookingString,"//","/");
583 }
584
585 return;
586}
std::string m_rootDir
Name of the ROOT directory.
std::string m_streamName
Name of the ROOT output stream (file)
void myReplace(std::string &str, const std::string &oldStr, const std::string &newStr)
Helper method to replace sub-string.

◆ cardinality()

unsigned int MuonCalib::MuonSegmentReader::cardinality ( ) const
inlinefinaloverride

Definition at line 50 of file MuonSegmentReader.h.

50{ return 1; } ;

◆ configAthHistogramming()

StatusCode AthHistogramming::configAthHistogramming ( const ServiceHandle< ITHistSvc > & histSvc,
const std::string & prefix,
const std::string & rootDir,
const std::string & histNamePrefix,
const std::string & histNamePostfix,
const std::string & histTitlePrefix,
const std::string & histTitlePostfix )
protectedinherited

To be called by the derived classes to fill the internal configuration.

Definition at line 66 of file AthHistogramming.cxx.

70{
73 m_rootDir = rootDir;
74 m_histNamePrefix = histNamePrefix;
75 m_histNamePostfix = histNamePostfix;
76 m_histTitlePrefix = histTitlePrefix;
77 m_histTitlePostfix = histTitlePostfix;
78
79 return StatusCode::SUCCESS;
80}
ServiceHandle< ITHistSvc > m_histSvc
Pointer to the THistSvc (event store by default)

◆ declareGaudiProperty()

Gaudi::Details::PropertyBase & AthCommonDataStore< AthCommonMsg< Algorithm > >::declareGaudiProperty ( Gaudi::Property< T, V, H > & hndl,
const SG::VarHandleKeyType &  )
inlineprivateinherited

specialization for handling Gaudi::Property<SG::VarHandleKey>

Definition at line 156 of file AthCommonDataStore.h.

158 {
160 hndl.value(),
161 hndl.documentation());
162
163 }

◆ declareProperty()

Gaudi::Details::PropertyBase & AthCommonDataStore< AthCommonMsg< Algorithm > >::declareProperty ( Gaudi::Property< T, V, H > & t)
inlineinherited

Definition at line 145 of file AthCommonDataStore.h.

145 {
146 typedef typename SG::HandleClassifier<T>::type htype;
148 }
Gaudi::Details::PropertyBase & declareGaudiProperty(Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
specialization for handling Gaudi::Property<SG::VarHandleKey>

◆ detStore()

const ServiceHandle< StoreGateSvc > & AthCommonDataStore< AthCommonMsg< Algorithm > >::detStore ( ) const
inlineinherited

The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.

Definition at line 95 of file AthCommonDataStore.h.

◆ efficiency()

TEfficiency * AthHistogramming::efficiency ( const std::string & effName,
const std::string & tDir = "",
const std::string & stream = "" )
protectedinherited

Simplify the retrieval of registered TEfficiency.

Definition at line 250 of file AthHistogramming.cxx.

251{
252 // Build a 32 bit hash out of the name
253 const hash_t effHash = this->hash(effName);
254
255 // See if this entry exists in the map
256 EffMap_t::const_iterator it = m_effMap.find( effHash );
257 if ( it == m_effMap.end() ) // It doesn't exist!
258 { // Let's see into the THistSvc if somebody else has registered the TEfficiency...
259
260 // Need to copy the strings as we will massage them from here on
261 std::string effNameCopy = effName;
262 std::string tDirCopy = tDir;
263 std::string streamCopy = stream;
264
265 // Massage the final string to book things
266 std::string bookingString("");
267 this->buildBookingString( bookingString, effNameCopy, tDirCopy, streamCopy ,false);
268
269 TEfficiency* effPointer(NULL);
270 if ( !((histSvc()->getEfficiency(bookingString, effPointer)).isSuccess()) )
271 {
272 // Massage the final string to book things
273 std::string bookingString("");
274 this->buildBookingString( bookingString, effNameCopy, tDirCopy, streamCopy, true );
275
276 if ( !((histSvc()->getEfficiency(bookingString, effPointer)).isSuccess()) )
277 {
278 m_msg << MSG::WARNING
279 << "Problem retrieving the TEfficiency with name (including pre- and post-fixes) "
280 << m_histNamePrefix + effNameCopy + m_histNamePostfix
281 << " or with name " << effNameCopy
282 << " in " << m_name << "... it doesn't exist, neither in the cached map nor in the THistSvc!"
283 << " Will return an NULL pointer... you have to handle it correctly!" << endmsg;
284 return NULL;
285 }
286 // If we get to here, we actually found the TEfficiency in the THistSvc.
287 // So let's add it to the local cache map and return its pointer
288 m_effMap.insert( m_effMap.end(), std::pair< const hash_t, TEfficiency* >( effHash, effPointer ) );
289 return effPointer;
290 }
291 // If we get to here, we actually found the TEfficiency in the THistSvc.
292 // So let's add it to the local cache map and return its pointer
293 m_effMap.insert( m_effMap.end(), std::pair< const hash_t, TEfficiency* >( effHash, effPointer ) );
294 return effPointer;
295 }
296
297 // Return the pointer to the TEfficiency that we got from the local cache map
298 return it->second;
299}

◆ evtStore()

ServiceHandle< StoreGateSvc > & AthCommonDataStore< AthCommonMsg< Algorithm > >::evtStore ( )
inlineinherited

The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.

Definition at line 85 of file AthCommonDataStore.h.

◆ execute()

StatusCode MuonCalib::MuonSegmentReader::execute ( )
overridevirtual

< number of measurements flaged as outliers in TSOS

Definition at line 46 of file MuonSegmentReader.cxx.

47{
48
49 // fill eventInfo branches
50 const EventContext& ctx = Gaudi::Hive::currentContext();
51 SG::ReadHandle<xAOD::EventInfo> eventInfo(m_evtKey,ctx);
52 if (!eventInfo.isValid()) {
53 ATH_MSG_ERROR("Did not find xAOD::EventInfo");
54 return StatusCode::FAILURE;
55 }
56
57 m_runNumber = eventInfo->runNumber();
58 m_eventNumber = eventInfo->eventNumber();
59 m_lumiBlock = eventInfo->lumiBlock();
60 m_bcId = eventInfo->bcid();
61 m_timeStamp = eventInfo->timeStamp();
62 m_pt = eventInfo->timeStampNSOffset(); // special treatment in eventInfo for muon calibration stream data
63
64 // load Geo
65 SG::ReadCondHandle<MuonGM::MuonDetectorManager> DetectorManagerHandle{m_DetectorManagerKey, ctx};
66 const MuonGM::MuonDetectorManager* MuonDetMgr = DetectorManagerHandle.cptr();
67 if (!MuonDetMgr) {
68 ATH_MSG_ERROR("Null pointer to the read MuonDetectorManager conditions object");
69 return StatusCode::FAILURE;
70 }
71
72 // fill the rawMdt Hit branches
73 SG::ReadHandle<Muon::MdtPrepDataContainer> mdtPrepRawData(m_MdtPrepDataKey, ctx);
74 ATH_MSG_DEBUG("Size of MdtPrepDataContainer : "<<mdtPrepRawData->size());
75 // Loop MdtPrepDataContainer
76 for( auto mdtColl : *mdtPrepRawData){
77 for (const Muon::MdtPrepData* prd : *mdtColl) {
78 MuonFixedId fixid = m_idToFixedIdTool->idToFixedId(prd->identify());
79 m_rawMdt_id.push_back(fixid.getIdInt()) ;
80 m_rawMdt_tdc.push_back(prd->tdc());
81 m_rawMdt_adc.push_back(prd->adc());
82 m_rawMdt_gPos.push_back(prd->globalPosition());
83 ATH_MSG_DEBUG("Mdt FixedId "<<fixid.getIdInt()<<" prd phi "<<prd->globalPosition().phi()<<" prd theta "<<prd->globalPosition().theta());
84 } // end of MdtPrepDataCollection
85 } // end of MdtPrepDataContainer
87 ATH_MSG_DEBUG("Number of MDT raw Hits : "<<m_rawMdt_nRMdt);
88
89 // fill the rawRpc Hit branches
90 SG::ReadHandle<Muon::RpcPrepDataContainer> rpcPrepRawData(m_RpcPrepDataKey, ctx);
91 ATH_MSG_DEBUG("Size of RpcPrepDataContainer : "<<rpcPrepRawData->size());
92 // Loop RpcPrepDataContainer
93 for( auto rpcColl : *rpcPrepRawData) {
94 for (const Muon::RpcPrepData* prd : *rpcColl) {
95 MuonFixedId fixid = m_idToFixedIdTool->idToFixedId(prd->identify());
96 m_rawRpc_id.push_back(fixid.getIdInt()) ;
97 m_rawRpc_time.push_back(prd->time());
98 m_rawRpc_gPos.push_back(prd->globalPosition());
99 ATH_MSG_DEBUG("Rpc FixedId "<<fixid.getIdInt()<<" prd phi "<<prd->globalPosition().phi()<<" prd theta "<<prd->globalPosition().theta());
100 } // end of RpcPrepDataCollection
101 } // end of RpcPrepDataContainer
102 m_rawRpc_nRRpc = m_rawRpc_id.size() ;
103 ATH_MSG_DEBUG("Number of Rpc raw Hits : "<<m_rawRpc_nRRpc);
104
105 // fill the rawTgc Hit branches
106 SG::ReadHandle<Muon::TgcPrepDataContainer> tgcPrepRawData(m_TgcPrepDataKey, ctx);
107 ATH_MSG_DEBUG("Size of TgcPrepDataContainer : "<<tgcPrepRawData->size());
108 // Loop TgcPrepDataContainer
109 for (auto tgcColl : *tgcPrepRawData) {
110 for (const Muon::TgcPrepData* prd : *tgcColl) {
111 MuonFixedId fixid = m_idToFixedIdTool->idToFixedId(prd->identify());
112 m_rawTgc_id.push_back(fixid.getIdInt()) ;
113 m_rawTgc_bcBitMap.push_back(prd->getBcBitMap());
114 m_rawTgc_gPos.push_back(prd->globalPosition());
115 ATH_MSG_DEBUG("Tgc FixedId "<<fixid.getIdInt()<<" prd phi "<<prd->globalPosition().phi()<<" prd theta "<<prd->globalPosition().theta());
116 } // end of TgcPrepDataCollection
117 } // end of TgcPrepDataContainer
118 m_rawTgc_nRTgc = m_rawTgc_id.size() ;
119 ATH_MSG_DEBUG("Number of Tgc raw Hits : "<<m_rawTgc_nRTgc);
120
121 // fill the muon standalone tracks branches
122 SG::ReadHandle<TrackCollection> muTrks(m_TrkKey, ctx);
123 ATH_MSG_INFO("Number of Muon StandAlone Tracks : "<<muTrks->size());
124 m_trk_nTracks = muTrks->size() ;
125 // if tracks were found, print MDT track hits
126 for (unsigned int itrk = 0; itrk < muTrks->size(); ++itrk) {
127 const Trk::Track* trkSA = muTrks->at(itrk) ;
128 ATH_MSG_DEBUG(m_printer->print(*trkSA));
129 ATH_MSG_DEBUG("Track author : "<<m_printer->printPatRec(*trkSA));
130 ATH_MSG_DEBUG("TrackHit measurements : "<<m_printer->printMeasurements(*trkSA));
131 m_trk_author.push_back(208); // Hardcode 208 as Moore for MuonStandaloneTrack
132 // get trackSummary
133 const Trk::MuonTrackSummary* summary = nullptr;
134 // check if the track already has a MuonTrackSummary, if not calculate it using the helper
135 const Trk::TrackSummary* trkSummary = trkSA->trackSummary();
136 if (not trkSummary) continue;
137 m_trk_nMdtHits.push_back(trkSummary->get(Trk::numberOfMdtHits));
139 m_trk_nOutliersHits.push_back(trkSummary->get(Trk::numberOfOutliersOnTrack));
140 m_trk_nRpcPhiHits.push_back(trkSummary->get(Trk::numberOfRpcPhiHits));
141 m_trk_nTgcPhiHits.push_back(trkSummary->get(Trk::numberOfTgcPhiHits));
142 m_trk_nRpcEtaHits.push_back(trkSummary->get(Trk::numberOfRpcEtaHits));
143 m_trk_nTgcEtaHits.push_back(trkSummary->get(Trk::numberOfTgcEtaHits));
144 m_trk_nMdtHoles.push_back(trkSummary->get(Trk::numberOfMdtHoles));
145
146 ATH_MSG_DEBUG("Mdt Hits " << trkSummary->get(Trk::numberOfMdtHits)
147 <<" Mdt Holes "<< trkSummary->get(Trk::numberOfMdtHoles)
148 << "Mdt Outliers " << trkSummary->get(Trk::numberOfOutliersOnTrack)
149 << " TGC Phi Eta Hits "<<trkSummary->get(Trk::numberOfTgcPhiHits)<<" "<<trkSummary->get(Trk::numberOfTgcEtaHits)
150 << " RPC Phi Eta Hits "<<trkSummary->get(Trk::numberOfRpcPhiHits)<<" "<<trkSummary->get(Trk::numberOfRpcEtaHits));
151
152 summary = trkSummary->muonTrackSummary();
153 if (!summary) {
154 ATH_MSG_WARNING("No muon summary is present");
155 } else {
156 ATH_MSG_DEBUG("print MuonSummary : "<<m_printer->print(*summary));
157 }
158
159 // Trk perigee
160 const Trk::Perigee* perigee = trkSA->perigeeParameters();
161 if (!perigee) {
162 ATH_MSG_WARNING(" was expecting a perigee here... ");
163 return StatusCode::FAILURE;
164 }
165 // track direction vector
166 const Amg::Vector3D dir = perigee->momentum().unit();
167 m_trk_perigee.push_back(dir);
168 m_trk_d0.push_back(perigee->parameters()[Trk::d0]);
169 m_trk_z0.push_back(perigee->parameters()[Trk::z0]);
170 m_trk_phi.push_back(perigee->parameters()[Trk::phi0]);
171 m_trk_theta.push_back(perigee->parameters()[Trk::theta]);
172 m_trk_qOverP.push_back(perigee->parameters()[Trk::qOverP]);
173 m_trk_eta.push_back(perigee->eta());
174 m_trk_pt.push_back(perigee->pT());
175
176 // Trk fit quality
177 const Trk::FitQuality* fq = trkSA->fitQuality();
178 if (!fq) {
179 ATH_MSG_WARNING(" was expecting a FitQuality here... ");
180 return StatusCode::FAILURE;
181 }
182 m_trk_chi2.push_back(fq->chiSquared()) ;
183 m_trk_ndof.push_back(fq->numberDoF());
184
185 // Loop track hits by trk_states and store the measure
186 const DataVector<const Trk::TrackStateOnSurface>* trk_states = trkSA->trackStateOnSurfaces();
187 if (!trk_states) {
188 ATH_MSG_WARNING(" track without states, discarding track ");
189 return StatusCode::FAILURE;
190 }
191
192 unsigned int nMeasurement = 0, nHole = 0;
193 for (const Trk::TrackStateOnSurface* trk_state : *trk_states) {
194 // First handle the case of mdtHole
195 if (trk_state->type(Trk::TrackStateOnSurface::Hole)) {
196 storeHole(trk_state, itrk);
197 nHole ++;
198 continue;
199 }
200
201 const Trk::MeasurementBase* measurement = trk_state->measurementOnTrack();
202 if (!measurement) continue;
203 storeMeasurement(ctx, MuonDetMgr, itrk, trk_state, measurement);
204 nMeasurement ++;
205 } // end of track hit loop
206 ATH_MSG_DEBUG("Total recorded hits in the track "<<itrk<<" #Mesurement "<<nMeasurement<<" #Hole "<<nHole) ;
207 } // end of track loop
211 ATH_MSG_DEBUG("Total recorded "<<m_trkHit_type.size()<<" MDT hits, "<<m_trkTriggerHit_type.size()<<" Trigger hits and "<<m_trkHole_type.size()<<" hole hits in all tracks!") ;
212
213
214 if (!m_tree.fill(ctx)) return StatusCode::FAILURE;
215 return StatusCode::SUCCESS;
216}
#define ATH_MSG_ERROR(x)
#define ATH_MSG_INFO(x)
#define ATH_MSG_WARNING(x)
#define ATH_MSG_DEBUG(x)
VectorBranch< unsigned int > & m_rawRpc_id
VectorBranch< float > & m_trk_d0
ScalarBranch< int > & m_trkTriggerHit_nHits
ScalarBranch< int > & m_lumiBlock
ScalarBranch< float > & m_pt
VectorBranch< float > & m_trk_qOverP
SG::ReadHandleKey< Muon::TgcPrepDataContainer > m_TgcPrepDataKey
ScalarBranch< int > & m_trk_nTracks
VectorBranch< int > & m_trk_ndof
void storeHole(const Trk::TrackStateOnSurface *trk_state, unsigned int itrk)
VectorBranch< float > & m_trk_theta
VectorBranch< float > & m_rawRpc_time
SG::ReadHandleKey< xAOD::EventInfo > m_evtKey
VectorBranch< float > & m_trk_phi
VectorBranch< int > & m_trkHit_type
VectorBranch< float > & m_trk_chi2
SG::ReadHandleKey< Muon::MdtPrepDataContainer > m_MdtPrepDataKey
void storeMeasurement(const EventContext &ctx, const MuonGM::MuonDetectorManager *MuonDetMgr, unsigned int itrk, const Trk::TrackStateOnSurface *trk_state, const Trk::MeasurementBase *measurement)
VectorBranch< int > & m_trkHole_type
ScalarBranch< int > & m_runNumber
ScalarBranch< int > & m_trkHit_nMdtHits
VectorBranch< int > & m_trk_nRpcEtaHits
VectorBranch< int > & m_trk_nOutliersHits
VectorBranch< float > & m_trk_z0
VectorBranch< int > & m_trk_nMdtHoles
PublicToolHandle< Muon::MuonEDMPrinterTool > m_printer
SG::ReadCondHandleKey< MuonGM::MuonDetectorManager > m_DetectorManagerKey
MuonDetectorManager from the conditions store.
VectorBranch< int > & m_trk_nRpcPhiHits
ScalarBranch< int > & m_eventNumber
ScalarBranch< int > & m_trkHole_nHoles
ScalarBranch< int > & m_rawTgc_nRTgc
VectorBranch< int > & m_rawMdt_adc
SG::ReadHandleKey< Muon::RpcPrepDataContainer > m_RpcPrepDataKey
VectorBranch< int > & m_trk_nTgcPhiHits
VectorBranch< float > & m_trk_eta
VectorBranch< unsigned int > & m_rawTgc_id
ToolHandle< MuonCalib::IIdToFixedIdTool > m_idToFixedIdTool
VectorBranch< int > & m_trkTriggerHit_type
VectorBranch< float > & m_trk_pt
VectorBranch< int > & m_trk_author
VectorBranch< int > & m_trk_nMdtHits
VectorBranch< int > & m_rawTgc_bcBitMap
VectorBranch< unsigned int > & m_rawMdt_id
ScalarBranch< int > & m_rawMdt_nRMdt
ScalarBranch< int > & m_timeStamp
ScalarBranch< int > & m_bcId
SG::ReadHandleKey< TrackCollection > m_TrkKey
ScalarBranch< int > & m_rawRpc_nRRpc
VectorBranch< int > & m_trk_nTgcEtaHits
VectorBranch< int > & m_rawMdt_tdc
const_pointer_type cptr()
int numberDoF() const
returns the number of degrees of freedom of the overall track or vertex fit as integer
Definition FitQuality.h:60
double chiSquared() const
returns the of the overall track fit
Definition FitQuality.h:56
double eta() const
Access method for pseudorapidity - from momentum.
const Amg::Vector3D & momentum() const
Access method for the momentum.
double pT() const
Access method for transverse momentum.
@ Hole
A hole on the track - this is defined in the following way.
const Trk::TrackStates * trackStateOnSurfaces() const
return a pointer to a const DataVector of const TrackStateOnSurfaces.
const Perigee * perigeeParameters() const
return Perigee.
const Trk::TrackSummary * trackSummary() const
Returns a pointer to the const Trk::TrackSummary owned by this const track (could be nullptr)
const FitQuality * fitQuality() const
return a pointer to the fit quality const-overload
Eigen::Matrix< double, 3, 1 > Vector3D
ParametersT< TrackParametersDim, Charged, PerigeeSurface > Perigee
@ phi0
Definition ParamDefs.h:65
@ theta
Definition ParamDefs.h:66
@ qOverP
perigee
Definition ParamDefs.h:67
@ d0
Definition ParamDefs.h:63
@ z0
Definition ParamDefs.h:64
@ numberOfMdtHoles
number of MDT measurements missing from the track
@ numberOfOutliersOnTrack
100 times the standard deviation of the chi2 from the surfaces

◆ extraDeps_update_handler()

void AthCommonDataStore< AthCommonMsg< Algorithm > >::extraDeps_update_handler ( Gaudi::Details::PropertyBase & ExtraDeps)
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

◆ extraOutputDeps()

const DataObjIDColl & AthAlgorithm::extraOutputDeps ( ) const
overridevirtualinherited

Return the list of extra output dependencies.

This list is extended to include symlinks implied by inheritance relations.

Definition at line 50 of file AthAlgorithm.cxx.

51{
52 // If we didn't find any symlinks to add, just return the collection
53 // from the base class. Otherwise, return the extended collection.
54 if (!m_extendedExtraObjects.empty()) {
56 }
57 return Algorithm::extraOutputDeps();
58}
DataObjIDColl m_extendedExtraObjects

◆ finalize()

StatusCode MuonCalib::MuonSegmentReader::finalize ( )
overridevirtual

Definition at line 454 of file MuonSegmentReader.cxx.

455{
456 ATH_MSG_INFO("MuonSegmentReader :: Finalize + Matching");
457 ATH_CHECK(m_tree.write());
458 return StatusCode::SUCCESS;
459}
#define ATH_CHECK
Evaluate an expression and check for errors.

◆ graph()

TGraph * AthHistogramming::graph ( const std::string & graphName,
const std::string & tDir = "",
const std::string & stream = "" )
protectedinherited

Simplify the retrieval of registered TGraphs.

Definition at line 492 of file AthHistogramming.cxx.

493{
494 // Build a 32 bit hash out of the name
495 const hash_t graphHash = this->hash(graphName);
496
497 // See if this entry exists in the map
498 GraphMap_t::const_iterator it = m_graphMap.find( graphHash );
499 if ( it == m_graphMap.end() ) // It doesn't exist!
500 { // Let's see into the THistSvc if somebody else has registered the TGraph...
501
502 // Need to copy the strings as we will massage them from here on
503 std::string graphNameCopy = graphName;
504 std::string tDirCopy = tDir;
505 std::string streamCopy = stream;
506
507 // Massage the final string to book things
508 std::string bookingString("");
509 this->buildBookingString( bookingString, graphNameCopy, tDirCopy, streamCopy, true);
510
511 TGraph* graphPointer(NULL);
512 if ( !((histSvc()->getGraph(bookingString, graphPointer)).isSuccess()) )
513 {
514 // Massage the final string to book things
515 std::string bookingString("");
516 this->buildBookingString( bookingString, graphNameCopy, tDirCopy, streamCopy, false );
517
518 if ( !((histSvc()->getGraph(bookingString, graphPointer)).isSuccess()) )
519 {
520 m_msg << MSG::WARNING
521 << "Problem retrieving the TGraph with name (including pre- and post-fixes) "
522 << m_histNamePrefix + graphNameCopy + m_histNamePostfix
523 << " or with name " << graphNameCopy
524 << " in " << m_name << "... it doesn't exist, neither in the cached map nor in the THistSvc!"
525 << " Will return an NULL pointer... you have to handle it correctly!" << endmsg;
526 return NULL;
527 }
528 // If we get to here, we actually found the TGraph in the THistSvc.
529 // So let's add it to the local cache map and return its pointer
530 m_graphMap.insert( m_graphMap.end(), std::pair< const hash_t, TGraph* >( graphHash, graphPointer ) );
531 return graphPointer;
532 }
533 // If we get to here, we actually found the TGraph in the THistSvc.
534 // So let's add it to the local cache map and return its pointer
535 m_graphMap.insert( m_graphMap.end(), std::pair< const hash_t, TGraph* >( graphHash, graphPointer ) );
536 return graphPointer;
537 }
538
539
540 // Return the pointer to the TGraph that we got from the local cache map
541 return it->second;
542}

◆ hash()

AthHistogramming::hash_t AthHistogramming::hash ( const std::string & histName) const
inlineprivateinherited

Method to calculate a 32-bit hash from a string.

Definition at line 428 of file AthHistogramming.h.

429{
430 const uint64_t hash64 = CxxUtils::crc64( histName );
431 return (hash_t)(hash64 & 0xFFFFFFFF);
432}
uint64_t crc64(const CRCTable &table, const char *data, size_t data_len)
Find the CRC-64 of a string,.
Definition crc64.cxx:696
std::uint64_t hash64(const void *data, std::size_t size)
Passthrough to XXH3_64bits.
Definition XXH.cxx:9

◆ hist()

TH1 * AthHistogramming::hist ( const std::string & histName,
const std::string & tDir = "",
const std::string & stream = "" )
protectedinherited

Simplify the retrieval of registered histograms of any type.

Definition at line 198 of file AthHistogramming.cxx.

199{
200 // Build a 32 bit hash out of the name
201 const hash_t histHash = this->hash(histName);
202
203 // See if this entry exists in the map
204 HistMap_t::const_iterator it = m_histMap.find( histHash );
205 if ( it == m_histMap.end() ) // It doesn't exist!
206 { // Let's see into the THistSvc if somebody else has registered the histogram...
207
208 // Need to copy the strings as we will massage them from here on
209 std::string histNameCopy = histName;
210 std::string tDirCopy = tDir;
211 std::string streamCopy = stream;
212
213 // Massage the final string to book things
214 std::string bookingString("");
215 this->buildBookingString( bookingString, histNameCopy, tDirCopy, streamCopy ,false);
216
217 TH1* histPointer(NULL);
218 if ( !((histSvc()->getHist(bookingString, histPointer)).isSuccess()) )
219 {
220 // Massage the final string to book things
221 std::string bookingString("");
222 this->buildBookingString( bookingString, histNameCopy, tDirCopy, streamCopy, true );
223
224 if ( !((histSvc()->getHist(bookingString, histPointer)).isSuccess()) )
225 {
226 m_msg << MSG::WARNING
227 << "Problem retrieving the histogram with name (including pre- and post-fixes) "
228 << m_histNamePrefix + histNameCopy + m_histNamePostfix
229 << " or with name " << histNameCopy
230 << " in " << m_name << "... it doesn't exist, neither in the cached map nor in the THistSvc!"
231 << " Will return an NULL pointer... you have to handle it correctly!" << endmsg;
232 return NULL;
233 }
234 // If we get to here, we actually found the histogram in the THistSvc.
235 // So let's add it to the local cache map and return its pointer
236 m_histMap.insert( m_histMap.end(), std::pair< const hash_t, TH1* >( histHash, histPointer ) );
237 return histPointer;
238 }
239 // If we get to here, we actually found the histogram in the THistSvc.
240 // So let's add it to the local cache map and return its pointer
241 m_histMap.insert( m_histMap.end(), std::pair< const hash_t, TH1* >( histHash, histPointer ) );
242 return histPointer;
243 }
244
245
246 // Return the pointer to the histogram that we got from the local cache map
247 return it->second;
248}

◆ hist2d()

TH2 * AthHistogramming::hist2d ( const std::string & histName,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the retrieval of registered 2-d histograms.

Definition at line 369 of file AthHistogramming.h.

370{
371 // Get the TH1 pointer
372 TH1* th1Pointer = this->hist(histName, tDir, stream);
373 if ( !th1Pointer )
374 {
375 m_msg << MSG::ERROR
376 << "Cannot get a 2-d histogram with name " << histName
377 << "... will probably seg-fault!" << endmsg;
378 return NULL;
379 }
380 // If the TH1 pointer is valid, simply return the dynamic_cast
381 return dynamic_cast<TH2*>( th1Pointer );
382}

◆ hist3d()

TH3 * AthHistogramming::hist3d ( const std::string & histName,
const std::string & tDir = "",
const std::string & stream = "" )
inlineprotectedinherited

Simplify the retrieval of registered 3-d histograms.

Definition at line 386 of file AthHistogramming.h.

387{
388 // Get the TH1 pointer
389 TH1* th1Pointer = this->hist(histName, tDir, stream);
390 if ( !th1Pointer )
391 {
392 m_msg << MSG::ERROR
393 << "Cannot get a 3-d histogram with name " << histName
394 << "... will probably seg-fault!" << endmsg;
395 return NULL;
396 }
397 // If the TH1 pointer is valid, simply return the dynamic_cast
398 return dynamic_cast<TH3*>( th1Pointer );
399}

◆ histSvc()

const ServiceHandle< ITHistSvc > & AthHistogramAlgorithm::histSvc ( ) const
inlineinherited

The standard THistSvc (for writing histograms and TTrees and more to a root file) Returns (kind of) a pointer to the THistSvc.

Definition at line 113 of file AthHistogramAlgorithm.h.

114{
115 return m_histSvc;
116}

◆ initialize()

StatusCode MuonCalib::MuonSegmentReader::initialize ( )
overridevirtual

Definition at line 17 of file MuonSegmentReader.cxx.

18{
19
20 ATH_CHECK(m_evtKey.initialize() );
21 //ATH_CHECK(m_TrkSegKey.initialize());
22 ATH_CHECK(m_TrkKey.initialize());
23 //ATH_CHECK(m_CbTrkKey.initialize());
24 //ATH_CHECK(m_EMEO_TrkKey.initialize()); // run3 only EM EO MS tracks
25 ATH_CHECK(m_MdtPrepDataKey.initialize());
26 ATH_CHECK(m_RpcPrepDataKey.initialize());
27 ATH_CHECK(m_TgcPrepDataKey.initialize());
28 ATH_CHECK(m_calibrationTool.retrieve());
29 ATH_MSG_VERBOSE("MdtCalibrationTool retrieved with pointer = " << m_calibrationTool);
30
31 ATH_CHECK(m_DetectorManagerKey.initialize());
32 ATH_CHECK(m_idToFixedIdTool.retrieve());
33 ATH_CHECK(m_pullCalculator.retrieve());
34 // ATH_CHECK(m_assocTool.retrieve());
35 // ATH_CHECK(m_idHelperSvc.retrieve());
36 ATH_CHECK(m_MuonIdHelper.retrieve());
37 ATH_CHECK(m_printer.retrieve());
38 //ATH_CHECK(histSvc.retrieve() );
39 ATH_CHECK(m_tree.init(this));
40
41
42
43 return StatusCode::SUCCESS;
44}
#define ATH_MSG_VERBOSE(x)
ServiceHandle< Muon::IMuonIdHelperSvc > m_MuonIdHelper
PublicToolHandle< Trk::IResidualPullCalculator > m_pullCalculator
ToolHandle< IMdtCalibrationTool > m_calibrationTool
pointer to MdtCalibSvc

◆ inputHandles()

virtual std::vector< Gaudi::DataHandle * > AthCommonDataStore< AthCommonMsg< Algorithm > >::inputHandles ( ) const
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.

◆ msg()

MsgStream & AthCommonMsg< Algorithm >::msg ( ) const
inlineinherited

Definition at line 24 of file AthCommonMsg.h.

24 {
25 return this->msgStream();
26 }

◆ msgLvl()

bool AthCommonMsg< Algorithm >::msgLvl ( const MSG::Level lvl) const
inlineinherited

Definition at line 30 of file AthCommonMsg.h.

30 {
31 return this->msgLevel(lvl);
32 }

◆ myReplace()

void AthHistogramming::myReplace ( std::string & str,
const std::string & oldStr,
const std::string & newStr )
privateinherited

Helper method to replace sub-string.

Definition at line 590 of file AthHistogramming.cxx.

593{
594 size_t pos = 0;
595 while((pos = str.find(oldStr, pos)) != std::string::npos)
596 {
597 str.replace(pos, oldStr.length(), newStr);
598 pos += newStr.length();
599 }
600}

◆ outputHandles()

virtual std::vector< Gaudi::DataHandle * > AthCommonDataStore< AthCommonMsg< Algorithm > >::outputHandles ( ) const
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.

◆ renounce()

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 > AthCommonDataStore< AthCommonMsg< Algorithm > >::renounce ( T & h)
inlineprotectedinherited

Definition at line 380 of file AthCommonDataStore.h.

381 {
382 h.renounce();
384 }
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)

◆ renounceArray()

void AthCommonDataStore< AthCommonMsg< Algorithm > >::renounceArray ( SG::VarHandleKeyArray & handlesArray)
inlineprotectedinherited

remove all handles from I/O resolution

Definition at line 364 of file AthCommonDataStore.h.

364 {
366 }

◆ storeHole()

void MuonCalib::MuonSegmentReader::storeHole ( const Trk::TrackStateOnSurface * trk_state,
unsigned int itrk )
private

Definition at line 218 of file MuonSegmentReader.cxx.

218 {
219 ATH_MSG_DEBUG(" MDT Hole on track ");
220 const Trk::TrackParameters *trackPars = trk_state->trackParameters();
221 if (!trackPars) return;
222 Amg::Vector3D pos = trackPars->position();
223 m_trkHole_gPos.push_back(pos);
224
225 const Identifier idHole = trk_state->trackParameters()->associatedSurface().associatedDetectorElementIdentifier();
226 MuonFixedId fixid = m_idToFixedIdTool->idToFixedId(idHole);
227 m_trkHole_id.push_back(fixid.getIdInt()) ;
228 ATH_MSG_DEBUG(" Hole stored at position x " << pos.x() << " y " << pos.y() << " z " << pos.z());
229 // check the hit type (1 MDT /2 RPC/3 TGC)
230 if (m_MuonIdHelper->isMdt(idHole)) m_trkHole_type.push_back(1);
231 else if (m_MuonIdHelper->isRpc(idHole)) m_trkHole_type.push_back(2);
232 else if (m_MuonIdHelper->isTgc(idHole)) m_trkHole_type.push_back(3);
233 else {
234 m_trkHole_type.push_back(0);
235 ATH_MSG_DEBUG("None of MDT/RPC/TGC Identifier match, something wrong!");
236 }
237
238 m_trkHole_driftRadius.push_back(std::abs(trackPars->parameters()[Trk::locR]));
239 m_trkHole_trackIndex.push_back(itrk);
240
241} // end storeHole
VectorBranch< unsigned int > & m_trkHole_id
VectorBranch< int > & m_trkHole_trackIndex
VectorBranch< float > & m_trkHole_driftRadius
const Amg::Vector3D & position() const
Access method for the position.
virtual const Surface & associatedSurface() const override=0
Access to the Surface associated to the Parameters.
Identifier associatedDetectorElementIdentifier() const
return Identifier of the associated Detector Element
const TrackParameters * trackParameters() const
return ptr to trackparameters const overload
@ locR
Definition ParamDefs.h:44
ParametersBase< TrackParametersDim, Charged > TrackParameters

◆ storeMeasurement()

void MuonCalib::MuonSegmentReader::storeMeasurement ( const EventContext & ctx,
const MuonGM::MuonDetectorManager * MuonDetMgr,
unsigned int itrk,
const Trk::TrackStateOnSurface * trk_state,
const Trk::MeasurementBase * measurement )
private

Definition at line 244 of file MuonSegmentReader.cxx.

244 {
245
246 const Trk::TrackParameters *trackPars = trk_state->trackParameters();
247 const Trk::RIO_OnTrack* rot = dynamic_cast<const Trk::RIO_OnTrack*>(measurement);
248
249 if (rot) { // case of measurement exist
250 Identifier rot_id = rot->identify();
251 if (m_MuonIdHelper->isMdt(rot_id)) {
252 const Muon::MdtDriftCircleOnTrack* mrot = dynamic_cast<const Muon::MdtDriftCircleOnTrack*>(rot);
253 if (!mrot) {
254 ATH_MSG_DEBUG("This is not a MdtDriftCircleOnTrack!!! ");
255 return;
256 }
257 int hitType = 0;
259 hitType = 1;
260 }
261 else if (trk_state->type(Trk::TrackStateOnSurface::Outlier)) {
262 hitType = 4;
263 }
264 else ATH_MSG_WARNING("This hit is not measurement o outlier, hit type wrong!");
265 m_trkHit_type.push_back(hitType);
266
267 // get PRD
268 const Muon::MdtPrepData* prd = mrot->prepRawData();
269 Identifier id = prd->identify();
270 int adc = prd->adc();
271 int tdc = prd->tdc();
272 Amg::Vector3D prd_pos = prd->globalPosition();
273 ATH_MSG_DEBUG("PRD ADC "<<adc<<" PRD TDC "<<tdc<<" PRD gPos "<<prd_pos);
274 // add the implement of calibrationTool, initialize global position by mrot
275 MdtCalibInput calibIn{*prd};
276 calibIn.setClosestApproach(mrot->globalPosition());
277 calibIn.setTrackDirection(trackPars->momentum().unit(), true);
278 const MdtCalibOutput calibResult{m_calibrationTool->calibrate(ctx, calibIn, false)};
279 ATH_MSG_DEBUG("print "<<calibIn << " calibResult : "<<calibResult);
280 m_trkHit_tubeT0.push_back(calibResult.tubeT0());
281 m_trkHit_tubeMeanAdc.push_back(calibResult.meanAdc());
282 m_trkHit_lorTime.push_back(calibResult.lorentzTime());
283 m_trkHit_slewTime.push_back(calibResult.slewingTime());
284 m_trkHit_propTime.push_back(calibResult.signalPropagationTime());
285 m_trkHit_tempTime.push_back(calibResult.temperatureTime());
286 m_trkHit_bkgTime.push_back(calibResult.backgroundTime());
287 m_trkHit_tof.push_back(calibIn.timeOfFlight());
288 m_trkHit_triggerTime.push_back(calibIn.triggerTime());
289 m_trkHit_calibStatus.push_back(calibResult.status());
290
291 // fill the trkHit branches
292 m_trkHit_adc.push_back(adc) ;
293 m_trkHit_tdc.push_back(tdc) ;
294 m_trkHit_trackIndex.push_back(itrk) ;
295 m_trkHit_driftTime.push_back(mrot->driftTime());
296
297 float localAngle = mrot->localAngle() ;
298 float driftRadius = mrot->driftRadius() ;
299 float error = std::sqrt(mrot->localCovariance()(0, 0));
300 m_trkHit_error.push_back(error) ;
301 m_trkHit_localAngle.push_back(localAngle);
302 m_trkHit_driftRadius.push_back(driftRadius) ;
303
304 const MuonGM::MdtReadoutElement* detEl = MuonDetMgr->getMdtReadoutElement(id);
305 if( !detEl ) {
306 ATH_MSG_WARNING( "getGlobalToStation failed to retrieve detEL byebye" );
307 return;
308 }
309
310 // get the 2nd coordinator from the track hit measurement
311 Amg::Vector3D trkHitPos = trackPars->position();
312 // global to local transformation for chamber coordination
313 Amg::Transform3D gToStation = detEl->GlobalToAmdbLRSTransform();
314
315 Amg::Vector3D trkHitPosLoc = gToStation* trkHitPos;
316 m_trkHit_closestApproach.push_back(trkHitPosLoc);
317 m_trkHit_gClosestApproach.push_back(trkHitPos);
318
319 // get trkHit local position from measurement
320 Amg::Vector3D mrot_gPos = mrot->globalPosition(); // equal to Amg::Vector3D mb_pos = it->globalPosition();
321 Amg::Vector3D mrot_pos = gToStation* mrot_gPos;
322
323 //distion to readout 2nd coordinators
324 float distRo_det = detEl->distanceFromRO(trkHitPos, id);
325 m_trkHit_distRO.push_back(distRo_det) ;
326
327 // save the local postion of hit center for local refitting, set x = 0, y = coordinator along the Ntube, z = coordinator along the Nlayer
328 Amg::Vector3D wireCenter = gToStation*detEl->tubePos(id);
329 wireCenter.x() = 0;
330 ATH_MSG_DEBUG(m_MuonIdHelper->mdtIdHelper().stationNameString(int(m_MuonIdHelper->mdtIdHelper().stationName(id)))<<" "<<m_MuonIdHelper->stationEta(id)<<" "<<m_MuonIdHelper->stationPhi(id)
331 <<" "<<"ml: "<<m_MuonIdHelper->mdtIdHelper().multilayer(id)<<" lb: "<<m_MuonIdHelper->mdtIdHelper().tubeLayer(id)<<" tube: "<<m_MuonIdHelper->mdtIdHelper().tube(id)
332 << " detEl wireLocalCenter " << " x : "<<wireCenter.x()<< " y : " << wireCenter.y()<< " z : "<<wireCenter.z());
333
334 m_trkHit_center.push_back(wireCenter);
335 m_trkHit_gPos.push_back(mrot_gPos);
336 m_trkHit_pos.push_back(mrot_pos);
337
338 // residual calculator
339 float residualBiased = -999.;
340 float pullBiased = -999.;
341 {
342 std::optional<Trk::ResidualPull> resPullBiased = m_pullCalculator->residualPull(measurement, trackPars, Trk::ResidualPull::Biased );
343 if(resPullBiased.has_value()){
344 residualBiased = resPullBiased.value().residual().front();
345 pullBiased = resPullBiased.value().pull().front();
346 }
347 }
348 // residual definition double residual = measurement->localParameters()[Trk::loc1] - trkPar->parameters()[Trk::loc1];
349 m_trkHit_resi.push_back(residualBiased) ;
350 m_trkHit_pull.push_back(pullBiased) ;
351 m_trkHit_rTrk.push_back(trackPars->parameters()[Trk::loc1]) ;
352
353 MuonFixedId fixid = m_idToFixedIdTool->idToFixedId(id);
354 m_trkHit_id.push_back(fixid.getIdInt()) ;
355
356 // debugging printout
357 ATH_MSG_DEBUG("trackHit distRO " << distRo_det<<" positionAlongWire "<<mrot->positionAlongWire()<<" tubeLength "<<detEl->tubeLength(id));
358 ATH_MSG_DEBUG("prd hit global position measurement " <<" x : "<< prd_pos.x()<<" y : "<< prd_pos.y()<<" z : "<<prd_pos.z());
359 ATH_MSG_DEBUG("MdtDriftCircleOnTrack hit global position measurement " << " x : " <<mrot_gPos.x()<<" y : "<< mrot_gPos.y() <<" z : "<<mrot_gPos.z());
360 ATH_MSG_DEBUG("trackHitPos from trackPars " << " x : "<<trkHitPos.x() <<" y : "<<trkHitPos.y() <<" z : "<< trkHitPos.z() );
361 ATH_MSG_DEBUG("trackHit Local Pos from globaltolocalCoords " <<" x : "<< trkHitPosLoc.x() <<" y : "<< trkHitPosLoc.y() <<" z : "<< trkHitPosLoc.z());
362 ATH_MSG_DEBUG("mrod Local Pos from globaltolocalCoords " <<" x : "<< mrot_pos.x() <<" y : "<< mrot_pos.y() <<" z : "<< mrot_pos.z());
363 ATH_MSG_DEBUG("TrackIndex "<<itrk<<" station " << fixid.stationNumberToFixedStationString(fixid.stationName()) << " eta " << fixid.eta() << " phi " << fixid.phi() << " ML " << fixid.mdtMultilayer() << " Layer " << fixid.mdtTubeLayer()
364 <<" Tube "<<fixid.mdtTube()<< " MROT drift R " << mrot->driftRadius() << " errDriftRadius " << error<< " drift Time "
365 << mrot->driftTime() <<" ADC "<<adc<<" TDC "<<tdc);
366 ATH_MSG_DEBUG(" driftRadius from driftRadius func "<<driftRadius<<" rTrk track fit to wire "<<trackPars->parameters()[Trk::loc1]<<" residualBiased " << residualBiased << " pullBiased " << pullBiased);
367
368 } // finish mdt hit loop
369
370 else if (m_MuonIdHelper->isRpc(rot_id)) {
371
372 ATH_MSG_DEBUG("Found the RPC ROT "<<rot_id<<" !");
373 MuonFixedId fixid = m_idToFixedIdTool->idToFixedId(rot_id);
374 m_trkTriggerHit_id.push_back(fixid.getIdInt()) ;
375 m_trkTriggerHit_trackIndex.push_back(itrk);
376 m_trkTriggerHit_type.push_back(1); // RPC ROT
377 const Muon::RpcClusterOnTrack* rpc = dynamic_cast<const Muon::RpcClusterOnTrack*>(rot);
378 const Muon::RpcPrepData* rpcPRD = rpc->prepRawData();
379 m_trkTriggerHit_time.push_back(rpcPRD->time());
380 m_trkTriggerHit_gPos.push_back(rpcPRD->globalPosition());
381
382 } // end of RPC rot
383 else if (m_MuonIdHelper->isTgc(rot_id)) {
384
385 ATH_MSG_DEBUG("Found the TGC ROT "<<rot_id<<" !");
386 MuonFixedId fixid = m_idToFixedIdTool->idToFixedId(rot_id);
387 m_trkTriggerHit_id.push_back(fixid.getIdInt()) ;
388 m_trkTriggerHit_trackIndex.push_back(itrk);
389 m_trkTriggerHit_type.push_back(3); // tgc ROT
390 const Muon::TgcClusterOnTrack* tgc = dynamic_cast<const Muon::TgcClusterOnTrack*>(rot);
391 const Muon::TgcPrepData* tgcPRD = tgc->prepRawData() ;
392 m_trkTriggerHit_time.push_back(tgcPRD->getBcBitMap());
393 m_trkTriggerHit_gPos.push_back(tgcPRD->globalPosition());
394
395 } //end of TGC rot
396 else {
397 ATH_MSG_DEBUG("Couldn't find track ROT ID "<<rot_id);
398 }
399
400 } // end of rot case
401 else {
402 ATH_MSG_DEBUG("No ROT! Check the competingROT");
403 // use competingROT from RPC and TGC
404 const Muon::CompetingMuonClustersOnTrack* crot = dynamic_cast<const Muon::CompetingMuonClustersOnTrack*>(measurement);
405 if (crot) {
406 const std::vector<const Muon::MuonClusterOnTrack*>& rots = crot->containedROTs();
407 if (rots.size() > 0) {
408 std::vector<const Muon::MuonClusterOnTrack*>::const_iterator itR = rots.begin(), itR_end = rots.end();
409 for (; itR != itR_end; ++itR) {
410 Identifier crot_id = (*itR)->identify() ;
411 MuonFixedId fixid = m_idToFixedIdTool->idToFixedId(crot_id);
412 m_trkTriggerHit_id.push_back(fixid.getIdInt());
413 m_trkTriggerHit_trackIndex.push_back(itrk);
414 if (m_MuonIdHelper->isTgc(crot_id)) {
415 ATH_MSG_DEBUG("This is TGC competing hits on track!") ;
416 if (m_MuonIdHelper->tgcIdHelper().isStrip(crot_id)) m_trkTriggerHit_type.push_back(5); // tgc strip hit, measuresPhi
417 else m_trkTriggerHit_type.push_back(4); // tgc wire hit
418 const Muon::TgcClusterOnTrack* tgc = dynamic_cast<const Muon::TgcClusterOnTrack*>(*itR);
419 const Muon::TgcPrepData* tgcPRD = tgc ? tgc->prepRawData() : nullptr;
420 if (tgcPRD) {
421 m_trkTriggerHit_time.push_back(tgcPRD->getBcBitMap());
422 m_trkTriggerHit_gPos.push_back(tgcPRD->globalPosition());
423 }
424 else {
425 m_trkTriggerHit_time.push_back(0);
426 m_trkTriggerHit_gPos.push_back(Amg::Vector3D(0,0,0));
427 }
428 } // tgc case
429 else if (m_MuonIdHelper->isRpc(crot_id)) {
430 ATH_MSG_DEBUG("This is RPC competing hits on track!") ;
431 m_trkTriggerHit_type.push_back(2);
432 const Muon::RpcClusterOnTrack* rpc = dynamic_cast<const Muon::RpcClusterOnTrack*>(*itR);
433 const Muon::RpcPrepData* rpcPRD = rpc ? rpc->prepRawData() : nullptr;
434 if (rpcPRD) {
435 m_trkTriggerHit_time.push_back(rpcPRD->time());
436 m_trkTriggerHit_gPos.push_back(rpcPRD->globalPosition());
437 }
438 else {
439 m_trkTriggerHit_time.push_back(0);
440 m_trkTriggerHit_gPos.push_back(Amg::Vector3D(0,0,0));
441 } // rpc case
442 } // rpc case
443 else {
444 m_trkTriggerHit_type.push_back(0);
445 m_trkTriggerHit_time.push_back(0);
446 m_trkTriggerHit_gPos.push_back(Amg::Vector3D(0,0,0));
447 }
448 } // end of crots loop
449 } // end of crots size check
450 } // end of crot check
451 } // end of CompetingROT
452} // end of store measurement
void setClosestApproach(const Amg::Vector3D &approach)
Sets the closest approach.
double timeOfFlight() const
Returns the time of flight.
double triggerTime() const
Returns the trigger offset time.
void setTrackDirection(const Amg::Vector3D &trackDir, bool hasPhi)
Sets the direction of the externally determined track.
double backgroundTime() const
Return the time correction arising from background processes.
MdtDriftCircleStatus status() const
Status of the calibration.
double temperatureTime() const
Returns the time corrections stemming from temperature & pressure corrections.
double signalPropagationTime() const
Returns the signal propagation time.
double lorentzTime() const
Returns the time corrections from the signal propgation inside a magnetic field.
double tubeT0() const
Returns the point in time where the muon typically enters the chamber.
double meanAdc() const
Returns the mean tube adc.
double slewingTime() const
Returns the slewing time (Needed time that the accumulated charge passes the electronic threshold to ...
VectorBranch< float > & m_trkHit_triggerTime
VectorBranch< int > & m_trkHit_tdc
VectorBranch< float > & m_trkHit_error
VectorBranch< unsigned int > & m_trkTriggerHit_id
ThreeVectorBranch m_trkHit_closestApproach
VectorBranch< int > & m_trkHit_trackIndex
ThreeVectorBranch m_trkHit_gClosestApproach
VectorBranch< int > & m_trkTriggerHit_trackIndex
ThreeVectorBranch m_trkTriggerHit_gPos
VectorBranch< float > & m_trkHit_rTrk
VectorBranch< float > & m_trkHit_driftRadius
VectorBranch< unsigned int > & m_trkHit_id
VectorBranch< float > & m_trkHit_tubeT0
VectorBranch< float > & m_trkHit_lorTime
VectorBranch< float > & m_trkHit_tof
VectorBranch< float > & m_trkHit_tubeMeanAdc
VectorBranch< float > & m_trkHit_localAngle
VectorBranch< float > & m_trkHit_pull
VectorBranch< int > & m_trkHit_calibStatus
VectorBranch< float > & m_trkHit_slewTime
VectorBranch< float > & m_trkTriggerHit_time
VectorBranch< float > & m_trkHit_bkgTime
VectorBranch< float > & m_trkHit_tempTime
VectorBranch< float > & m_trkHit_driftTime
VectorBranch< float > & m_trkHit_propTime
VectorBranch< float > & m_trkHit_distRO
VectorBranch< int > & m_trkHit_adc
VectorBranch< float > & m_trkHit_resi
Amg::Vector3D tubePos(const Identifier &id) const
Returns the global position of the given tube.
double distanceFromRO(const Amg::Vector3D &GlobalHitPosition, const Identifier &id) const
double tubeLength(const int tubeLayer, const int tube) const
const MdtReadoutElement * getMdtReadoutElement(const Identifier &id) const
access via extended identifier (requires unpacking)
const std::vector< const MuonClusterOnTrack * > & containedROTs() const
returns the vector of SCT_ClusterOnTrack objects .
double localAngle() const
Returns the local angle, as determined by the extrapolation used when creating this Trk::RIO_OnTrack.
virtual const Amg::Vector3D & globalPosition() const override final
Returns the global Position.
double driftRadius() const
Returns the value of the drift radius.
double driftTime() const
Returns the value of the drift time used to obtain the drift radius.
double positionAlongWire() const
Returns the position along the wire, as determined by the extrapolation used when creating this Trk::...
virtual const MdtPrepData * prepRawData() const override final
Returns the PrepRawData used to create this corrected measurement.
int adc() const
Returns the ADC (typically range is 0 to 250)
virtual const Amg::Vector3D & globalPosition() const
Returns the global position of the CENTER of the drift tube (i.e.
int tdc() const
Returns the TDC (typically range is 0 to 2500).
virtual const RpcPrepData * prepRawData() const override final
Returns the RpcPrepData - is a TRT_DriftCircle in this scope.
virtual const Amg::Vector3D & globalPosition() const override
Returns the global position.
float time() const
Returns the time.
virtual const TgcPrepData * prepRawData() const
Returns the TgcPrepData - is a TRT_DriftCircle in this scope.
virtual const Amg::Vector3D & globalPosition() const override final
Returns the global position.
uint16_t getBcBitMap() const
Returns the bcBitMap of this PRD bit2 for Previous BC, bit1 for Current BC, bit0 for Next BC.
const Amg::MatrixX & localCovariance() const
Interface method to get the localError.
Identifier identify() const
return the identifier
Identifier identify() const
return the identifier -extends MeasurementBase
@ Biased
RP with track state including the hit.
bool type(const TrackStateOnSurfaceType type) const
Use this method to find out if the TSoS is of a certain type: i.e.
@ Measurement
This is a measurement, and will at least contain a Trk::MeasurementBase.
@ Outlier
This TSoS contains an outlier, that is, it contains a MeasurementBase/RIO_OnTrack which was not used ...
Eigen::Affine3d Transform3D
@ driftRadius
trt, straws
Definition ParamDefs.h:53
@ loc1
Definition ParamDefs.h:34

◆ sysInitialize()

StatusCode AthHistogramAlgorithm::sysInitialize ( )
virtualinherited

Initialization method invoked by the framework.

This method is responsible for any bookkeeping of initialization required by the framework itself. It will in turn invoke the initialize() method of the derived algorithm, and of any sub-algorithms which it creates.

Reimplemented from AthAlgorithm.

Reimplemented in AthAnalysisAlgorithm.

Definition at line 75 of file AthHistogramAlgorithm.cxx.

76{
77 // ---- stolen from GaudiKernel/Algorithm::sysInitialize -------
78 // Bypass the initialization if the algorithm
79 // has already been initialized.
80 if ( Gaudi::StateMachine::INITIALIZED <= FSMState() ) return StatusCode::SUCCESS;
81
82 // Set the Algorithm's properties
83 bindPropertiesTo( serviceLocator()->getOptsSvc() );
84
85 // Bypass the initialization if the algorithm is disabled.
86 // Need to do this after bindPropertiesTo.
87 if ( !isEnabled( ) ) return StatusCode::SUCCESS;
88
89 // ---- stolen from GaudiKernel/Algorithm::sysInitialize ------- END ---
90
91
92 // Get the THistSvc
94
95 // Configure the underlying AthHistogramming helper
100
101 // Print some setup information into the log file
102 ATH_MSG_DEBUG ("Initializing " << name() << "...");
103 ATH_MSG_DEBUG (" using THistService = " << m_histSvc );
104 ATH_MSG_DEBUG (" using RootStreamName = " << m_prefix );
105 ATH_MSG_DEBUG (" using RootDirName = " << m_rootDir );
106 ATH_MSG_DEBUG (" using HistNamePrefix = " << m_histNamePrefix );
107 ATH_MSG_DEBUG (" using HistNamePostfix = " << m_histNamePostfix );
108 ATH_MSG_DEBUG (" using HistTitlePrefix = " << m_histTitlePrefix );
109 ATH_MSG_DEBUG (" using HistTitlePostfix = " << m_histTitlePostfix );
110
111
112 // re-direct to base class...
114}
virtual StatusCode sysInitialize() override
Override sysInitialize.
const ServiceHandle< ITHistSvc > & histSvc() const
The standard THistSvc (for writing histograms and TTrees and more to a root file) Returns (kind of) a...
StatusCode configAthHistogramming(const ServiceHandle< ITHistSvc > &histSvc, const std::string &prefix, const std::string &rootDir, const std::string &histNamePrefix, const std::string &histNamePostfix, const std::string &histTitlePrefix, const std::string &histTitlePostfix)
To be called by the derived classes to fill the internal configuration.
retrieve(aClass, aKey=None)
Definition PyKernel.py:110

◆ sysStart()

virtual StatusCode AthCommonDataStore< AthCommonMsg< Algorithm > >::sysStart ( )
overridevirtualinherited

Handle START transition.

We override this in order to make sure that conditions handle keys can cache a pointer to the conditions container.

◆ tree()

TTree * AthHistogramming::tree ( const std::string & treeName,
const std::string & tDir = "",
const std::string & stream = "" )
protectedinherited

Simplify the retrieval of registered TTrees.

Definition at line 378 of file AthHistogramming.cxx.

379{
380 // Build a 32 bit hash out of the name
381 const hash_t treeHash = this->hash(treeName);
382
383 // See if this entry exists in the map
384 TreeMap_t::const_iterator it = m_treeMap.find( treeHash );
385 if ( it == m_treeMap.end() ) // It doesn't exist!
386 { // Let's see into the THistSvc if somebody else has registered the TTree...
387
388 // Need to copy the strings as we will massage them from here on
389 std::string treeNameCopy = treeName;
390 std::string tDirCopy = tDir;
391 std::string streamCopy = stream;
392
393 // Massage the final string to book things
394 std::string bookingString("");
395 this->buildBookingString( bookingString, treeNameCopy, tDirCopy, streamCopy );
396
397 TTree* treePointer(NULL);
398 if ( !((histSvc()->getTree(bookingString, treePointer)).isSuccess()) )
399 {
400 m_msg << MSG::WARNING
401 << "Problem retrieving the TTree with name " << treeNameCopy
402 << " in " << m_name << "... it doesn't exist, neither in the cached map nor in the THistSvc!"
403 << " Will return an NULL pointer... you have to handle it correctly!" << endmsg;
404 return NULL;
405 }
406 // If we get to here, we actually found the TTree in the THistSvc.
407 // So let's add it to the local cache map and return its pointer
408 m_treeMap.insert( m_treeMap.end(), std::pair< const hash_t, TTree* >( treeHash, treePointer ) );
409 return treePointer;
410 }
411
412 // Return the pointer to the TTree that we got from the local cache map
413 return it->second;
414}

◆ updateVHKA()

void AthCommonDataStore< AthCommonMsg< Algorithm > >::updateVHKA ( Gaudi::Details::PropertyBase & )
inlineinherited

Definition at line 308 of file AthCommonDataStore.h.

308 {
309 // debug() << "updateVHKA for property " << p.name() << " " << p.toString()
310 // << " size: " << m_vhka.size() << endmsg;
311 for (auto &a : m_vhka) {
313 for (auto k : keys) {
314 k->setOwner(this);
315 }
316 }
317 }
std::vector< SG::VarHandleKeyArray * > m_vhka

Member Data Documentation

◆ m_bcId

ScalarBranch<int>& MuonCalib::MuonSegmentReader::m_bcId {m_tree.newScalar<int>("event_bcId")}
private

Definition at line 85 of file MuonSegmentReader.h.

85{m_tree.newScalar<int>("event_bcId")};

◆ m_calibrationTool

ToolHandle<IMdtCalibrationTool> MuonCalib::MuonSegmentReader::m_calibrationTool {this, "CalibrationTool", "MdtCalibrationTool"}
private

pointer to MdtCalibSvc

Definition at line 71 of file MuonSegmentReader.h.

71{this, "CalibrationTool", "MdtCalibrationTool"};

◆ m_DetectorManagerKey

SG::ReadCondHandleKey<MuonGM::MuonDetectorManager> MuonCalib::MuonSegmentReader::m_DetectorManagerKey
private
Initial value:
{this, "DetectorManagerKey", "MuonDetectorManager",
"Key of input MuonDetectorManager condition data"}

MuonDetectorManager from the conditions store.

Definition at line 64 of file MuonSegmentReader.h.

64 {this, "DetectorManagerKey", "MuonDetectorManager",
65 "Key of input MuonDetectorManager condition data"};

◆ m_detStore

StoreGateSvc_t AthCommonDataStore< AthCommonMsg< Algorithm > >::m_detStore
privateinherited

Pointer to StoreGate (detector store by default)

Definition at line 393 of file AthCommonDataStore.h.

◆ m_effMap

EffMap_t AthHistogramming::m_effMap
privateinherited

The map of histogram names to their pointers.

Definition at line 208 of file AthHistogramming.h.

◆ m_eventNumber

ScalarBranch<int>& MuonCalib::MuonSegmentReader::m_eventNumber {m_tree.newScalar<int>("event_eventNumber")}
private

Definition at line 83 of file MuonSegmentReader.h.

83{m_tree.newScalar<int>("event_eventNumber")};

◆ m_evtKey

SG::ReadHandleKey<xAOD::EventInfo> MuonCalib::MuonSegmentReader::m_evtKey {this, "EventInfoKey", "EventInfo", "xAOD::EventInfo ReadHandleKey"}
private

Definition at line 54 of file MuonSegmentReader.h.

54{this, "EventInfoKey", "EventInfo", "xAOD::EventInfo ReadHandleKey"};

◆ m_evtStore

StoreGateSvc_t AthCommonDataStore< AthCommonMsg< Algorithm > >::m_evtStore
privateinherited

Pointer to StoreGate (event store by default)

Definition at line 390 of file AthCommonDataStore.h.

◆ m_extendedExtraObjects

DataObjIDColl AthAlgorithm::m_extendedExtraObjects
privateinherited

Definition at line 79 of file AthAlgorithm.h.

◆ m_graphMap

GraphMap_t AthHistogramming::m_graphMap
privateinherited

The map of TGraph names to their pointers.

Definition at line 222 of file AthHistogramming.h.

◆ m_histMap

HistMap_t AthHistogramming::m_histMap
privateinherited

The map of histogram names to their pointers.

Definition at line 201 of file AthHistogramming.h.

◆ m_histNamePostfix

std::string AthHistogramAlgorithm::m_histNamePostfix
privateinherited

The postfix for the histogram THx name.

Definition at line 97 of file AthHistogramAlgorithm.h.

◆ m_histNamePrefix

std::string AthHistogramAlgorithm::m_histNamePrefix
privateinherited

The prefix for the histogram THx name.

Definition at line 94 of file AthHistogramAlgorithm.h.

◆ m_histSvc

ServiceHandle<ITHistSvc> AthHistogramAlgorithm::m_histSvc
privateinherited

Default constructor: AthHistogramAlgorithm();.

a handle on the Hist/TTree registration service

Definition at line 83 of file AthHistogramAlgorithm.h.

◆ m_histTitlePostfix

std::string AthHistogramAlgorithm::m_histTitlePostfix
privateinherited

The postfix for the histogram THx title.

Definition at line 103 of file AthHistogramAlgorithm.h.

◆ m_histTitlePrefix

std::string AthHistogramAlgorithm::m_histTitlePrefix
privateinherited

The prefix for the histogram THx title.

Definition at line 100 of file AthHistogramAlgorithm.h.

◆ m_idToFixedIdTool

ToolHandle<MuonCalib::IIdToFixedIdTool> MuonCalib::MuonSegmentReader::m_idToFixedIdTool {this, "IdToFixedIdTool", "MuonCalib::IdToFixedIdTool/MuonCalib_IdToFixedIdTool"}
private

Definition at line 76 of file MuonSegmentReader.h.

76{this, "IdToFixedIdTool", "MuonCalib::IdToFixedIdTool/MuonCalib_IdToFixedIdTool"};

◆ m_lumiBlock

ScalarBranch<int>& MuonCalib::MuonSegmentReader::m_lumiBlock {m_tree.newScalar<int>("event_lumiBlock")}
private

Definition at line 84 of file MuonSegmentReader.h.

84{m_tree.newScalar<int>("event_lumiBlock")};

◆ m_MdtPrepDataKey

SG::ReadHandleKey<Muon::MdtPrepDataContainer> MuonCalib::MuonSegmentReader::m_MdtPrepDataKey {this, "MdtPrepData", "MDT_DriftCircles","MDT DriftCircles"}
private

Definition at line 59 of file MuonSegmentReader.h.

59{this, "MdtPrepData", "MDT_DriftCircles","MDT DriftCircles"};

◆ m_msg

MsgStream AthHistogramming::m_msg
privateinherited

Cached Message Stream.

Definition at line 248 of file AthHistogramming.h.

◆ m_MuonIdHelper

ServiceHandle<Muon::IMuonIdHelperSvc> MuonCalib::MuonSegmentReader::m_MuonIdHelper
private
Initial value:
{this, "MuonIdHelper", "Muon::MuonIdHelperSvc/MuonIdHelperSvc",
"Handle to the MuonIdHelperSvc"}

Definition at line 67 of file MuonSegmentReader.h.

67 {this, "MuonIdHelper", "Muon::MuonIdHelperSvc/MuonIdHelperSvc",
68 "Handle to the MuonIdHelperSvc"};

◆ m_name

std::string AthHistogramming::m_name
privateinherited

Instance name.

Definition at line 245 of file AthHistogramming.h.

◆ m_prefix

std::string AthHistogramAlgorithm::m_prefix
privateinherited

Name of the ROOT output stream (file)

Definition at line 88 of file AthHistogramAlgorithm.h.

◆ m_printer

PublicToolHandle<Muon::MuonEDMPrinterTool> MuonCalib::MuonSegmentReader::m_printer {this, "Printer", "Muon::MuonEDMPrinterTool/MuonEDMPrinterTool"}
private

Definition at line 78 of file MuonSegmentReader.h.

78{this, "Printer", "Muon::MuonEDMPrinterTool/MuonEDMPrinterTool"};

◆ m_pt

ScalarBranch<float>& MuonCalib::MuonSegmentReader::m_pt {m_tree.newScalar<float>("event_LVL2Pt")}
private

Definition at line 87 of file MuonSegmentReader.h.

87{m_tree.newScalar<float>("event_LVL2Pt")};

◆ m_pullCalculator

PublicToolHandle<Trk::IResidualPullCalculator> MuonCalib::MuonSegmentReader::m_pullCalculator
private
Initial value:
{this, "PullCalculator",
"Trk::ResidualPullCalculator/ResidualPullCalculator"}

Definition at line 73 of file MuonSegmentReader.h.

73 {this, "PullCalculator",
74 "Trk::ResidualPullCalculator/ResidualPullCalculator"};

◆ m_rawMdt_adc

VectorBranch<int>& MuonCalib::MuonSegmentReader::m_rawMdt_adc {m_tree.newVector<int>("rawMdt_adc")}
private

Definition at line 95 of file MuonSegmentReader.h.

95{m_tree.newVector<int>("rawMdt_adc")}; //adc counts of the raw MDT hit

◆ m_rawMdt_gPos

ThreeVectorBranch MuonCalib::MuonSegmentReader::m_rawMdt_gPos {m_tree,"rawMdt_gPos"}
private

Definition at line 96 of file MuonSegmentReader.h.

96{m_tree,"rawMdt_gPos"};

◆ m_rawMdt_id

VectorBranch<unsigned int>& MuonCalib::MuonSegmentReader::m_rawMdt_id {m_tree.newVector<unsigned int>("rawMdt_id")}
private

Definition at line 93 of file MuonSegmentReader.h.

93{m_tree.newVector<unsigned int>("rawMdt_id")}; //identifier of the raw MDT hit (given by MuonFixedId)

◆ m_rawMdt_nRMdt

ScalarBranch<int>& MuonCalib::MuonSegmentReader::m_rawMdt_nRMdt {m_tree.newScalar<int>("rawMdt_nRMdt")}
private

Definition at line 92 of file MuonSegmentReader.h.

92{m_tree.newScalar<int>("rawMdt_nRMdt")}; //total number of MDT hits in the event

◆ m_rawMdt_tdc

VectorBranch<int>& MuonCalib::MuonSegmentReader::m_rawMdt_tdc {m_tree.newVector<int>("rawMdt_tdc")}
private

Definition at line 94 of file MuonSegmentReader.h.

94{m_tree.newVector<int>("rawMdt_tdc")}; //tdc counts of the raw MDT hit

◆ m_rawRpc_gPos

ThreeVectorBranch MuonCalib::MuonSegmentReader::m_rawRpc_gPos {m_tree,"rawRpc_gPos"}
private

Definition at line 102 of file MuonSegmentReader.h.

102{m_tree,"rawRpc_gPos"};

◆ m_rawRpc_id

VectorBranch<unsigned int>& MuonCalib::MuonSegmentReader::m_rawRpc_id {m_tree.newVector<unsigned int>("rawRpc_id")}
private

Definition at line 100 of file MuonSegmentReader.h.

100{m_tree.newVector<unsigned int>("rawRpc_id")}; //identifier of the raw MDT hit (given by MuonFixedId)

◆ m_rawRpc_nRRpc

ScalarBranch<int>& MuonCalib::MuonSegmentReader::m_rawRpc_nRRpc {m_tree.newScalar<int>("rawRpc_nRRpc")}
private

Definition at line 99 of file MuonSegmentReader.h.

99{m_tree.newScalar<int>("rawRpc_nRRpc")}; //total number of MDT hits in the event

◆ m_rawRpc_time

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_rawRpc_time {m_tree.newVector<float>("rawRpc_time")}
private

Definition at line 101 of file MuonSegmentReader.h.

101{m_tree.newVector<float>("rawRpc_time")}; //times of the raw RPC hit

◆ m_rawTgc_bcBitMap

VectorBranch<int>& MuonCalib::MuonSegmentReader::m_rawTgc_bcBitMap {m_tree.newVector<int>("rawTgc_bcBitMap")}
private

Definition at line 107 of file MuonSegmentReader.h.

107{m_tree.newVector<int>("rawTgc_bcBitMap")}; //times of the raw MDT hit

◆ m_rawTgc_gPos

ThreeVectorBranch MuonCalib::MuonSegmentReader::m_rawTgc_gPos {m_tree,"rawTgc_gPos"}
private

Definition at line 108 of file MuonSegmentReader.h.

108{m_tree,"rawTgc_gPos"};

◆ m_rawTgc_id

VectorBranch<unsigned int>& MuonCalib::MuonSegmentReader::m_rawTgc_id {m_tree.newVector<unsigned int>("rawTgc_id")}
private

Definition at line 106 of file MuonSegmentReader.h.

106{m_tree.newVector<unsigned int>("rawTgc_id")}; //identifier of the raw MDT hit (given by MuonFixedId)

◆ m_rawTgc_nRTgc

ScalarBranch<int>& MuonCalib::MuonSegmentReader::m_rawTgc_nRTgc {m_tree.newScalar<int>("rawTgc_nRTgc")}
private

Definition at line 105 of file MuonSegmentReader.h.

105{m_tree.newScalar<int>("rawTgc_nRTgc")}; //total number of MDT hits in the event

◆ m_rootDir

std::string AthHistogramAlgorithm::m_rootDir
privateinherited

Name of the ROOT directory.

Definition at line 91 of file AthHistogramAlgorithm.h.

◆ m_RpcPrepDataKey

SG::ReadHandleKey<Muon::RpcPrepDataContainer> MuonCalib::MuonSegmentReader::m_RpcPrepDataKey {this,"RpcPrdCollection","RPC_Measurements","RPC PRD Container"}
private

Definition at line 60 of file MuonSegmentReader.h.

60{this,"RpcPrdCollection","RPC_Measurements","RPC PRD Container"};

◆ m_runNumber

ScalarBranch<int>& MuonCalib::MuonSegmentReader::m_runNumber {m_tree.newScalar<int>("event_runNumber")}
private

Definition at line 82 of file MuonSegmentReader.h.

82{m_tree.newScalar<int>("event_runNumber")};

◆ m_streamName

std::string AthHistogramming::m_streamName
privateinherited

Name of the ROOT output stream (file)

Definition at line 226 of file AthHistogramming.h.

◆ m_TgcPrepDataKey

SG::ReadHandleKey<Muon::TgcPrepDataContainer> MuonCalib::MuonSegmentReader::m_TgcPrepDataKey {this,"TgcPrdCollection","TGC_Measurements","TGC PRD Container"}
private

Definition at line 61 of file MuonSegmentReader.h.

61{this,"TgcPrdCollection","TGC_Measurements","TGC PRD Container"};

◆ m_timeStamp

ScalarBranch<int>& MuonCalib::MuonSegmentReader::m_timeStamp {m_tree.newScalar<int>("event_timeStamp")}
private

Definition at line 86 of file MuonSegmentReader.h.

86{m_tree.newScalar<int>("event_timeStamp")};

◆ m_tree

MuonTesterTree MuonCalib::MuonSegmentReader::m_tree {"Segments", "CALIBNTUPLESTREAM"}
private

Definition at line 80 of file MuonSegmentReader.h.

80{"Segments", "CALIBNTUPLESTREAM"};

◆ m_treeMap

TreeMap_t AthHistogramming::m_treeMap
privateinherited

The map of TTree names to their pointers.

Definition at line 215 of file AthHistogramming.h.

◆ m_trk_author

VectorBranch<int>& MuonCalib::MuonSegmentReader::m_trk_author {m_tree.newVector<int>("trk_author")}
private

Definition at line 121 of file MuonSegmentReader.h.

121{m_tree.newVector<int>("trk_author")};

◆ m_trk_chi2

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trk_chi2 {m_tree.newVector<float>("trk_chi2")}
private

Definition at line 119 of file MuonSegmentReader.h.

119{m_tree.newVector<float>("trk_chi2")};

◆ m_trk_d0

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trk_d0 {m_tree.newVector<float>("trk_d0")}
private

Definition at line 112 of file MuonSegmentReader.h.

112{m_tree.newVector<float>("trk_d0")};

◆ m_trk_eta

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trk_eta {m_tree.newVector<float>("trk_eta")}
private

Definition at line 116 of file MuonSegmentReader.h.

116{m_tree.newVector<float>("trk_eta")};

◆ m_trk_ndof

VectorBranch<int>& MuonCalib::MuonSegmentReader::m_trk_ndof {m_tree.newVector<int>("trk_ndof")}
private

Definition at line 120 of file MuonSegmentReader.h.

120{m_tree.newVector<int>("trk_ndof")};

◆ m_trk_nMdtHits

VectorBranch<int>& MuonCalib::MuonSegmentReader::m_trk_nMdtHits {m_tree.newVector<int>("trk_nMdtHits")}
private

Definition at line 124 of file MuonSegmentReader.h.

124{m_tree.newVector<int>("trk_nMdtHits")};

◆ m_trk_nMdtHoles

VectorBranch<int>& MuonCalib::MuonSegmentReader::m_trk_nMdtHoles {m_tree.newVector<int>("trk_nMdtHoles")}
private

Definition at line 125 of file MuonSegmentReader.h.

125{m_tree.newVector<int>("trk_nMdtHoles")};

◆ m_trk_nOutliersHits

VectorBranch<int>& MuonCalib::MuonSegmentReader::m_trk_nOutliersHits {m_tree.newVector<int>("trk_nOutliersHits")}
private

Definition at line 126 of file MuonSegmentReader.h.

126{m_tree.newVector<int>("trk_nOutliersHits")};

◆ m_trk_nRpcEtaHits

VectorBranch<int>& MuonCalib::MuonSegmentReader::m_trk_nRpcEtaHits {m_tree.newVector<int>("trk_nRpcEtaHits")}
private

Definition at line 128 of file MuonSegmentReader.h.

128{m_tree.newVector<int>("trk_nRpcEtaHits")};

◆ m_trk_nRpcPhiHits

VectorBranch<int>& MuonCalib::MuonSegmentReader::m_trk_nRpcPhiHits {m_tree.newVector<int>("trk_nRpcPhiHits")}
private

Definition at line 127 of file MuonSegmentReader.h.

127{m_tree.newVector<int>("trk_nRpcPhiHits")};

◆ m_trk_nTgcEtaHits

VectorBranch<int>& MuonCalib::MuonSegmentReader::m_trk_nTgcEtaHits {m_tree.newVector<int>("trk_nTgcEtaHits")}
private

Definition at line 130 of file MuonSegmentReader.h.

130{m_tree.newVector<int>("trk_nTgcEtaHits")};

◆ m_trk_nTgcPhiHits

VectorBranch<int>& MuonCalib::MuonSegmentReader::m_trk_nTgcPhiHits {m_tree.newVector<int>("trk_nTgcPhiHits")}
private

Definition at line 129 of file MuonSegmentReader.h.

129{m_tree.newVector<int>("trk_nTgcPhiHits")};

◆ m_trk_nTracks

ScalarBranch<int>& MuonCalib::MuonSegmentReader::m_trk_nTracks {m_tree.newScalar<int>("trk_nTracks")}
private

Definition at line 111 of file MuonSegmentReader.h.

111{m_tree.newScalar<int>("trk_nTracks")};

◆ m_trk_perigee

ThreeVectorBranch MuonCalib::MuonSegmentReader::m_trk_perigee {m_tree,"trk_perigee"}
private

Definition at line 122 of file MuonSegmentReader.h.

122{m_tree,"trk_perigee"} ;

◆ m_trk_phi

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trk_phi {m_tree.newVector<float>("trk_phi")}
private

Definition at line 114 of file MuonSegmentReader.h.

114{m_tree.newVector<float>("trk_phi")};

◆ m_trk_pt

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trk_pt {m_tree.newVector<float>("trk_pt")}
private

Definition at line 118 of file MuonSegmentReader.h.

118{m_tree.newVector<float>("trk_pt")};

◆ m_trk_qOverP

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trk_qOverP {m_tree.newVector<float>("trk_qOverP")}
private

Definition at line 117 of file MuonSegmentReader.h.

117{m_tree.newVector<float>("trk_qOverP")};

◆ m_trk_theta

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trk_theta {m_tree.newVector<float>("trk_theta")}
private

Definition at line 115 of file MuonSegmentReader.h.

115{m_tree.newVector<float>("trk_theta")};

◆ m_trk_z0

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trk_z0 {m_tree.newVector<float>("trk_z0")}
private

Definition at line 113 of file MuonSegmentReader.h.

113{m_tree.newVector<float>("trk_z0")};

◆ m_trkHit_adc

VectorBranch<int>& MuonCalib::MuonSegmentReader::m_trkHit_adc {m_tree.newVector<int>("trkHit_adc")}
private

Definition at line 141 of file MuonSegmentReader.h.

141{m_tree.newVector<int>("trkHit_adc")};

◆ m_trkHit_bkgTime

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trkHit_bkgTime {m_tree.newVector<float>("trkHit_bkgTime")}
private

Definition at line 162 of file MuonSegmentReader.h.

162{m_tree.newVector<float>("trkHit_bkgTime")};

◆ m_trkHit_calibStatus

VectorBranch<int>& MuonCalib::MuonSegmentReader::m_trkHit_calibStatus {m_tree.newVector<int>("trkHit_calibStatus")}
private

Definition at line 164 of file MuonSegmentReader.h.

164{m_tree.newVector<int>("trkHit_calibStatus")};

◆ m_trkHit_center

ThreeVectorBranch MuonCalib::MuonSegmentReader::m_trkHit_center {m_tree,"trkHit_center"}
private

Definition at line 139 of file MuonSegmentReader.h.

139{m_tree,"trkHit_center"};

◆ m_trkHit_closestApproach

ThreeVectorBranch MuonCalib::MuonSegmentReader::m_trkHit_closestApproach {m_tree,"trkHit_closestApproach"}
private

Definition at line 137 of file MuonSegmentReader.h.

137{m_tree,"trkHit_closestApproach"} ;

◆ m_trkHit_distRO

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trkHit_distRO {m_tree.newVector<float>("trkHit_distRO")}
private

Definition at line 151 of file MuonSegmentReader.h.

151{m_tree.newVector<float>("trkHit_distRO")};

◆ m_trkHit_driftRadius

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trkHit_driftRadius {m_tree.newVector<float>("trkHit_driftRadius")}
private

Definition at line 147 of file MuonSegmentReader.h.

147{m_tree.newVector<float>("trkHit_driftRadius")};

◆ m_trkHit_driftTime

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trkHit_driftTime {m_tree.newVector<float>("trkHit_driftTime")}
private

Definition at line 150 of file MuonSegmentReader.h.

150{m_tree.newVector<float>("trkHit_driftTime")};

◆ m_trkHit_error

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trkHit_error {m_tree.newVector<float>("trkHit_error")}
private

Definition at line 148 of file MuonSegmentReader.h.

148{m_tree.newVector<float>("trkHit_error")};

◆ m_trkHit_gClosestApproach

ThreeVectorBranch MuonCalib::MuonSegmentReader::m_trkHit_gClosestApproach {m_tree,"trkHit_gClosestApproach"}
private

Definition at line 138 of file MuonSegmentReader.h.

138{m_tree,"trkHit_gClosestApproach"} ;

◆ m_trkHit_gPos

ThreeVectorBranch MuonCalib::MuonSegmentReader::m_trkHit_gPos {m_tree,"trkHit_gPos"}
private

Definition at line 135 of file MuonSegmentReader.h.

135{m_tree,"trkHit_gPos"} ;

◆ m_trkHit_id

VectorBranch<unsigned int>& MuonCalib::MuonSegmentReader::m_trkHit_id {m_tree.newVector<unsigned int>("trkHit_id")}
private

Definition at line 146 of file MuonSegmentReader.h.

146{m_tree.newVector<unsigned int>("trkHit_id")};

◆ m_trkHit_localAngle

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trkHit_localAngle {m_tree.newVector<float>("trkHit_localAngle")}
private

Definition at line 152 of file MuonSegmentReader.h.

152{m_tree.newVector<float>("trkHit_localAngle")};

◆ m_trkHit_lorTime

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trkHit_lorTime {m_tree.newVector<float>("trkHit_lorTime")}
private

Definition at line 159 of file MuonSegmentReader.h.

159{m_tree.newVector<float>("trkHit_lorTime")};

◆ m_trkHit_nMdtHits

ScalarBranch<int>& MuonCalib::MuonSegmentReader::m_trkHit_nMdtHits {m_tree.newScalar<int>("trkHit_nMdtHits")}
private

Definition at line 133 of file MuonSegmentReader.h.

133{m_tree.newScalar<int>("trkHit_nMdtHits")}; // total MDT track hits

◆ m_trkHit_pos

ThreeVectorBranch MuonCalib::MuonSegmentReader::m_trkHit_pos {m_tree,"trkHit_pos"}
private

Definition at line 136 of file MuonSegmentReader.h.

136{m_tree,"trkHit_pos"} ;

◆ m_trkHit_propTime

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trkHit_propTime {m_tree.newVector<float>("trkHit_propTime")}
private

Definition at line 160 of file MuonSegmentReader.h.

160{m_tree.newVector<float>("trkHit_propTime")};

◆ m_trkHit_pull

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trkHit_pull {m_tree.newVector<float>("trkHit_pull")}
private

Definition at line 145 of file MuonSegmentReader.h.

145{m_tree.newVector<float>("trkHit_pull")};

◆ m_trkHit_resi

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trkHit_resi {m_tree.newVector<float>("trkHit_resi")}
private

Definition at line 144 of file MuonSegmentReader.h.

144{m_tree.newVector<float>("trkHit_resi")};

◆ m_trkHit_rTrk

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trkHit_rTrk {m_tree.newVector<float>("trkHit_rTrk")}
private

Definition at line 149 of file MuonSegmentReader.h.

149{m_tree.newVector<float>("trkHit_rTrk")};

◆ m_trkHit_slewTime

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trkHit_slewTime {m_tree.newVector<float>("trkHit_slewTime")}
private

Definition at line 158 of file MuonSegmentReader.h.

158{m_tree.newVector<float>("trkHit_slewTime")};

◆ m_trkHit_tdc

VectorBranch<int>& MuonCalib::MuonSegmentReader::m_trkHit_tdc {m_tree.newVector<int>("trkHit_tdc")}
private

Definition at line 143 of file MuonSegmentReader.h.

143{m_tree.newVector<int>("trkHit_tdc")};

◆ m_trkHit_tempTime

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trkHit_tempTime {m_tree.newVector<float>("trkHit_tempTime")}
private

Definition at line 161 of file MuonSegmentReader.h.

161{m_tree.newVector<float>("trkHit_tempTime")};

◆ m_trkHit_tof

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trkHit_tof {m_tree.newVector<float>("trkHit_tof")}
private

Definition at line 163 of file MuonSegmentReader.h.

163{m_tree.newVector<float>("trkHit_tof")};

◆ m_trkHit_trackIndex

VectorBranch<int>& MuonCalib::MuonSegmentReader::m_trkHit_trackIndex {m_tree.newVector<int>("trkHit_trackIndex")}
private

Definition at line 134 of file MuonSegmentReader.h.

134{m_tree.newVector<int>("trkHit_trackIndex")};

◆ m_trkHit_triggerTime

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trkHit_triggerTime {m_tree.newVector<float>("trkHit_triggerTime")}
private

Definition at line 156 of file MuonSegmentReader.h.

156{m_tree.newVector<float>("trkHit_triggerTime")};

◆ m_trkHit_tubeMeanAdc

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trkHit_tubeMeanAdc {m_tree.newVector<float>("trkHit_tubeMeanAdc")}
private

Definition at line 157 of file MuonSegmentReader.h.

157{m_tree.newVector<float>("trkHit_tubeMeanAdc")};

◆ m_trkHit_tubeT0

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trkHit_tubeT0 {m_tree.newVector<float>("trkHit_tubeT0")}
private

Definition at line 155 of file MuonSegmentReader.h.

155{m_tree.newVector<float>("trkHit_tubeT0")};

◆ m_trkHit_type

VectorBranch<int>& MuonCalib::MuonSegmentReader::m_trkHit_type {m_tree.newVector<int>("trkHit_type")}
private

Definition at line 142 of file MuonSegmentReader.h.

142{m_tree.newVector<int>("trkHit_type")}; // 1 hits, 4 outliers

◆ m_trkHole_driftRadius

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trkHole_driftRadius {m_tree.newVector<float>("trkHole_driftRadius")}
private

Definition at line 172 of file MuonSegmentReader.h.

172{m_tree.newVector<float>("trkHole_driftRadius")};

◆ m_trkHole_gPos

ThreeVectorBranch MuonCalib::MuonSegmentReader::m_trkHole_gPos {m_tree,"trkHole_gPos"}
private

Definition at line 170 of file MuonSegmentReader.h.

170{m_tree,"trkHole_gPos"} ;

◆ m_trkHole_id

VectorBranch<unsigned int>& MuonCalib::MuonSegmentReader::m_trkHole_id {m_tree.newVector<unsigned int>("trkHole_id")}
private

Definition at line 171 of file MuonSegmentReader.h.

171{m_tree.newVector<unsigned int>("trkHole_id")};

◆ m_trkHole_nHoles

ScalarBranch<int>& MuonCalib::MuonSegmentReader::m_trkHole_nHoles {m_tree.newScalar<int>("trkHole_nHoles")}
private

Definition at line 167 of file MuonSegmentReader.h.

167{m_tree.newScalar<int>("trkHole_nHoles")}; // total holes

◆ m_trkHole_trackIndex

VectorBranch<int>& MuonCalib::MuonSegmentReader::m_trkHole_trackIndex {m_tree.newVector<int>("trkHole_trackIndex")}
private

Definition at line 168 of file MuonSegmentReader.h.

168{m_tree.newVector<int>("trkHole_trackIndex")};

◆ m_trkHole_type

VectorBranch<int>& MuonCalib::MuonSegmentReader::m_trkHole_type {m_tree.newVector<int>("trkHole_type")}
private

Definition at line 169 of file MuonSegmentReader.h.

169{m_tree.newVector<int>("trkHole_type")}; // 1 MDT, 2 RPC, 3 TGC

◆ m_TrkKey

SG::ReadHandleKey<TrackCollection> MuonCalib::MuonSegmentReader::m_TrkKey {this, "MuonTrackLocations", "MuonSpectrometerTracks"}
private

Definition at line 57 of file MuonSegmentReader.h.

57{this, "MuonTrackLocations", "MuonSpectrometerTracks"};

◆ m_trkTriggerHit_gPos

ThreeVectorBranch MuonCalib::MuonSegmentReader::m_trkTriggerHit_gPos {m_tree,"trkTriggerHit_gPos"}
private

Definition at line 178 of file MuonSegmentReader.h.

178{m_tree,"trkTriggerHit_gPos"} ;

◆ m_trkTriggerHit_id

VectorBranch<unsigned int>& MuonCalib::MuonSegmentReader::m_trkTriggerHit_id {m_tree.newVector<unsigned int>("trkTriggerHit_id")}
private

Definition at line 179 of file MuonSegmentReader.h.

179{m_tree.newVector<unsigned int>("trkTriggerHit_id")};

◆ m_trkTriggerHit_nHits

ScalarBranch<int>& MuonCalib::MuonSegmentReader::m_trkTriggerHit_nHits {m_tree.newScalar<int>("trkTriggerHit_nHits")}
private

Definition at line 175 of file MuonSegmentReader.h.

175{m_tree.newScalar<int>("trkTriggerHit_nHits")}; // total trigger hits

◆ m_trkTriggerHit_time

VectorBranch<float>& MuonCalib::MuonSegmentReader::m_trkTriggerHit_time {m_tree.newVector<float>("trkTriggerHit_time")}
private

Definition at line 180 of file MuonSegmentReader.h.

180{m_tree.newVector<float>("trkTriggerHit_time")}; // time for RPC and bcBitMap for TGC

◆ m_trkTriggerHit_trackIndex

VectorBranch<int>& MuonCalib::MuonSegmentReader::m_trkTriggerHit_trackIndex {m_tree.newVector<int>("trkTriggerHit_trackIndex")}
private

Definition at line 176 of file MuonSegmentReader.h.

176{m_tree.newVector<int>("trkTriggerHit_trackIndex")};

◆ m_trkTriggerHit_type

VectorBranch<int>& MuonCalib::MuonSegmentReader::m_trkTriggerHit_type {m_tree.newVector<int>("trkTriggerHit_type")}
private

Definition at line 177 of file MuonSegmentReader.h.

177{m_tree.newVector<int>("trkTriggerHit_type")}; // 0 unknown, 1 RPC rot, 2 RPC crot, 3 TGC rot, 4 TGC strip, 5 TGC wire

◆ m_varHandleArraysDeclared

bool AthCommonDataStore< AthCommonMsg< Algorithm > >::m_varHandleArraysDeclared
privateinherited

Definition at line 399 of file AthCommonDataStore.h.

◆ m_vhka

std::vector<SG::VarHandleKeyArray*> AthCommonDataStore< AthCommonMsg< Algorithm > >::m_vhka
privateinherited

Definition at line 398 of file AthCommonDataStore.h.


The documentation for this class was generated from the following files: