ATLAS Offline Software
Loading...
Searching...
No Matches
MuonPRDTest::MMSimHitVariables Class Reference

#include <MMSimHitVariables.h>

Inheritance diagram for MuonPRDTest::MMSimHitVariables:
Collaboration diagram for MuonPRDTest::MMSimHitVariables:

Public Types

using DataDependency = SG::VarHandleKey*

Public Member Functions

 MMSimHitVariables (MuonTesterTree &tree, const std::string &container_name, MSG::Level msglvl)
bool fill (const EventContext &ctx) override final
 The fill method checks if enough information is provided such that the branch is cleared from the information of the prevoius event and in cases of that updates did no happen befure a default value is provided.
bool declare_keys () override final
bool init () override final
 The init method checks whether the branch name has already registered to the MuonTree and tries then to add the branch to the tree --> return false if the branch has already been defined or the inclusion of the branch to the tree failed or the name of the branch is empty.
std::string name () const override final
 Returns the name of the branch.
bool initialized () const
 Returns whether the object has been initialized or not The outcome of the variable is bound to a successful call of the addToTree method.
TTree * tree () override final
 Returns the underlying TTree object.
const TTree * tree () const override final
std::vector< DataDependencydata_dependencies () override final
 Returns the data dependencies needed by the MuonTesterBranch.
bool msgLvl (const MSG::Level lvl) const
 Test the output level.
MsgStream & msg () const
 The standard message stream.
MsgStream & msg (const MSG::Level lvl) const
 The standard message stream.
void setLevel (MSG::Level lvl)
 Change the current logging level.

Static Public Member Functions

static std::string eraseWhiteSpaces (const std::string &In)

Protected Member Functions

const Muon::IMuonIdHelperSvcidHelperSvc () const
const MuonGM::MuonDetectorManagergetDetMgr (const EventContext &ctx) const
template<class T>
bool addToTree (T &variable)
 Connects the Memory buffer with the TTree.
template<class Key>
bool declare_dependency (Key &key)
 Declares the ReadHandle/ ReadCondHandleKey as data dependency of the algorithm.
MuonTesterTreeparent ()
 Returns the reference to the MuonTesterTree parent.

Private Member Functions

void initMessaging () const
 Initialize our message level and MessageSvc.

Private Attributes

SG::ReadHandleKey< MMSimHitCollectionm_key {}
ThreeVectorBranch m_NSWMM_hitGlobalPosition {parent(), "Hits_MM_GlobalPosition"}
ThreeVectorBranch m_NSWMM_hitGlobalDirection {parent(), "Hits_MM_GlobalDirection"}
VectorBranch< int > & m_NSWMM_particleEncoding {parent().newVector<int>("Hits_MM_particleEncoding")}
VectorBranch< float > & m_NSWMM_kineticEnergy {parent().newVector<float>("Hits_MM_kineticEnergy")}
VectorBranch< float > & m_NSWMM_depositEnergy {parent().newVector<float>("Hits_MM_depositEnergy")}
VectorBranch< bool > & m_NSWMM_isInsideBounds {parent().newVector<bool>("Hits_MM_isInsideBounds")}
VectorBranch< int > & m_NSWMM_trackId {parent().newVector<int>("Hits_MM_trackId")}
ScalarBranch< unsigned int > & m_NSWMM_nSimHits {parent().newScalar<unsigned int>("Hits_MM_nHits")}
MmIdentifierBranch m_NSWMM_Id {parent(), "Hits_MM_off"}
VectorBranch< float > & m_NSWMM_globalTime {parent().newVector<float>("Hits_MM_globalTime")}
ThreeVectorBranch m_NSWMM_detector_globalPosition {parent(), "Hits_MM_detector_globalPosition"}
ThreeVectorBranch m_NSWMM_hitToDsurfacePosition {parent(), "Hits_MM_hitToDsurfacePosition"}
ThreeVectorBranch m_NSWMM_hitToRsurfacePosition {parent(), "Hits_MM_hitToRsurfacePosition"}
VectorBranch< float > & m_NSWMM_FastDigitRsurfacePositionX {parent().newVector<float>("Hits_MM_FastDigitRsurfacePositionX")}
VectorBranch< float > & m_NSWMM_FastDigitRsurfacePositionY {parent().newVector<float>("Hits_MM_FastDigitRsurfacePositionY")}
SG::ReadCondHandleKey< MuonGM::MuonDetectorManagerm_detMgrKey {"MuonDetectorManager"}
ServiceHandle< Muon::IMuonIdHelperSvcm_idHelperSvc {"Muon::MuonIdHelperSvc/MuonIdHelperSvc", name()}
TTree * m_tree {nullptr}
MuonTesterTreem_parent {nullptr}
std::string m_name {}
bool m_init {false}
std::vector< DataDependencym_dependencies {}
std::string m_nm
 Message source name.
boost::thread_specific_ptr< MsgStream > m_msg_tls
 MsgStream instance (a std::cout like with print-out levels)
std::atomic< IMessageSvc * > m_imsg { nullptr }
 MessageSvc pointer.
std::atomic< MSG::Level > m_lvl { MSG::NIL }
 Current logging level.
std::atomic_flag m_initialized ATLAS_THREAD_SAFE = ATOMIC_FLAG_INIT
 Messaging initialized (initMessaging)

Detailed Description

Definition at line 13 of file MMSimHitVariables.h.

Member Typedef Documentation

◆ DataDependency

Constructor & Destructor Documentation

◆ MMSimHitVariables()

MuonPRDTest::MMSimHitVariables::MMSimHitVariables ( MuonTesterTree & tree,
const std::string & container_name,
MSG::Level msglvl )

Definition at line 10 of file MMSimHitVariables.cxx.

10 :
11 PrdTesterModule(tree, "MM_Sim", msglvl), m_key{container_name} {}
SG::ReadHandleKey< MMSimHitCollection > m_key
PrdTesterModule(MuonTesterTree &tree, const std::string &grp_name, MSG::Level msglvl)
virtual TTree * tree()=0
Returns the pointer to the underlying TTree object.

Member Function Documentation

◆ addToTree()

template<class T>
bool MuonVal::MuonTesterBranch::addToTree ( T & variable)
protectedinherited

Connects the Memory buffer with the TTree.

◆ data_dependencies()

std::vector< MuonTesterBranch::DataDependency > MuonVal::MuonTesterBranch::data_dependencies ( )
finaloverridevirtualinherited

Returns the data dependencies needed by the MuonTesterBranch.

Implements MuonVal::IMuonTesterBranch.

Definition at line 61 of file MuonTesterBranch.cxx.

61{ return m_dependencies;}
std::vector< DataDependency > m_dependencies

◆ declare_dependency()

template<class Key>
bool MuonVal::MuonTesterBranch::declare_dependency ( Key & key)
protectedinherited

Declares the ReadHandle/ ReadCondHandleKey as data dependency of the algorithm.

◆ declare_keys()

bool MuonPRDTest::MMSimHitVariables::declare_keys ( )
finaloverridevirtual

Implements MuonPRDTest::PrdTesterModule.

Definition at line 13 of file MMSimHitVariables.cxx.

13{ return declare_dependency(m_key); }
bool declare_dependency(Key &key)
Declares the ReadHandle/ ReadCondHandleKey as data dependency of the algorithm.

◆ eraseWhiteSpaces()

std::string MuonVal::MuonTesterBranch::eraseWhiteSpaces ( const std::string & In)
staticinherited

Definition at line 56 of file MuonTesterBranch.cxx.

56 {
57 std::string out = In;
58 out.erase(std::remove_if(out.begin(), out.end(), isspace), out.end());
59 return out;
60}
DataModel_detail::iterator< DVL > remove_if(typename DataModel_detail::iterator< DVL > beg, typename DataModel_detail::iterator< DVL > end, Predicate pred)
Specialization of remove_if for DataVector/List.

◆ fill()

bool MuonPRDTest::MMSimHitVariables::fill ( const EventContext & ctx)
finaloverridevirtual

The fill method checks if enough information is provided such that the branch is cleared from the information of the prevoius event and in cases of that updates did no happen befure a default value is provided.

--> returns false if no update is called or the dummy value has not been defined

Implements MuonVal::IMuonTesterBranch.

Definition at line 15 of file MMSimHitVariables.cxx.

15 {
16 ATH_MSG_DEBUG("do fill MmSimHitVariables()");
17 SG::ReadHandle<MMSimHitCollection> mmContainer{m_key, ctx};
18 if (!mmContainer.isValid()) {
19 ATH_MSG_FATAL("Failed to retrieve digit container " << m_key.fullKey());
20 return false;
21 }
22 const MuonGM::MuonDetectorManager* MuonDetMgr = getDetMgr(ctx);
23 if (!MuonDetMgr) { return false; }
24 unsigned int n_hits{0};
25 // Get the MM Id hit helper
26 const MicromegasHitIdHelper* mmhhelper = MicromegasHitIdHelper::GetHelper();
27 if (!mmContainer->size()) ATH_MSG_DEBUG("MM Sim container is empty");
28 for (const MMSimHit& hit : *mmContainer) {
29 int simId = hit.MMId();
30
31 if(hit.depositEnergy()==0.) continue; // SimHits without energy loss are not recorded.
32
33 // connect the hit with the MC truth
34 int barcode = hit.particleLink().barcode();
35 m_NSWMM_trackId.push_back(barcode);
36 m_NSWMM_globalTime.push_back(hit.globalTime());
37
38 const Amg::Vector3D& globalPosition = hit.globalPosition();
39 m_NSWMM_hitGlobalPosition.push_back(globalPosition);
40
41 const Amg::Vector3D& globalDirection = hit.globalDirection();
42 m_NSWMM_hitGlobalDirection.push_back(globalDirection);
43
44 m_NSWMM_particleEncoding.push_back(hit.particleEncoding());
45 m_NSWMM_kineticEnergy.push_back(hit.kineticEnergy());
46 m_NSWMM_depositEnergy.push_back(hit.depositEnergy());
47
48 std::string stname = mmhhelper->GetStationName(simId);
49 int steta = mmhhelper->GetZSector(simId);
50 int stphi = mmhhelper->GetPhiSector(simId);
51 int multilayer = mmhhelper->GetMultiLayer(simId);
52 int layer = mmhhelper->GetLayer(simId);
53 int side = mmhhelper->GetSide(simId);
54
55 if( stphi == 0 ){
56 ATH_MSG_ERROR("MicroMegas validation: unexpected phi range " << stphi);
57 return false;
58 }
59
60 Identifier offId = idHelperSvc()->mmIdHelper().channelID( stname[2] == 'L' ? "MML" : "MMS",
61 side == 1 ? steta+1 : -steta-1,
62 (stphi-1)/2+1,multilayer,layer,1 );
63 m_NSWMM_Id.push_back(offId);
64
65 // sanity checks
66 if( !idHelperSvc()->mmIdHelper().is_mm(offId) ){
67 ATH_MSG_WARNING("MM id is not a mm id! " << idHelperSvc()->mmIdHelper().print_to_string(offId));
68 }
69 if( !idHelperSvc()->mmIdHelper().is_muon(offId) ){
70 ATH_MSG_WARNING("MM id is not a muon id! " << idHelperSvc()->mmIdHelper().print_to_string(offId));
71 }
72 if( idHelperSvc()->mmIdHelper().is_mdt(offId)||idHelperSvc()->mmIdHelper().is_rpc(offId)||idHelperSvc()->mmIdHelper().is_tgc(offId)||idHelperSvc()->mmIdHelper().is_csc(offId)||idHelperSvc()->mmIdHelper().is_stgc(offId) ){
73 ATH_MSG_WARNING("MM id has wrong technology type! " << idHelperSvc()->mmIdHelper().is_mdt(offId) << " " << idHelperSvc()->mmIdHelper().is_rpc(offId)
74 << " " << idHelperSvc()->mmIdHelper().is_tgc(offId) << " " << idHelperSvc()->mmIdHelper().is_csc(offId) << " " << idHelperSvc()->mmIdHelper().is_stgc(offId) );
75 }
76 if( idHelperSvc()->mmIdHelper().gasGap(offId) != layer ) {
77 ATH_MSG_WARNING("MM id has bad layer field! " << idHelperSvc()->mmIdHelper().print_to_string(offId) );
78 }
79
80 int isSmall = stname[2] == 'S';
81 ATH_MSG_DEBUG("MicroMegas geometry, retrieving detector element for: isSmall " << isSmall << " eta " << idHelperSvc()->mmIdHelper().stationEta(offId)
82 << " phi " << idHelperSvc()->mmIdHelper().stationPhi(offId) << " ml " << idHelperSvc()->mmIdHelper().multilayer(offId) );
83
84 const MuonGM::MMReadoutElement* detEl = MuonDetMgr->getMMReadoutElement(offId);
85 if (!detEl) {
86 ATH_MSG_ERROR("MMSimHitVariables::fillVariables() - Failed to retrieve MMReadoutElement for "<<idHelperSvc()->mmIdHelper().print_to_string(offId).c_str());
87 return false;
88 }
89
90 // surface
91 const Trk::PlaneSurface& surf = detEl->surface(offId);
92 // compute hit position within the detector element/surfaces
93 Amg::Transform3D gToL = detEl->absTransform().inverse();
94 Amg::Vector3D hpos(hit.globalPosition().x(),hit.globalPosition().y(),hit.globalPosition().z());
95 Amg::Vector3D dSurface_pos = gToL*hpos;
96
97 // compute the hit position on the readout plane (same as in MuonFastDigitization)
98 Amg::Vector3D rSurface_pos = surf.transform().inverse()*hpos;
99
100 Amg::Vector2D posOnSurfUnProjected(rSurface_pos.x(),rSurface_pos.y());
101
102 // check where the readout plane is located and compute the local direction accordingly
103 Amg::Vector3D ldir(0., 0., 0.);
104 ldir = surf.transform().inverse().linear()*Amg::Vector3D(hit.globalDirection().x(), hit.globalDirection().y(), hit.globalDirection().z());
105
106 double scale, scaletop;
107 double gasgap = 5.;
108
109 scale = -rSurface_pos.z()/ldir.z();
110 scaletop = (gasgap+rSurface_pos.z())/ldir.z();
111
112 Amg::Vector3D hitOnSurface = rSurface_pos + scale*ldir;
113 Amg::Vector3D hitOnTopSurface = rSurface_pos + scaletop*ldir;
114 Amg::Vector2D posOnSurf (hitOnSurface.x(), hitOnSurface.y());
115 Amg::Vector2D posOnTopSurf (hitOnTopSurface.x(),hitOnTopSurface.y());
116
117
118 int stripNumber = detEl->stripNumber(posOnSurf,offId);
119
120 // perform bound check (making the call from the detector element to consider edge passivation)
121 m_NSWMM_isInsideBounds.push_back( detEl->insideActiveBounds(offId, posOnSurf) );
122
123 if( stripNumber == -1 ){
124 ATH_MSG_WARNING("MicroMegas validation: failed to obtain strip number " << idHelperSvc()->mmIdHelper().print_to_string(offId) );
125 ATH_MSG_WARNING(" pos " << posOnSurf << " z " << rSurface_pos.z() );
126 stripNumber = 1;
127 }
128
129 Identifier oldId = offId;
130 offId = idHelperSvc()->mmIdHelper().channelID(offId, idHelperSvc()->mmIdHelper().multilayer(offId), idHelperSvc()->mmIdHelper().gasGap(offId),stripNumber);
131 if( idHelperSvc()->mmIdHelper().gasGap(offId) != layer ) {
132 ATH_MSG_WARNING("MicroMegas validation: MM id has bad layer field(2)! " << std::endl << " " << idHelperSvc()->mmIdHelper().print_to_string(offId) << std::endl
133 << " " << idHelperSvc()->mmIdHelper().print_to_string(oldId) << " stripN " << stripNumber );
134 }
135
136 Amg::Vector2D fastDigitPos(0.,0.);
137 if( !detEl->stripPosition(offId,fastDigitPos ) ){
138 ATH_MSG_WARNING("MicroMegas validation: failed to obtain local position for identifier " << idHelperSvc()->mmIdHelper().print_to_string(offId) );
139 }
140
141 Amg::Vector3D detpos = detEl->globalPosition();
142 ATH_MSG_DEBUG("Global hit : r " << hit.globalPosition().perp() << ", phi " << hit.globalPosition().phi() << ", z " << hit.globalPosition().z()
143 << "; detEl: r " << detpos.perp() << ", phi " << detpos.phi() << ", z " << detpos.z()
144 << "; surf z " << surf.center().z() << ", ml " << multilayer << ", l " << layer );
145 ATH_MSG_DEBUG(" detEl: x " << dSurface_pos.x() << " y " << dSurface_pos.y() << " z " << dSurface_pos.z());
146 ATH_MSG_DEBUG("MM Fast digit: x " << fastDigitPos.x() << " y " << fastDigitPos.y()
147 << ", gToL: x " << rSurface_pos.x() << " y " << rSurface_pos.y() << " z " << rSurface_pos.z() );
148
149 // Fill ntuple with the hit/surface/digit positions
150 m_NSWMM_detector_globalPosition.push_back(detpos);
151 m_NSWMM_hitToDsurfacePosition.push_back(dSurface_pos);
152 m_NSWMM_hitToRsurfacePosition.push_back(rSurface_pos);
153
154 m_NSWMM_FastDigitRsurfacePositionX.push_back( posOnSurf.x() );
155 m_NSWMM_FastDigitRsurfacePositionY.push_back( posOnSurf.y() );
156
157 ++n_hits;
158 }
159 m_NSWMM_nSimHits = n_hits;
160
161 ATH_MSG_DEBUG("processed " << m_NSWMM_nSimHits << " MM hits");
162 return true;
163 }
#define ATH_MSG_ERROR(x)
#define ATH_MSG_FATAL(x)
#define ATH_MSG_WARNING(x)
#define ATH_MSG_DEBUG(x)
int GetLayer(const int &hid) const
static const MicromegasHitIdHelper * GetHelper()
int GetSide(const int &hid) const
int GetPhiSector(const int &hid) const
int GetMultiLayer(const int &hid) const
int GetZSector(const int &hid) const
std::string GetStationName(const int &hid) const
Identifier channelID(int stationName, int stationEta, int stationPhi, int multilayer, int gasGap, int channel) const
virtual bool stripPosition(const Identifier &id, Amg::Vector2D &pos) const override final
strip position – local or global If the strip number is outside the range of valid strips,...
bool insideActiveBounds(const Identifier &id, const Amg::Vector2D &locpos, double tol1=0., double tol2=0.) const
boundary check Wrapper Trk::PlaneSurface::insideBounds() taking into account the passivated width
virtual int stripNumber(const Amg::Vector2D &pos, const Identifier &id) const override final
strip number corresponding to local position.
virtual const Trk::PlaneSurface & surface() const override
access to chamber surface (phi orientation), uses the first gas gap
const MMReadoutElement * getMMReadoutElement(const Identifier &id) const
access via extended identifier (requires unpacking)
ThreeVectorBranch m_NSWMM_hitGlobalPosition
ScalarBranch< unsigned int > & m_NSWMM_nSimHits
VectorBranch< float > & m_NSWMM_globalTime
VectorBranch< int > & m_NSWMM_trackId
VectorBranch< float > & m_NSWMM_depositEnergy
ThreeVectorBranch m_NSWMM_hitToDsurfacePosition
VectorBranch< float > & m_NSWMM_FastDigitRsurfacePositionY
VectorBranch< int > & m_NSWMM_particleEncoding
VectorBranch< float > & m_NSWMM_FastDigitRsurfacePositionX
VectorBranch< float > & m_NSWMM_kineticEnergy
VectorBranch< bool > & m_NSWMM_isInsideBounds
ThreeVectorBranch m_NSWMM_detector_globalPosition
ThreeVectorBranch m_NSWMM_hitGlobalDirection
ThreeVectorBranch m_NSWMM_hitToRsurfacePosition
const MuonGM::MuonDetectorManager * getDetMgr(const EventContext &ctx) const
const Muon::IMuonIdHelperSvc * idHelperSvc() const
virtual const MmIdHelper & mmIdHelper() const =0
access to CscIdHelper
virtual bool isValid() override final
Can the handle be successfully dereferenced?
const Amg::Transform3D & transform() const
Returns HepGeom::Transform3D by reference.
const Amg::Vector3D & center() const
Returns the center position of the Surface.
Eigen::Affine3d Transform3D
Eigen::Matrix< double, 2, 1 > Vector2D
Eigen::Matrix< double, 3, 1 > Vector3D
int barcode(const T *p)
Definition Barcode.h:16
bool isSmall(const ChIndex index)
Returns true if the chamber index is in a small sector.
constexpr uint8_t stationPhi
station Phi 1 to 8
@ layer
Definition HitInfo.h:79

◆ getDetMgr()

const MuonGM::MuonDetectorManager * MuonPRDTest::PrdTesterModule::getDetMgr ( const EventContext & ctx) const
protectedinherited

Definition at line 16 of file PrdTesterModule.cxx.

16 {
17 SG::ReadCondHandle handle{m_detMgrKey, ctx};
18 if (!handle.isValid()) {
19 ATH_MSG_ERROR("Failed to retrieve MuonDetectorManager " << m_detMgrKey.fullKey());
20 return nullptr;
21 }
22 return handle.cptr();
23 }
SG::ReadCondHandleKey< MuonGM::MuonDetectorManager > m_detMgrKey
const_pointer_type cptr()

◆ idHelperSvc()

const Muon::IMuonIdHelperSvc * MuonPRDTest::PrdTesterModule::idHelperSvc ( ) const
protectedinherited

Definition at line 15 of file PrdTesterModule.cxx.

15{ return m_idHelperSvc.get(); }
ServiceHandle< Muon::IMuonIdHelperSvc > m_idHelperSvc

◆ init()

bool MuonPRDTest::PrdTesterModule::init ( )
finaloverridevirtualinherited

The init method checks whether the branch name has already registered to the MuonTree and tries then to add the branch to the tree --> return false if the branch has already been defined or the inclusion of the branch to the tree failed or the name of the branch is empty.

Implements MuonVal::IMuonTesterBranch.

Definition at line 24 of file PrdTesterModule.cxx.

24 {
26 m_idHelperSvc.retrieve().isSuccess() && declare_keys();
27 }

◆ initialized()

bool MuonVal::MuonTesterBranch::initialized ( ) const
inherited

Returns whether the object has been initialized or not The outcome of the variable is bound to a successful call of the addToTree method.

Definition at line 52 of file MuonTesterBranch.cxx.

◆ initMessaging()

void AthMessaging::initMessaging ( ) const
privateinherited

Initialize our message level and MessageSvc.

This method should only be called once.

Definition at line 39 of file AthMessaging.cxx.

40{
42 // If user did not set an explicit level, set a default
43 if (m_lvl == MSG::NIL) {
44 m_lvl = m_imsg ?
45 static_cast<MSG::Level>( m_imsg.load()->outputLevel(m_nm) ) :
46 MSG::INFO;
47 }
48}
std::string m_nm
Message source name.
std::atomic< IMessageSvc * > m_imsg
MessageSvc pointer.
std::atomic< MSG::Level > m_lvl
Current logging level.
IMessageSvc * getMessageSvc(bool quiet=false)

◆ msg() [1/2]

MsgStream & AthMessaging::msg ( ) const
inlineinherited

The standard message stream.

Returns a reference to the default message stream May not be invoked before sysInitialize() has been invoked.

Definition at line 163 of file AthMessaging.h.

164{
165 MsgStream* ms = m_msg_tls.get();
166 if (!ms) {
167 if (!m_initialized.test_and_set()) initMessaging();
168 ms = new MsgStream(m_imsg,m_nm);
169 m_msg_tls.reset( ms );
170 }
171
172 ms->setLevel (m_lvl);
173 return *ms;
174}
boost::thread_specific_ptr< MsgStream > m_msg_tls
MsgStream instance (a std::cout like with print-out levels)
void initMessaging() const
Initialize our message level and MessageSvc.

◆ msg() [2/2]

MsgStream & AthMessaging::msg ( const MSG::Level lvl) const
inlineinherited

The standard message stream.

Returns a reference to the default message stream May not be invoked before sysInitialize() has been invoked.

Definition at line 178 of file AthMessaging.h.

179{ return msg() << lvl; }
MsgStream & msg() const
The standard message stream.

◆ msgLvl()

bool AthMessaging::msgLvl ( const MSG::Level lvl) const
inlineinherited

Test the output level.

Parameters
lvlThe message level to test against
Returns
boolean Indicating if messages at given level will be printed
Return values
trueMessages at level "lvl" will be printed

Definition at line 151 of file AthMessaging.h.

152{
153 if (m_lvl <= lvl) {
154 msg() << lvl;
155 return true;
156 } else {
157 return false;
158 }
159}

◆ name()

std::string MuonVal::MuonTesterBranch::name ( ) const
finaloverridevirtualinherited

Returns the name of the branch.

Implements MuonVal::IMuonTesterBranch.

Definition at line 51 of file MuonTesterBranch.cxx.

51{ return m_name; }

◆ parent()

MuonTesterTree & MuonVal::MuonTesterBranch::parent ( )
protectedinherited

Returns the reference to the MuonTesterTree parent.

Definition at line 38 of file MuonTesterBranch.cxx.

38 {
39 if (!m_parent) {
40 ATH_MSG_WARNING("The parent of " << name() << " is null.");
41 }
42 return *m_parent;
43}
std::string name() const override final
Returns the name of the branch.

◆ setLevel()

void AthMessaging::setLevel ( MSG::Level lvl)
inherited

Change the current logging level.

Use this rather than msg().setLevel() for proper operation with MT.

Definition at line 28 of file AthMessaging.cxx.

29{
30 m_lvl = lvl;
31}

◆ tree() [1/2]

const TTree * MuonVal::MuonTesterBranch::tree ( ) const
finaloverridevirtualinherited

Implements MuonVal::IMuonTesterBranch.

Definition at line 54 of file MuonTesterBranch.cxx.

54{ return m_tree; }

◆ tree() [2/2]

TTree * MuonVal::MuonTesterBranch::tree ( )
finaloverridevirtualinherited

Returns the underlying TTree object.

Implements MuonVal::IMuonTesterBranch.

Definition at line 53 of file MuonTesterBranch.cxx.

53{ return m_tree; }

Member Data Documentation

◆ ATLAS_THREAD_SAFE

std::atomic_flag m_initialized AthMessaging::ATLAS_THREAD_SAFE = ATOMIC_FLAG_INIT
mutableprivateinherited

Messaging initialized (initMessaging)

Definition at line 141 of file AthMessaging.h.

◆ m_dependencies

std::vector<DataDependency> MuonVal::MuonTesterBranch::m_dependencies {}
privateinherited

Definition at line 62 of file MuonTesterBranch.h.

62{};

◆ m_detMgrKey

SG::ReadCondHandleKey<MuonGM::MuonDetectorManager> MuonPRDTest::PrdTesterModule::m_detMgrKey {"MuonDetectorManager"}
privateinherited

Definition at line 29 of file PrdTesterModule.h.

29{"MuonDetectorManager"};

◆ m_idHelperSvc

ServiceHandle<Muon::IMuonIdHelperSvc> MuonPRDTest::PrdTesterModule::m_idHelperSvc {"Muon::MuonIdHelperSvc/MuonIdHelperSvc", name()}
privateinherited

Definition at line 30 of file PrdTesterModule.h.

30{"Muon::MuonIdHelperSvc/MuonIdHelperSvc", name()};

◆ m_imsg

std::atomic<IMessageSvc*> AthMessaging::m_imsg { nullptr }
mutableprivateinherited

MessageSvc pointer.

Definition at line 135 of file AthMessaging.h.

135{ nullptr };

◆ m_init

bool MuonVal::MuonTesterBranch::m_init {false}
privateinherited

Definition at line 61 of file MuonTesterBranch.h.

61{false};

◆ m_key

SG::ReadHandleKey<MMSimHitCollection> MuonPRDTest::MMSimHitVariables::m_key {}
private

Definition at line 21 of file MMSimHitVariables.h.

21{};

◆ m_lvl

std::atomic<MSG::Level> AthMessaging::m_lvl { MSG::NIL }
mutableprivateinherited

Current logging level.

Definition at line 138 of file AthMessaging.h.

138{ MSG::NIL };

◆ m_msg_tls

boost::thread_specific_ptr<MsgStream> AthMessaging::m_msg_tls
mutableprivateinherited

MsgStream instance (a std::cout like with print-out levels)

Definition at line 132 of file AthMessaging.h.

◆ m_name

std::string MuonVal::MuonTesterBranch::m_name {}
privateinherited

Definition at line 60 of file MuonTesterBranch.h.

60{};

◆ m_nm

std::string AthMessaging::m_nm
privateinherited

Message source name.

Definition at line 129 of file AthMessaging.h.

◆ m_NSWMM_depositEnergy

VectorBranch<float>& MuonPRDTest::MMSimHitVariables::m_NSWMM_depositEnergy {parent().newVector<float>("Hits_MM_depositEnergy")}
private

Definition at line 26 of file MMSimHitVariables.h.

26{parent().newVector<float>("Hits_MM_depositEnergy")};
MuonTesterTree & parent()
Returns the reference to the MuonTesterTree parent.
VectorBranch< T > & newVector(const std::string &name)
Creates new branches and returns their reference.

◆ m_NSWMM_detector_globalPosition

ThreeVectorBranch MuonPRDTest::MMSimHitVariables::m_NSWMM_detector_globalPosition {parent(), "Hits_MM_detector_globalPosition"}
private

Definition at line 32 of file MMSimHitVariables.h.

32{parent(), "Hits_MM_detector_globalPosition"};

◆ m_NSWMM_FastDigitRsurfacePositionX

VectorBranch<float>& MuonPRDTest::MMSimHitVariables::m_NSWMM_FastDigitRsurfacePositionX {parent().newVector<float>("Hits_MM_FastDigitRsurfacePositionX")}
private

Definition at line 35 of file MMSimHitVariables.h.

35{parent().newVector<float>("Hits_MM_FastDigitRsurfacePositionX")};

◆ m_NSWMM_FastDigitRsurfacePositionY

VectorBranch<float>& MuonPRDTest::MMSimHitVariables::m_NSWMM_FastDigitRsurfacePositionY {parent().newVector<float>("Hits_MM_FastDigitRsurfacePositionY")}
private

Definition at line 36 of file MMSimHitVariables.h.

36{parent().newVector<float>("Hits_MM_FastDigitRsurfacePositionY")};

◆ m_NSWMM_globalTime

VectorBranch<float>& MuonPRDTest::MMSimHitVariables::m_NSWMM_globalTime {parent().newVector<float>("Hits_MM_globalTime")}
private

Definition at line 31 of file MMSimHitVariables.h.

31{parent().newVector<float>("Hits_MM_globalTime")};

◆ m_NSWMM_hitGlobalDirection

ThreeVectorBranch MuonPRDTest::MMSimHitVariables::m_NSWMM_hitGlobalDirection {parent(), "Hits_MM_GlobalDirection"}
private

Definition at line 23 of file MMSimHitVariables.h.

23{parent(), "Hits_MM_GlobalDirection"};

◆ m_NSWMM_hitGlobalPosition

ThreeVectorBranch MuonPRDTest::MMSimHitVariables::m_NSWMM_hitGlobalPosition {parent(), "Hits_MM_GlobalPosition"}
private

Definition at line 22 of file MMSimHitVariables.h.

22{parent(), "Hits_MM_GlobalPosition"};

◆ m_NSWMM_hitToDsurfacePosition

ThreeVectorBranch MuonPRDTest::MMSimHitVariables::m_NSWMM_hitToDsurfacePosition {parent(), "Hits_MM_hitToDsurfacePosition"}
private

Definition at line 33 of file MMSimHitVariables.h.

33{parent(), "Hits_MM_hitToDsurfacePosition"};

◆ m_NSWMM_hitToRsurfacePosition

ThreeVectorBranch MuonPRDTest::MMSimHitVariables::m_NSWMM_hitToRsurfacePosition {parent(), "Hits_MM_hitToRsurfacePosition"}
private

Definition at line 34 of file MMSimHitVariables.h.

34{parent(), "Hits_MM_hitToRsurfacePosition"};

◆ m_NSWMM_Id

MmIdentifierBranch MuonPRDTest::MMSimHitVariables::m_NSWMM_Id {parent(), "Hits_MM_off"}
private

Definition at line 30 of file MMSimHitVariables.h.

30{parent(), "Hits_MM_off"};

◆ m_NSWMM_isInsideBounds

VectorBranch<bool>& MuonPRDTest::MMSimHitVariables::m_NSWMM_isInsideBounds {parent().newVector<bool>("Hits_MM_isInsideBounds")}
private

Definition at line 27 of file MMSimHitVariables.h.

27{parent().newVector<bool>("Hits_MM_isInsideBounds")};

◆ m_NSWMM_kineticEnergy

VectorBranch<float>& MuonPRDTest::MMSimHitVariables::m_NSWMM_kineticEnergy {parent().newVector<float>("Hits_MM_kineticEnergy")}
private

Definition at line 25 of file MMSimHitVariables.h.

25{parent().newVector<float>("Hits_MM_kineticEnergy")};

◆ m_NSWMM_nSimHits

ScalarBranch<unsigned int>& MuonPRDTest::MMSimHitVariables::m_NSWMM_nSimHits {parent().newScalar<unsigned int>("Hits_MM_nHits")}
private

Definition at line 29 of file MMSimHitVariables.h.

29{parent().newScalar<unsigned int>("Hits_MM_nHits")};
ScalarBranch< T > & newScalar(const std::string &name)

◆ m_NSWMM_particleEncoding

VectorBranch<int>& MuonPRDTest::MMSimHitVariables::m_NSWMM_particleEncoding {parent().newVector<int>("Hits_MM_particleEncoding")}
private

Definition at line 24 of file MMSimHitVariables.h.

24{parent().newVector<int>("Hits_MM_particleEncoding")};

◆ m_NSWMM_trackId

VectorBranch<int>& MuonPRDTest::MMSimHitVariables::m_NSWMM_trackId {parent().newVector<int>("Hits_MM_trackId")}
private

Definition at line 28 of file MMSimHitVariables.h.

28{parent().newVector<int>("Hits_MM_trackId")};

◆ m_parent

MuonTesterTree* MuonVal::MuonTesterBranch::m_parent {nullptr}
privateinherited

Definition at line 59 of file MuonTesterBranch.h.

59{nullptr};

◆ m_tree

TTree* MuonVal::MuonTesterBranch::m_tree {nullptr}
privateinherited

Definition at line 58 of file MuonTesterBranch.h.

58{nullptr};

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