|
ATLAS Offline Software
|
#include <sTGCSimHitVariables.h>
|
| 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< DataDependency > | data_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...
|
|
Definition at line 13 of file sTGCSimHitVariables.h.
◆ DataDependency
◆ sTGCSimHitVariables()
MuonPRDTest::sTGCSimHitVariables::sTGCSimHitVariables |
( |
MuonTesterTree & |
tree, |
|
|
const std::string & |
container_name, |
|
|
MSG::Level |
msglvl |
|
) |
| |
◆ addToTree()
template<class T >
bool MuonVal::MuonTesterBranch::addToTree |
( |
T & |
variable | ) |
|
|
protectedinherited |
Connects the Memory buffer with the TTree.
◆ data_dependencies()
|
finaloverridevirtualinherited |
◆ 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 |
◆ eraseWhiteSpaces()
std::string MuonVal::MuonTesterBranch::eraseWhiteSpaces |
( |
const std::string & |
In | ) |
|
|
staticinherited |
◆ 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.
17 if (!stgcContainer.isValid()) {
22 if (!MuonDetMgr) {
return false; }
23 unsigned int n_hits{0};
27 if (!stgcContainer->size())
ATH_MSG_DEBUG(
"sTGC Sim container is empty");
29 if(hit.depositEnergy()==0.)
continue;
32 int simId = hit.sTGCId();
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");
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;
58 side == 1 ? steta+1 : -steta-1,
59 (stphi-1)/2+1,multilayer,
layer,1,1 );
64 int isSmall = stName[2] ==
'S';
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");
73 ATH_MSG_ERROR(
"sTGCSimHitVariables::fillVariables() - Failed to retrieve sTgcReadoutElement for "<<
idHelperSvc()->stgcIdHelper().print_to_string(offId).c_str());
77 if( !
idHelperSvc()->stgcIdHelper().is_stgc(offId) ){
80 if( !
idHelperSvc()->stgcIdHelper().is_muon(offId) ){
85 <<
" " <<
idHelperSvc()->stgcIdHelper().is_tgc(offId) <<
" " <<
idHelperSvc()->stgcIdHelper().is_csc(offId) <<
" " <<
idHelperSvc()->stgcIdHelper().is_mm(offId) );
92 int barcode = hit.particleLink().barcode();
102 const Amg::Vector3D& globalDirection = hit.globalDirection();
109 const Amg::Vector3D& globalPrePosition = hit.globalPrePosition();
111 if (hit.kineticEnergy() < 0.0) {
131 double scale = -rSurface_pos.z()/ldir.z();
140 int stripNumber = detEl->
stripNumber(posOnSurf,newId);
141 if( stripNumber == -1 ){
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 );
155 ATH_MSG_WARNING(
"sTGC validation: failed to obtain local position for identifier " <<
idHelperSvc()->stgcIdHelper().print_to_string(offId) );
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 );
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() );
◆ getDetMgr()
◆ 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.
◆ 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.
◆ 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.
◆ 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
-
lvl | The message level to test against |
- Returns
- boolean Indicating if messages at given level will be printed
- Return values
-
true | Messages at level "lvl" will be printed |
Definition at line 151 of file AthMessaging.h.
◆ name()
std::string MuonVal::MuonTesterBranch::name |
( |
| ) |
const |
|
finaloverridevirtualinherited |
◆ parent()
◆ setLevel()
void AthMessaging::setLevel |
( |
MSG::Level |
lvl | ) |
|
|
inherited |
◆ tree() [1/2]
const TTree * MuonVal::MuonTesterBranch::tree |
( |
| ) |
const |
|
finaloverridevirtualinherited |
◆ tree() [2/2]
TTree * MuonVal::MuonTesterBranch::tree |
( |
| ) |
|
|
finaloverridevirtualinherited |
◆ ATLAS_THREAD_SAFE
std::atomic_flag m_initialized AthMessaging::ATLAS_THREAD_SAFE = ATOMIC_FLAG_INIT |
|
mutableprivateinherited |
◆ m_dependencies
std::vector<DataDependency> MuonVal::MuonTesterBranch::m_dependencies {} |
|
privateinherited |
◆ m_detMgrKey
◆ m_idHelperSvc
◆ m_imsg
std::atomic<IMessageSvc*> AthMessaging::m_imsg { nullptr } |
|
mutableprivateinherited |
◆ m_init
bool MuonVal::MuonTesterBranch::m_init {false} |
|
privateinherited |
◆ m_key
◆ m_lvl
std::atomic<MSG::Level> AthMessaging::m_lvl { MSG::NIL } |
|
mutableprivateinherited |
◆ 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 |
◆ m_nm
std::string AthMessaging::m_nm |
|
privateinherited |
◆ m_NSWsTGC_depositEnergy
VectorBranch<float>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_depositEnergy {parent().newVector<float>("Hits_sTGC_depositEnergy")} |
|
private |
◆ m_NSWsTGC_detector_globalPosition
ThreeVectorBranch MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_detector_globalPosition {parent(), "Hits_sTGC_detector_globalPosition"} |
|
private |
◆ m_NSWsTGC_detectorNumber
VectorBranch<int>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_detectorNumber {parent().newVector<int>("Hits_sTGC_detectorNumber")} |
|
private |
◆ m_NSWsTGC_FastDigitRsurfacePositionX
VectorBranch<float>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_FastDigitRsurfacePositionX {parent().newVector<float>("Hits_sTGC_FastDigitRsurfacePositionX")} |
|
private |
◆ m_NSWsTGC_FastDigitRsurfacePositionY
VectorBranch<float>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_FastDigitRsurfacePositionY {parent().newVector<float>("Hits_sTGC_FastDigitRsurfacePositionY")} |
|
private |
◆ m_NSWsTGC_globalTime
VectorBranch<float>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_globalTime {parent().newVector<float>("Hits_sTGC_globalTime")} |
|
private |
◆ m_NSWsTGC_hitGlobalDirection
ThreeVectorBranch MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_hitGlobalDirection {parent(), "Hits_sTGC_GlobalDirection"} |
|
private |
◆ m_NSWsTGC_hitGlobalPosition
ThreeVectorBranch MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_hitGlobalPosition {parent(), "Hits_sTGC_GlobalPosition"} |
|
private |
◆ m_NSWsTGC_hitGlobalPrePosition
ThreeVectorBranch MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_hitGlobalPrePosition {parent(), "Hits_sTGC_GlobalPrePosition"} |
|
private |
◆ m_NSWsTGC_hitToDsurfacePosition
ThreeVectorBranch MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_hitToDsurfacePosition {parent(), "Hits_sTGC_hitToDsurfacePosition"} |
|
private |
◆ m_NSWsTGC_hitToRsurfacePosition
ThreeVectorBranch MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_hitToRsurfacePosition {parent(), "Hits_sTGC_hitToRsurfacePosition"} |
|
private |
◆ m_NSWsTGC_Id
◆ m_NSWsTGC_isInsideBounds
VectorBranch<bool>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_isInsideBounds {parent().newVector<bool>("Hits_sTGC_isInsideBounds")} |
|
private |
◆ m_NSWsTGC_kineticEnergy
VectorBranch<float>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_kineticEnergy {parent().newVector<float>("Hits_sTGC_kineticEnergy")} |
|
private |
◆ m_NSWsTGC_nSimHits
ScalarBranch<unsigned int>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_nSimHits {parent().newScalar<unsigned int>("Hits_sTGC_nHits")} |
|
private |
◆ m_NSWsTGC_particleEncoding
VectorBranch<int>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_particleEncoding {parent().newVector<int>("Hits_sTGC_particleEncoding")} |
|
private |
◆ m_NSWsTGC_stripNumber
VectorBranch<int>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_stripNumber {parent().newVector<int>("Hits_sTGC_stripNumber")} |
|
private |
◆ m_NSWsTGC_trackId
VectorBranch<int>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_trackId {parent().newVector<int>("Hits_sTGC_trackId")} |
|
private |
◆ m_NSWsTGC_wedgeId
VectorBranch<int>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_wedgeId {parent().newVector<int>("Hits_sTGC_wedgeId")} |
|
private |
◆ m_NSWsTGC_wedgeType
VectorBranch<int>& MuonPRDTest::sTGCSimHitVariables::m_NSWsTGC_wedgeType {parent().newVector<int>("Hits_sTGC_wedgeType")} |
|
private |
◆ m_parent
◆ m_tree
TTree* MuonVal::MuonTesterBranch::m_tree {nullptr} |
|
privateinherited |
The documentation for this class was generated from the following files:
std::atomic< MSG::Level > m_lvl
Current logging level.
SG::ReadHandleKey< sTGCSimHitCollection > m_key
int GetSide(const int &hid) const
constexpr uint8_t stationPhi
station Phi 1 to 8
virtual const sTgcIdHelper & stgcIdHelper() const =0
access to TgcIdHelper
const Amg::Transform3D & absTransform() const
VectorBranch< int > & m_NSWsTGC_trackId
VectorBranch< float > & m_NSWsTGC_FastDigitRsurfacePositionY
Eigen::Matrix< double, 2, 1 > Vector2D
Identifier channelID(int stationName, int stationEta, int stationPhi, int multilayer, int gasGap, int channelType, int channel) const
ThreeVectorBranch m_NSWsTGC_detector_globalPosition
VectorBranch< int > & m_NSWsTGC_wedgeId
static const sTgcHitIdHelper * GetHelper()
std::vector< DataDependency > m_dependencies
VectorBranch< int > & m_NSWsTGC_detectorNumber
const MuonGM::MuonDetectorManager * getDetMgr(const EventContext &ctx) const
void push_back(const Identifier &id) override final
VectorBranch< bool > & m_NSWsTGC_isInsideBounds
const Amg::Vector3D & center() const
Returns the center position of the Surface.
std::atomic< IMessageSvc * > m_imsg
MessageSvc pointer.
virtual const Trk::PlaneSurface & surface() const override
access to chamber surface (phi orientation), uses the first gas gap
IMessageSvc * getMessageSvc(bool quiet=false)
TTree * tree() override final
Returns the underlying TTree object.
MuonTesterTree * m_parent
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...
bool declare_dependency(Key &key)
Declares the ReadHandle/ ReadCondHandleKey as data dependency of the algorithm.
void push_back(const Amg::Vector3D &vec)
interface using the Amg::Vector3D
VectorBranch< float > & m_NSWsTGC_globalTime
virtual bool insideBounds(const Amg::Vector2D &locpos, double tol1=0., double tol2=0.) const override
This method calls the inside() method of the Bounds.
int GetMultiLayer(const int &hid) const
VectorBranch< float > & m_NSWsTGC_kineticEnergy
int channel(const Identifier &id) const override
int GetLayer(const int &hid) const
An sTgcReadoutElement corresponds to a single STGC module; therefore typicaly a barrel muon station c...
Eigen::Affine3d Transform3D
ThreeVectorBranch m_NSWsTGC_hitGlobalDirection
VectorBranch< int > & m_NSWsTGC_wedgeType
const Amg::Vector3D globalPosition() const
ServiceHandle< Muon::IMuonIdHelperSvc > m_idHelperSvc
MsgStream & msg() const
The standard message stream.
std::string name() const override final
Returns the name of the branch.
void push_back(const T &value)
Adds a new element at the end of the vector.
const std::string & stationNameString(const int &index) const
sTgcIdentifierBranch m_NSWsTGC_Id
ThreeVectorBranch m_NSWsTGC_hitGlobalPosition
PrdTesterModule(MuonTesterTree &tree, const std::string &grp_name, MSG::Level msglvl)
virtual bool declare_keys()=0
ThreeVectorBranch m_NSWsTGC_hitGlobalPrePosition
std::string GetStationName(const int &hid) const
SG::ReadCondHandleKey< MuonGM::MuonDetectorManager > m_detMgrKey
Eigen::Matrix< double, 3, 1 > Vector3D
int GetZSector(const int &hid) const
virtual int stripNumber(const Amg::Vector2D &pos, const Identifier &id) const override final
strip number corresponding to local position.
ThreeVectorBranch m_NSWsTGC_hitToRsurfacePosition
The MuonDetectorManager stores the transient representation of the Muon Spectrometer geometry and pro...
#define ATH_MSG_WARNING(x)
VectorBranch< float > & m_NSWsTGC_depositEnergy
std::string m_nm
Message source name.
const Muon::IMuonIdHelperSvc * idHelperSvc() const
VectorBranch< int > & m_NSWsTGC_stripNumber
int atoi(std::string_view str)
Helper functions to unpack numbers decoded in string into integers and doubles The strings are requir...
const sTgcReadoutElement * getsTgcReadoutElement(const Identifier &id) const
access via extended identifier (requires unpacking)
void initMessaging() const
Initialize our message level and MessageSvc.
constexpr uint8_t stationEta
1 to 3
VectorBranch< float > & m_NSWsTGC_FastDigitRsurfacePositionX
boost::thread_specific_ptr< MsgStream > m_msg_tls
MsgStream instance (a std::cout like with print-out levels)
const Amg::Transform3D & transform() const
Returns HepGeom::Transform3D by reference.
VectorBranch< int > & m_NSWsTGC_particleEncoding
int GetPhiSector(const int &hid) const
ScalarBranch< unsigned int > & m_NSWsTGC_nSimHits
ThreeVectorBranch m_NSWsTGC_hitToDsurfacePosition