ATLAS Offline Software
Public Types | Public Member Functions | Static Public Member Functions | Protected Member Functions | Private Member Functions | Private Attributes | List of all members
MuonPRDTest::sTGCSimHitVariables Class Reference

#include <sTGCSimHitVariables.h>

Inheritance diagram for MuonPRDTest::sTGCSimHitVariables:
Collaboration diagram for MuonPRDTest::sTGCSimHitVariables:

Public Types

using DataDependency = SG::VarHandleKey *
 

Public Member Functions

 sTGCSimHitVariables (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. More...
 
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. More...
 
std::string name () const override final
 Returns the name of the branch. More...
 
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. More...
 
TTree * tree () override final
 Returns the underlying TTree object. More...
 
const TTree * tree () const override final
 
std::vector< DataDependencydata_dependencies () override final
 Returns the data dependencies needed by the MuonTesterBranch. More...
 
bool msgLvl (const MSG::Level lvl) const
 Test the output level. More...
 
MsgStream & msg () const
 The standard message stream. More...
 
MsgStream & msg (const MSG::Level lvl) const
 The standard message stream. More...
 
void setLevel (MSG::Level lvl)
 Change the current logging level. More...
 

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. More...
 
template<class Key >
bool declare_dependency (Key &key)
 Declares the ReadHandle/ ReadCondHandleKey as data dependency of the algorithm. More...
 
MuonTesterTreeparent ()
 Returns the reference to the MuonTesterTree parent. More...
 

Private Member Functions

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

Private Attributes

SG::ReadHandleKey< sTGCSimHitCollectionm_key {}
 
ThreeVectorBranch m_NSWsTGC_hitGlobalPosition {parent(), "Hits_sTGC_GlobalPosition"}
 
ThreeVectorBranch m_NSWsTGC_hitGlobalDirection {parent(), "Hits_sTGC_GlobalDirection"}
 
ThreeVectorBranch m_NSWsTGC_hitGlobalPrePosition {parent(), "Hits_sTGC_GlobalPrePosition"}
 
VectorBranch< int > & m_NSWsTGC_particleEncoding {parent().newVector<int>("Hits_sTGC_particleEncoding")}
 
VectorBranch< float > & m_NSWsTGC_kineticEnergy {parent().newVector<float>("Hits_sTGC_kineticEnergy")}
 
VectorBranch< float > & m_NSWsTGC_depositEnergy {parent().newVector<float>("Hits_sTGC_depositEnergy")}
 
VectorBranch< bool > & m_NSWsTGC_isInsideBounds {parent().newVector<bool>("Hits_sTGC_isInsideBounds")}
 
VectorBranch< int > & m_NSWsTGC_trackId {parent().newVector<int>("Hits_sTGC_trackId")}
 
ScalarBranch< unsigned int > & m_NSWsTGC_nSimHits {parent().newScalar<unsigned int>("Hits_sTGC_nHits")}
 
sTgcIdentifierBranch m_NSWsTGC_Id {parent(), "Hits_sTGC_off"}
 
VectorBranch< float > & m_NSWsTGC_globalTime {parent().newVector<float>("Hits_sTGC_globalTime")}
 
VectorBranch< int > & m_NSWsTGC_detectorNumber {parent().newVector<int>("Hits_sTGC_detectorNumber")}
 
VectorBranch< int > & m_NSWsTGC_wedgeId {parent().newVector<int>("Hits_sTGC_wedgeId")}
 
VectorBranch< int > & m_NSWsTGC_wedgeType {parent().newVector<int>("Hits_sTGC_wedgeType")}
 
ThreeVectorBranch m_NSWsTGC_detector_globalPosition {parent(), "Hits_sTGC_detector_globalPosition"}
 
ThreeVectorBranch m_NSWsTGC_hitToDsurfacePosition {parent(), "Hits_sTGC_hitToDsurfacePosition"}
 
ThreeVectorBranch m_NSWsTGC_hitToRsurfacePosition {parent(), "Hits_sTGC_hitToRsurfacePosition"}
 
VectorBranch< float > & m_NSWsTGC_FastDigitRsurfacePositionX {parent().newVector<float>("Hits_sTGC_FastDigitRsurfacePositionX")}
 
VectorBranch< float > & m_NSWsTGC_FastDigitRsurfacePositionY {parent().newVector<float>("Hits_sTGC_FastDigitRsurfacePositionY")}
 
VectorBranch< int > & m_NSWsTGC_stripNumber {parent().newVector<int>("Hits_sTGC_stripNumber")}
 
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. More...
 
boost::thread_specific_ptr< MsgStream > m_msg_tls
 MsgStream instance (a std::cout like with print-out levels) More...
 
std::atomic< IMessageSvc * > m_imsg { nullptr }
 MessageSvc pointer. More...
 
std::atomic< MSG::Level > m_lvl { MSG::NIL }
 Current logging level. More...
 
std::atomic_flag m_initialized ATLAS_THREAD_SAFE = ATOMIC_FLAG_INIT
 Messaging initialized (initMessaging) More...
 

Detailed Description

Definition at line 13 of file sTGCSimHitVariables.h.

Member Typedef Documentation

◆ DataDependency

Definition at line 39 of file IMuonTesterBranch.h.

Constructor & Destructor Documentation

◆ sTGCSimHitVariables()

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

Definition at line 9 of file sTGCSimHitVariables.cxx.

9  :
10  PrdTesterModule(tree, "sTGC_Sim", msglvl), m_key{container_name} {}

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;}

◆ 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::sTGCSimHitVariables::declare_keys ( )
finaloverridevirtual

Implements MuonPRDTest::PrdTesterModule.

Definition at line 12 of file sTGCSimHitVariables.cxx.

12 { return declare_dependency(m_key); }

◆ 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 }

◆ fill()

bool MuonPRDTest::sTGCSimHitVariables::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 14 of file sTGCSimHitVariables.cxx.

14  {
15  ATH_MSG_DEBUG("do fill sTGCSimHitVariables()");
16  SG::ReadHandle<sTGCSimHitCollection> stgcContainer{m_key, ctx};
17  if (!stgcContainer.isValid()) {
18  ATH_MSG_FATAL("Failed to retrieve SimHit container " << m_key.fullKey());
19  return false;
20  }
21  const MuonGM::MuonDetectorManager* MuonDetMgr = getDetMgr(ctx);
22  if (!MuonDetMgr) { return false; }
23  unsigned int n_hits{0};
24  // Get the sTGC Id hit helper
25  const sTgcHitIdHelper* stgchhelper = sTgcHitIdHelper::GetHelper();
26  const Amg::Vector3D dummyVector(-9999.9, 0.0, 0.0);
27  if (!stgcContainer->size()) ATH_MSG_DEBUG("sTGC Sim container is empty");
28  for (const sTGCSimHit& hit : *stgcContainer) {
29  if(hit.depositEnergy()==0.) continue; // SimHits without energy loss are not recorded.
30 
31  for( int type=0;type<=2;++type ){
32  int simId = hit.sTGCId();
33  std::string stname = stgchhelper->GetStationName(simId);
34  int steta = stgchhelper->GetZSector(simId);
35  int stphi = stgchhelper->GetPhiSector(simId);
36  int multilayer = stgchhelper->GetMultiLayer(simId);
37  int layer = stgchhelper->GetLayer(simId);
38  int side = stgchhelper->GetSide(simId);
39 
40  if ( stphi==0 ) {
41  ATH_MSG_ERROR("unexpected phi range: " << stphi);
42  return false;
43  }
44 
45  // Old [7/12/12] implementation of the Station Name is: T[0-3][L/S][P/C]
46  // Current implementation of the Station Name is: Q[L/S][1-3][P/C]
47  int detNumber = -999, wedgeId = -999, wedgeType = -999;
48  if(stname.length()!=4) {
49  ATH_MSG_WARNING("sTGC validation: station Name exceeds 4 charactes, filling dummy information for detNumber, wedgeId and wedgeType");
50  }
51  else {
52  detNumber = atoi(stname.substr(2,1).c_str());
53  wedgeId = (stname.substr(1,1).compare("L")) ? 0 : 1;
54  wedgeType = (stname.substr(3,1).compare("P")) ? 0 : 1;
55  }
56 
57  Identifier offId = idHelperSvc()->stgcIdHelper().channelID(stname[1] == 'L' ? "STL" : "STS",
58  side == 1 ? steta+1 : -steta-1,
59  (stphi-1)/2+1,multilayer,layer,1,1 );
60  m_NSWsTGC_Id.push_back(offId);
61  std::string stName = idHelperSvc()->stgcIdHelper().stationNameString(idHelperSvc()->stgcIdHelper().stationName(offId));
62  int off_channel = idHelperSvc()->stgcIdHelper().channel(offId);
63 
64  int isSmall = stName[2] == 'S';
65 
66  if( type == 2 && off_channel == 63) {
67  ATH_MSG_DEBUG("Found sTGC Wire Sim Hit with channel number 63 (dead region), skipping this hit");
68  continue;
69  }
70 
71  const MuonGM::sTgcReadoutElement* detEl = MuonDetMgr->getsTgcReadoutElement(offId);
72  if (!detEl) {
73  ATH_MSG_ERROR("sTGCSimHitVariables::fillVariables() - Failed to retrieve sTgcReadoutElement for "<<idHelperSvc()->stgcIdHelper().print_to_string(offId).c_str());
74  return false;
75  }
76 
77  if( !idHelperSvc()->stgcIdHelper().is_stgc(offId) ){
78  ATH_MSG_WARNING("sTgc id is not a stgc id! " << idHelperSvc()->stgcIdHelper().print_to_string(offId));
79  }
80  if( !idHelperSvc()->stgcIdHelper().is_muon(offId) ){
81  ATH_MSG_WARNING("sTgc id is not a muon id! " << idHelperSvc()->stgcIdHelper().print_to_string(offId));
82  }
83  if( idHelperSvc()->stgcIdHelper().is_mdt(offId)||idHelperSvc()->stgcIdHelper().is_rpc(offId)||idHelperSvc()->stgcIdHelper().is_tgc(offId)||idHelperSvc()->stgcIdHelper().is_csc(offId)||idHelperSvc()->stgcIdHelper().is_mm(offId) ){
84  ATH_MSG_WARNING("sTgc id has wrong technology type! " << idHelperSvc()->stgcIdHelper().is_mdt(offId) << " " << idHelperSvc()->stgcIdHelper().is_rpc(offId)
85  << " " << idHelperSvc()->stgcIdHelper().is_tgc(offId) << " " << idHelperSvc()->stgcIdHelper().is_csc(offId) << " " << idHelperSvc()->stgcIdHelper().is_mm(offId) );
86  }
87  if( idHelperSvc()->stgcIdHelper().gasGap(offId) != layer ) {
88  ATH_MSG_WARNING("sTgc id has bad layer field! " << idHelperSvc()->stgcIdHelper().print_to_string(offId) );
89  }
90 
91  // connect the hit with the MC truth
92  int barcode = hit.particleLink().barcode();
95  m_NSWsTGC_wedgeType.push_back(wedgeType);
97 
98  m_NSWsTGC_globalTime.push_back(hit.globalTime());
99  const Amg::Vector3D& globalPosition = hit.globalPosition();
100  m_NSWsTGC_hitGlobalPosition.push_back(globalPosition);
101 
102  const Amg::Vector3D& globalDirection = hit.globalDirection();
103  m_NSWsTGC_hitGlobalDirection.push_back(globalDirection);
104 
105  m_NSWsTGC_particleEncoding.push_back(hit.particleEncoding());
106  m_NSWsTGC_depositEnergy.push_back(hit.depositEnergy());
107  m_NSWsTGC_kineticEnergy.push_back(hit.kineticEnergy());
108 
109  const Amg::Vector3D& globalPrePosition = hit.globalPrePosition();
110  m_NSWsTGC_hitGlobalPrePosition.push_back(globalPrePosition);
111  if (hit.kineticEnergy() < 0.0) {
113  }
114 
115  ATH_MSG_DEBUG("sTGC geometry, retrieving detector element for: isSmall " << isSmall << " eta " << idHelperSvc()->stgcIdHelper().stationEta(offId)
116  << " phi " << idHelperSvc()->stgcIdHelper().stationPhi(offId) << " ml " << idHelperSvc()->stgcIdHelper().multilayer(offId) );
117 
118  Identifier newId = idHelperSvc()->stgcIdHelper().channelID(idHelperSvc()->stgcIdHelper().parentID(offId), idHelperSvc()->stgcIdHelper().multilayer(offId), idHelperSvc()->stgcIdHelper().gasGap(offId),type,1);
119 
120  // compute hit position within the detector element/surfaces
121  const Trk::PlaneSurface& surf = detEl->surface(newId);
122  Amg::Transform3D gToL = detEl->absTransform().inverse();
123  Amg::Vector3D dSurface_pos = gToL*globalPosition;
124 
125  // compute the hit position on the readout plane (same as in MuonFastDigitization)
126  Amg::Vector3D rSurface_pos = surf.transform().inverse()*globalPosition;
127  Amg::Vector3D ldir = surf.transform().inverse().linear()*globalDirection;
128 
129  ATH_MSG_DEBUG("sTGC channel type:" << type);
130 
131  double scale = -rSurface_pos.z()/ldir.z();
132  Amg::Vector3D hitOnSurface = rSurface_pos + scale*ldir;
133 
134  // hitOnSurface.x() will be susequent smeared to simulate the detector resolution, here we do not apply any smearing
135  Amg::Vector2D posOnSurf(hitOnSurface.x(), rSurface_pos.y());
136 
137  // remember whether the given hit is inside the active volume (and produces a valid digit)
139 
140  int stripNumber = detEl->stripNumber(posOnSurf,newId);
141  if( stripNumber == -1 ){
142  ATH_MSG_WARNING("sTGC validation: failed to obtain strip number " << idHelperSvc()->stgcIdHelper().print_to_string(offId) );
143  ATH_MSG_WARNING(" pos " << posOnSurf << " z " << rSurface_pos.z() );
144  //stripNumber = 1;
145  }
146  Identifier oldId = offId;
147  offId = idHelperSvc()->stgcIdHelper().channelID(offId, idHelperSvc()->stgcIdHelper().multilayer(offId), idHelperSvc()->stgcIdHelper().gasGap(offId),1,stripNumber);
148  if( idHelperSvc()->stgcIdHelper().gasGap(offId) != layer ) {
149  ATH_MSG_WARNING("sTGC validation: sTgc id has bad layer field(2)! " << std::endl << " " << idHelperSvc()->stgcIdHelper().print_to_string(offId) << std::endl
150  << " " << idHelperSvc()->stgcIdHelper().print_to_string(oldId) << " stripN " << stripNumber );
151  }
152 
153  Amg::Vector2D fastDigitPos(0,0);
154  if( !detEl->stripPosition(offId,fastDigitPos) ){
155  ATH_MSG_WARNING("sTGC validation: failed to obtain local position for identifier " << idHelperSvc()->stgcIdHelper().print_to_string(offId) );
156  }
157 
158  Amg::Vector3D detpos = detEl->globalPosition();
159  ATH_MSG_DEBUG("sTGC Global hit: r " << hit.globalPosition().perp() << ", phi " << hit.globalPosition().phi() << ", z " << hit.globalPosition().z()
160  << "; detEl: r " << detpos.perp() << ", phi " << detpos.phi() << ", z " << detpos.z()
161  << "; surf z " << surf.center().z() << ", ml " << multilayer << ", l " << layer );
162 
163  ATH_MSG_DEBUG(" detEl: x " << dSurface_pos.x() << " y " << dSurface_pos.y() << " z " << dSurface_pos.z());
164  ATH_MSG_DEBUG("sTGC Fast digit: x " << fastDigitPos.x() << " y " << fastDigitPos.y()
165  << ", gToL: x " << rSurface_pos.x() << " y " << rSurface_pos.y() << " z " << rSurface_pos.z() );
166 
167  // Fill ntuple with the hit/surface/digit positions
169 
171 
173 
176  m_NSWsTGC_stripNumber.push_back(stripNumber);
177  }
178  ++n_hits;
179  }
180  m_NSWsTGC_nSimHits = n_hits;
181 
182  ATH_MSG_DEBUG("processed " << m_NSWsTGC_nSimHits << " sTgc hits");
183  return true;
184  }

◆ getDetMgr()

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

Definition at line 16 of file PrdTesterModule.cxx.

16  {
18  if (!handle.isValid()) {
19  ATH_MSG_ERROR("Failed to retrieve MuonDetectorManager " << m_detMgrKey.fullKey());
20  return nullptr;
21  }
22  return handle.cptr();
23  }

◆ idHelperSvc()

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

Definition at line 15 of file PrdTesterModule.cxx.

15 { return m_idHelperSvc.get(); }

◆ 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.

52 { return m_init; }

◆ 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  m_lvl = m_imsg ?
43  static_cast<MSG::Level>( m_imsg.load()->outputLevel(m_nm) ) :
44  MSG::INFO;
45 }

◆ 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 164 of file AthMessaging.h.

165 {
166  MsgStream* ms = m_msg_tls.get();
167  if (!ms) {
168  if (!m_initialized.test_and_set()) initMessaging();
169  ms = new MsgStream(m_imsg,m_nm);
170  m_msg_tls.reset( ms );
171  }
172 
173  ms->setLevel (m_lvl);
174  return *ms;
175 }

◆ 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 179 of file AthMessaging.h.

180 { return msg() << lvl; }

◆ 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_initialized.test_and_set()) initMessaging();
154  if (m_lvl <= lvl) {
155  msg() << lvl;
156  return true;
157  } else {
158  return false;
159  }
160 }

◆ 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 }

◆ 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.

◆ m_detMgrKey

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

Definition at line 29 of file PrdTesterModule.h.

◆ m_idHelperSvc

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

Definition at line 30 of file PrdTesterModule.h.

◆ m_imsg

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

MessageSvc pointer.

Definition at line 135 of file AthMessaging.h.

◆ m_init

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

Definition at line 61 of file MuonTesterBranch.h.

◆ m_key

SG::ReadHandleKey<sTGCSimHitCollection> MuonPRDTest::sTGCSimHitVariables::m_key {}
private

Definition at line 21 of file sTGCSimHitVariables.h.

◆ m_lvl

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

Current logging level.

Definition at line 138 of file AthMessaging.h.

◆ 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.

◆ m_nm

std::string AthMessaging::m_nm
privateinherited

Message source name.

Definition at line 129 of file AthMessaging.h.

◆ m_NSWsTGC_depositEnergy

VectorBranch<float>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_depositEnergy {parent().newVector<float>("Hits_sTGC_depositEnergy")}
private

Definition at line 27 of file sTGCSimHitVariables.h.

◆ m_NSWsTGC_detector_globalPosition

ThreeVectorBranch MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_detector_globalPosition {parent(), "Hits_sTGC_detector_globalPosition"}
private

Definition at line 36 of file sTGCSimHitVariables.h.

◆ m_NSWsTGC_detectorNumber

VectorBranch<int>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_detectorNumber {parent().newVector<int>("Hits_sTGC_detectorNumber")}
private

Definition at line 33 of file sTGCSimHitVariables.h.

◆ m_NSWsTGC_FastDigitRsurfacePositionX

VectorBranch<float>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_FastDigitRsurfacePositionX {parent().newVector<float>("Hits_sTGC_FastDigitRsurfacePositionX")}
private

Definition at line 39 of file sTGCSimHitVariables.h.

◆ m_NSWsTGC_FastDigitRsurfacePositionY

VectorBranch<float>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_FastDigitRsurfacePositionY {parent().newVector<float>("Hits_sTGC_FastDigitRsurfacePositionY")}
private

Definition at line 40 of file sTGCSimHitVariables.h.

◆ m_NSWsTGC_globalTime

VectorBranch<float>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_globalTime {parent().newVector<float>("Hits_sTGC_globalTime")}
private

Definition at line 32 of file sTGCSimHitVariables.h.

◆ m_NSWsTGC_hitGlobalDirection

ThreeVectorBranch MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_hitGlobalDirection {parent(), "Hits_sTGC_GlobalDirection"}
private

Definition at line 23 of file sTGCSimHitVariables.h.

◆ m_NSWsTGC_hitGlobalPosition

ThreeVectorBranch MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_hitGlobalPosition {parent(), "Hits_sTGC_GlobalPosition"}
private

Definition at line 22 of file sTGCSimHitVariables.h.

◆ m_NSWsTGC_hitGlobalPrePosition

ThreeVectorBranch MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_hitGlobalPrePosition {parent(), "Hits_sTGC_GlobalPrePosition"}
private

Definition at line 24 of file sTGCSimHitVariables.h.

◆ m_NSWsTGC_hitToDsurfacePosition

ThreeVectorBranch MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_hitToDsurfacePosition {parent(), "Hits_sTGC_hitToDsurfacePosition"}
private

Definition at line 37 of file sTGCSimHitVariables.h.

◆ m_NSWsTGC_hitToRsurfacePosition

ThreeVectorBranch MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_hitToRsurfacePosition {parent(), "Hits_sTGC_hitToRsurfacePosition"}
private

Definition at line 38 of file sTGCSimHitVariables.h.

◆ m_NSWsTGC_Id

sTgcIdentifierBranch MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_Id {parent(), "Hits_sTGC_off"}
private

Definition at line 31 of file sTGCSimHitVariables.h.

◆ m_NSWsTGC_isInsideBounds

VectorBranch<bool>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_isInsideBounds {parent().newVector<bool>("Hits_sTGC_isInsideBounds")}
private

Definition at line 28 of file sTGCSimHitVariables.h.

◆ m_NSWsTGC_kineticEnergy

VectorBranch<float>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_kineticEnergy {parent().newVector<float>("Hits_sTGC_kineticEnergy")}
private

Definition at line 26 of file sTGCSimHitVariables.h.

◆ m_NSWsTGC_nSimHits

ScalarBranch<unsigned int>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_nSimHits {parent().newScalar<unsigned int>("Hits_sTGC_nHits")}
private

Definition at line 30 of file sTGCSimHitVariables.h.

◆ m_NSWsTGC_particleEncoding

VectorBranch<int>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_particleEncoding {parent().newVector<int>("Hits_sTGC_particleEncoding")}
private

Definition at line 25 of file sTGCSimHitVariables.h.

◆ m_NSWsTGC_stripNumber

VectorBranch<int>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_stripNumber {parent().newVector<int>("Hits_sTGC_stripNumber")}
private

Definition at line 41 of file sTGCSimHitVariables.h.

◆ m_NSWsTGC_trackId

VectorBranch<int>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_trackId {parent().newVector<int>("Hits_sTGC_trackId")}
private

Definition at line 29 of file sTGCSimHitVariables.h.

◆ m_NSWsTGC_wedgeId

VectorBranch<int>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_wedgeId {parent().newVector<int>("Hits_sTGC_wedgeId")}
private

Definition at line 34 of file sTGCSimHitVariables.h.

◆ m_NSWsTGC_wedgeType

VectorBranch<int>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_wedgeType {parent().newVector<int>("Hits_sTGC_wedgeType")}
private

Definition at line 35 of file sTGCSimHitVariables.h.

◆ m_parent

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

Definition at line 59 of file MuonTesterBranch.h.

◆ m_tree

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

Definition at line 58 of file MuonTesterBranch.h.


The documentation for this class was generated from the following files:
AthMessaging::m_lvl
std::atomic< MSG::Level > m_lvl
Current logging level.
Definition: AthMessaging.h:138
MuonPRDTest::sTGCSimHitVariables::m_key
SG::ReadHandleKey< sTGCSimHitCollection > m_key
Definition: sTGCSimHitVariables.h:21
sTgcHitIdHelper::GetSide
int GetSide(const int &hid) const
Definition: sTgcHitIdHelper.cxx:83
Muon::nsw::STGTPSegments::moduleIDBits::stationPhi
constexpr uint8_t stationPhi
station Phi 1 to 8
Definition: NSWSTGTPDecodeBitmaps.h:158
dumpTgcDigiDeadChambers.gasGap
list gasGap
Definition: dumpTgcDigiDeadChambers.py:33
ATH_MSG_FATAL
#define ATH_MSG_FATAL(x)
Definition: AthMsgStreamMacros.h:34
Muon::IMuonIdHelperSvc::stgcIdHelper
virtual const sTgcIdHelper & stgcIdHelper() const =0
access to TgcIdHelper
MuonGM::MuonReadoutElement::absTransform
const Amg::Transform3D & absTransform() const
Definition: MuonDetDescr/MuonReadoutGeometry/MuonReadoutGeometry/MuonReadoutElement.h:210
SG::ReadCondHandle
Definition: ReadCondHandle.h:44
MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_trackId
VectorBranch< int > & m_NSWsTGC_trackId
Definition: sTGCSimHitVariables.h:29
dumpTgcDigiDeadChambers.stationName
dictionary stationName
Definition: dumpTgcDigiDeadChambers.py:30
MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_FastDigitRsurfacePositionY
VectorBranch< float > & m_NSWsTGC_FastDigitRsurfacePositionY
Definition: sTGCSimHitVariables.h:40
Amg::Vector2D
Eigen::Matrix< double, 2, 1 > Vector2D
Definition: GeoPrimitives.h:48
SG::ReadHandle
Definition: StoreGate/StoreGate/ReadHandle.h:70
sTgcIdHelper::channelID
Identifier channelID(int stationName, int stationEta, int stationPhi, int multilayer, int gasGap, int channelType, int channel) const
Definition: sTgcIdHelper.cxx:886
MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_detector_globalPosition
ThreeVectorBranch m_NSWsTGC_detector_globalPosition
Definition: sTGCSimHitVariables.h:36
MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_wedgeId
VectorBranch< int > & m_NSWsTGC_wedgeId
Definition: sTGCSimHitVariables.h:34
sTgcHitIdHelper::GetHelper
static const sTgcHitIdHelper * GetHelper()
Definition: sTgcHitIdHelper.cxx:24
MuonVal::MuonTesterBranch::m_dependencies
std::vector< DataDependency > m_dependencies
Definition: MuonTesterBranch.h:62
MuonVal::MuonTesterBranch::m_tree
TTree * m_tree
Definition: MuonTesterBranch.h:58
MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_detectorNumber
VectorBranch< int > & m_NSWsTGC_detectorNumber
Definition: sTGCSimHitVariables.h:33
python.AthDsoLogger.out
out
Definition: AthDsoLogger.py:71
MuonPRDTest::PrdTesterModule::getDetMgr
const MuonGM::MuonDetectorManager * getDetMgr(const EventContext &ctx) const
Definition: PrdTesterModule.cxx:16
MuonVal::sTgcIdentifierBranch::push_back
void push_back(const Identifier &id) override final
Definition: IdentifierBranch.cxx:79
MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_isInsideBounds
VectorBranch< bool > & m_NSWsTGC_isInsideBounds
Definition: sTGCSimHitVariables.h:28
Trk::Surface::center
const Amg::Vector3D & center() const
Returns the center position of the Surface.
yodamerge_tmp.scale
scale
Definition: yodamerge_tmp.py:138
AthMessaging::m_imsg
std::atomic< IMessageSvc * > m_imsg
MessageSvc pointer.
Definition: AthMessaging.h:135
python.SystemOfUnits.ms
int ms
Definition: SystemOfUnits.py:132
MuonGM::MuonClusterReadoutElement::surface
virtual const Trk::PlaneSurface & surface() const override
access to chamber surface (phi orientation), uses the first gas gap
Definition: MuonClusterReadoutElement.h:123
Athena::getMessageSvc
IMessageSvc * getMessageSvc(bool quiet=false)
Definition: getMessageSvc.cxx:20
MuonVal::MuonTesterBranch::tree
TTree * tree() override final
Returns the underlying TTree object.
Definition: MuonTesterBranch.cxx:53
MuonVal::MuonTesterBranch::m_parent
MuonTesterTree * m_parent
Definition: MuonTesterBranch.h:59
MuonGM::sTgcReadoutElement::stripPosition
virtual bool stripPosition(const Identifier &id, Amg::Vector2D &pos) const override final
strip position - should be renamed to channel position If the strip number is outside the range of va...
Definition: MuonDetDescr/MuonReadoutGeometry/MuonReadoutGeometry/sTgcReadoutElement.h:325
MuonVal::MuonTesterBranch::declare_dependency
bool declare_dependency(Key &key)
Declares the ReadHandle/ ReadCondHandleKey as data dependency of the algorithm.
TRT::Hit::side
@ side
Definition: HitInfo.h:83
MuonVal::ThreeVectorBranch::push_back
void push_back(const Amg::Vector3D &vec)
interface using the Amg::Vector3D
Definition: ThreeVectorBranch.cxx:23
MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_globalTime
VectorBranch< float > & m_NSWsTGC_globalTime
Definition: sTGCSimHitVariables.h:32
Trk::PlaneSurface::insideBounds
virtual bool insideBounds(const Amg::Vector2D &locpos, double tol1=0., double tol2=0.) const override
This method calls the inside() method of the Bounds.
sTgcHitIdHelper::GetMultiLayer
int GetMultiLayer(const int &hid) const
Definition: sTgcHitIdHelper.cxx:77
MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_kineticEnergy
VectorBranch< float > & m_NSWsTGC_kineticEnergy
Definition: sTGCSimHitVariables.h:26
TrigConf::MSGTC::Level
Level
Definition: Trigger/TrigConfiguration/TrigConfBase/TrigConfBase/MsgStream.h:21
sTgcIdHelper::channel
int channel(const Identifier &id) const override
Definition: sTgcIdHelper.cxx:1027
ATH_MSG_ERROR
#define ATH_MSG_ERROR(x)
Definition: AthMsgStreamMacros.h:33
sTgcHitIdHelper::GetLayer
int GetLayer(const int &hid) const
Definition: sTgcHitIdHelper.cxx:80
ATH_MSG_DEBUG
#define ATH_MSG_DEBUG(x)
Definition: AthMsgStreamMacros.h:29
HepMC::barcode
int barcode(const T *p)
Definition: Barcode.h:16
TRT::Hit::layer
@ layer
Definition: HitInfo.h:79
MuonGM::sTgcReadoutElement
An sTgcReadoutElement corresponds to a single STGC module; therefore typicaly a barrel muon station c...
Definition: MuonDetDescr/MuonReadoutGeometry/MuonReadoutGeometry/sTgcReadoutElement.h:30
Amg::Transform3D
Eigen::Affine3d Transform3D
Definition: GeoPrimitives.h:46
MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_hitGlobalDirection
ThreeVectorBranch m_NSWsTGC_hitGlobalDirection
Definition: sTGCSimHitVariables.h:23
MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_wedgeType
VectorBranch< int > & m_NSWsTGC_wedgeType
Definition: sTGCSimHitVariables.h:35
MuonVal::MuonTesterBranch::m_init
bool m_init
Definition: MuonTesterBranch.h:61
MuonGM::MuonReadoutElement::globalPosition
const Amg::Vector3D globalPosition() const
Definition: MuonDetDescr/MuonReadoutGeometry/src/MuonReadoutElement.cxx:47
MuonPRDTest::PrdTesterModule::m_idHelperSvc
ServiceHandle< Muon::IMuonIdHelperSvc > m_idHelperSvc
Definition: PrdTesterModule.h:30
AthMessaging::msg
MsgStream & msg() const
The standard message stream.
Definition: AthMessaging.h:164
MuonVal::MuonTesterBranch::name
std::string name() const override final
Returns the name of the branch.
Definition: MuonTesterBranch.cxx:51
MuonVal::VectorBranch::push_back
void push_back(const T &value)
Adds a new element at the end of the vector.
MuonIdHelper::stationNameString
const std::string & stationNameString(const int &index) const
Definition: MuonIdHelper.cxx:854
MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_Id
sTgcIdentifierBranch m_NSWsTGC_Id
Definition: sTGCSimHitVariables.h:31
MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_hitGlobalPosition
ThreeVectorBranch m_NSWsTGC_hitGlobalPosition
Definition: sTGCSimHitVariables.h:22
MuonPRDTest::PrdTesterModule::PrdTesterModule
PrdTesterModule(MuonTesterTree &tree, const std::string &grp_name, MSG::Level msglvl)
Definition: PrdTesterModule.cxx:8
MuonPRDTest::PrdTesterModule::declare_keys
virtual bool declare_keys()=0
Definition: PrdTesterModule.cxx:28
MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_hitGlobalPrePosition
ThreeVectorBranch m_NSWsTGC_hitGlobalPrePosition
Definition: sTGCSimHitVariables.h:24
sTgcHitIdHelper::GetStationName
std::string GetStationName(const int &hid) const
Definition: sTgcHitIdHelper.cxx:56
MuonPRDTest::PrdTesterModule::m_detMgrKey
SG::ReadCondHandleKey< MuonGM::MuonDetectorManager > m_detMgrKey
Definition: PrdTesterModule.h:29
Amg::Vector3D
Eigen::Matrix< double, 3, 1 > Vector3D
Definition: GeoPrimitives.h:47
sTgcHitIdHelper::GetZSector
int GetZSector(const int &hid) const
Definition: sTgcHitIdHelper.cxx:72
sTGCSimHit
Definition: sTGCSimHit.h:15
MuonGM::sTgcReadoutElement::stripNumber
virtual int stripNumber(const Amg::Vector2D &pos, const Identifier &id) const override final
strip number corresponding to local position.
Definition: MuonDetDescr/MuonReadoutGeometry/MuonReadoutGeometry/sTgcReadoutElement.h:313
MuonVal::MuonTesterBranch::m_name
std::string m_name
Definition: MuonTesterBranch.h:60
MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_hitToRsurfacePosition
ThreeVectorBranch m_NSWsTGC_hitToRsurfacePosition
Definition: sTGCSimHitVariables.h:38
sTgcHitIdHelper
Definition: sTgcHitIdHelper.h:13
MuonGM::MuonDetectorManager
The MuonDetectorManager stores the transient representation of the Muon Spectrometer geometry and pro...
Definition: MuonDetDescr/MuonReadoutGeometry/MuonReadoutGeometry/MuonDetectorManager.h:50
ATH_MSG_WARNING
#define ATH_MSG_WARNING(x)
Definition: AthMsgStreamMacros.h:32
Trk::PlaneSurface
Definition: PlaneSurface.h:64
MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_depositEnergy
VectorBranch< float > & m_NSWsTGC_depositEnergy
Definition: sTGCSimHitVariables.h:27
python.CaloScaleNoiseConfig.type
type
Definition: CaloScaleNoiseConfig.py:78
AthMessaging::m_nm
std::string m_nm
Message source name.
Definition: AthMessaging.h:129
MuonPRDTest::PrdTesterModule::idHelperSvc
const Muon::IMuonIdHelperSvc * idHelperSvc() const
Definition: PrdTesterModule.cxx:15
MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_stripNumber
VectorBranch< int > & m_NSWsTGC_stripNumber
Definition: sTGCSimHitVariables.h:41
CxxUtils::atoi
int atoi(std::string_view str)
Helper functions to unpack numbers decoded in string into integers and doubles The strings are requir...
Definition: Control/CxxUtils/Root/StringUtils.cxx:85
MuonGM::MuonDetectorManager::getsTgcReadoutElement
const sTgcReadoutElement * getsTgcReadoutElement(const Identifier &id) const
access via extended identifier (requires unpacking)
Definition: MuonDetDescr/MuonReadoutGeometry/src/MuonDetectorManager.cxx:259
AthMessaging::initMessaging
void initMessaging() const
Initialize our message level and MessageSvc.
Definition: AthMessaging.cxx:39
Muon::nsw::STGTPSegments::moduleIDBits::stationEta
constexpr uint8_t stationEta
1 to 3
Definition: NSWSTGTPDecodeBitmaps.h:156
MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_FastDigitRsurfacePositionX
VectorBranch< float > & m_NSWsTGC_FastDigitRsurfacePositionX
Definition: sTGCSimHitVariables.h:39
AthMessaging::m_msg_tls
boost::thread_specific_ptr< MsgStream > m_msg_tls
MsgStream instance (a std::cout like with print-out levels)
Definition: AthMessaging.h:132
Trk::Surface::transform
const Amg::Transform3D & transform() const
Returns HepGeom::Transform3D by reference.
MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_particleEncoding
VectorBranch< int > & m_NSWsTGC_particleEncoding
Definition: sTGCSimHitVariables.h:25
sTgcHitIdHelper::GetPhiSector
int GetPhiSector(const int &hid) const
Definition: sTgcHitIdHelper.cxx:68
MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_nSimHits
ScalarBranch< unsigned int > & m_NSWsTGC_nSimHits
Definition: sTGCSimHitVariables.h:30
Identifier
Definition: IdentifierFieldParser.cxx:14
MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_hitToDsurfacePosition
ThreeVectorBranch m_NSWsTGC_hitToDsurfacePosition
Definition: sTGCSimHitVariables.h:37