Loading [MathJax]/extensions/tex2jax.js
 |
ATLAS Offline Software
|
#include <MMSimHitVariables.h>
|
| 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. 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 MMSimHitVariables.h.
◆ DataDependency
◆ MMSimHitVariables()
MuonPRDTest::MMSimHitVariables::MMSimHitVariables |
( |
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::MMSimHitVariables::declare_keys |
( |
| ) |
|
|
finaloverridevirtual |
◆ eraseWhiteSpaces()
std::string MuonVal::MuonTesterBranch::eraseWhiteSpaces |
( |
const std::string & |
In | ) |
|
|
staticinherited |
◆ 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.
18 if (!mmContainer.isValid()) {
23 if (!MuonDetMgr) {
return false; }
24 unsigned int n_hits{0};
27 if (!mmContainer->size())
ATH_MSG_DEBUG(
"MM Sim container is empty");
28 for (
const MMSimHit& hit : *mmContainer) {
29 int simId = hit.MMId();
31 if(hit.depositEnergy()==0.)
continue;
34 int barcode = hit.particleLink().barcode();
56 ATH_MSG_ERROR(
"MicroMegas validation: unexpected phi range " << stphi);
61 side == 1 ? steta+1 : -steta-1,
62 (stphi-1)/2+1,multilayer,
layer,1 );
80 int isSmall = stname[2] ==
'S';
86 ATH_MSG_ERROR(
"MMSimHitVariables::fillVariables() - Failed to retrieve MMReadoutElement for "<<
idHelperSvc()->mmIdHelper().print_to_string(offId).c_str());
94 Amg::Vector3D hpos(hit.globalPosition().x(),hit.globalPosition().y(),hit.globalPosition().z());
100 Amg::Vector2D posOnSurfUnProjected(rSurface_pos.x(),rSurface_pos.y());
104 ldir = surf.
transform().inverse().linear()*
Amg::Vector3D(hit.globalDirection().x(), hit.globalDirection().y(), hit.globalDirection().z());
106 double scale, scaletop;
109 scale = -rSurface_pos.z()/ldir.z();
110 scaletop = (gasgap+rSurface_pos.z())/ldir.z();
113 Amg::Vector3D hitOnTopSurface = rSurface_pos + scaletop*ldir;
114 Amg::Vector2D posOnSurf (hitOnSurface.x(), hitOnSurface.y());
115 Amg::Vector2D posOnTopSurf (hitOnTopSurface.x(),hitOnTopSurface.y());
118 int stripNumber = detEl->
stripNumber(posOnSurf,offId);
123 if( stripNumber == -1 ){
124 ATH_MSG_WARNING(
"MicroMegas validation: failed to obtain strip number " <<
idHelperSvc()->mmIdHelper().print_to_string(offId) );
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 );
138 ATH_MSG_WARNING(
"MicroMegas validation: failed to obtain local position for identifier " <<
idHelperSvc()->mmIdHelper().print_to_string(offId) );
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() );
◆ 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_NSWMM_depositEnergy
VectorBranch<float>& MuonPRDTest::MMSimHitVariables::m_NSWMM_depositEnergy {parent().newVector<float>("Hits_MM_depositEnergy")} |
|
private |
◆ m_NSWMM_detector_globalPosition
ThreeVectorBranch MuonPRDTest::MMSimHitVariables::m_NSWMM_detector_globalPosition {parent(), "Hits_MM_detector_globalPosition"} |
|
private |
◆ m_NSWMM_FastDigitRsurfacePositionX
VectorBranch<float>& MuonPRDTest::MMSimHitVariables::m_NSWMM_FastDigitRsurfacePositionX {parent().newVector<float>("Hits_MM_FastDigitRsurfacePositionX")} |
|
private |
◆ m_NSWMM_FastDigitRsurfacePositionY
VectorBranch<float>& MuonPRDTest::MMSimHitVariables::m_NSWMM_FastDigitRsurfacePositionY {parent().newVector<float>("Hits_MM_FastDigitRsurfacePositionY")} |
|
private |
◆ m_NSWMM_globalTime
VectorBranch<float>& MuonPRDTest::MMSimHitVariables::m_NSWMM_globalTime {parent().newVector<float>("Hits_MM_globalTime")} |
|
private |
◆ m_NSWMM_hitGlobalDirection
◆ m_NSWMM_hitGlobalPosition
◆ m_NSWMM_hitToDsurfacePosition
ThreeVectorBranch MuonPRDTest::MMSimHitVariables::m_NSWMM_hitToDsurfacePosition {parent(), "Hits_MM_hitToDsurfacePosition"} |
|
private |
◆ m_NSWMM_hitToRsurfacePosition
ThreeVectorBranch MuonPRDTest::MMSimHitVariables::m_NSWMM_hitToRsurfacePosition {parent(), "Hits_MM_hitToRsurfacePosition"} |
|
private |
◆ m_NSWMM_Id
◆ m_NSWMM_isInsideBounds
VectorBranch<bool>& MuonPRDTest::MMSimHitVariables::m_NSWMM_isInsideBounds {parent().newVector<bool>("Hits_MM_isInsideBounds")} |
|
private |
◆ m_NSWMM_kineticEnergy
VectorBranch<float>& MuonPRDTest::MMSimHitVariables::m_NSWMM_kineticEnergy {parent().newVector<float>("Hits_MM_kineticEnergy")} |
|
private |
◆ m_NSWMM_nSimHits
ScalarBranch<unsigned int>& MuonPRDTest::MMSimHitVariables::m_NSWMM_nSimHits {parent().newScalar<unsigned int>("Hits_MM_nHits")} |
|
private |
◆ m_NSWMM_particleEncoding
VectorBranch<int>& MuonPRDTest::MMSimHitVariables::m_NSWMM_particleEncoding {parent().newVector<int>("Hits_MM_particleEncoding")} |
|
private |
◆ m_NSWMM_trackId
VectorBranch<int>& MuonPRDTest::MMSimHitVariables::m_NSWMM_trackId {parent().newVector<int>("Hits_MM_trackId")} |
|
private |
◆ m_parent
◆ m_tree
TTree* MuonVal::MuonTesterBranch::m_tree {nullptr} |
|
privateinherited |
The documentation for this class was generated from the following files:
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,...
std::atomic< MSG::Level > m_lvl
Current logging level.
int GetSide(const int &hid) const
constexpr uint8_t stationPhi
station Phi 1 to 8
std::string GetStationName(const int &hid) const
int GetMultiLayer(const int &hid) const
const Amg::Transform3D & absTransform() const
ThreeVectorBranch m_NSWMM_hitGlobalPosition
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
ThreeVectorBranch m_NSWMM_detector_globalPosition
ScalarBranch< unsigned int > & m_NSWMM_nSimHits
Eigen::Matrix< double, 2, 1 > Vector2D
VectorBranch< float > & m_NSWMM_FastDigitRsurfacePositionX
std::vector< DataDependency > m_dependencies
const MuonGM::MuonDetectorManager * getDetMgr(const EventContext &ctx) const
VectorBranch< float > & m_NSWMM_globalTime
void push_back(const Identifier &id) override final
int GetZSector(const int &hid) const
int GetLayer(const int &hid) const
const Amg::Vector3D & center() const
Returns the center position of the Surface.
virtual const MmIdHelper & mmIdHelper() const =0
access to CscIdHelper
VectorBranch< int > & m_NSWMM_particleEncoding
ThreeVectorBranch m_NSWMM_hitToRsurfacePosition
VectorBranch< float > & m_NSWMM_kineticEnergy
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
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
ThreeVectorBranch m_NSWMM_hitToDsurfacePosition
Eigen::Affine3d Transform3D
MmIdentifierBranch m_NSWMM_Id
VectorBranch< float > & m_NSWMM_FastDigitRsurfacePositionY
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.
VectorBranch< int > & m_NSWMM_trackId
int GetPhiSector(const int &hid) const
VectorBranch< bool > & m_NSWMM_isInsideBounds
PrdTesterModule(MuonTesterTree &tree, const std::string &grp_name, MSG::Level msglvl)
virtual bool declare_keys()=0
ThreeVectorBranch m_NSWMM_hitGlobalDirection
SG::ReadCondHandleKey< MuonGM::MuonDetectorManager > m_detMgrKey
Eigen::Matrix< double, 3, 1 > Vector3D
static const MicromegasHitIdHelper * GetHelper()
SG::ReadHandleKey< MMSimHitCollection > m_key
The MuonDetectorManager stores the transient representation of the Muon Spectrometer geometry and pro...
#define ATH_MSG_WARNING(x)
virtual int stripNumber(const Amg::Vector2D &pos, const Identifier &id) const override final
strip number corresponding to local position.
std::string m_nm
Message source name.
const MMReadoutElement * getMMReadoutElement(const Identifier &id) const
access via extended identifier (requires unpacking)
const Muon::IMuonIdHelperSvc * idHelperSvc() const
An MMReadoutElement corresponds to a single STGC module; therefore typicaly a barrel muon station con...
void initMessaging() const
Initialize our message level and MessageSvc.
constexpr uint8_t stationEta
1 to 3
boost::thread_specific_ptr< MsgStream > m_msg_tls
MsgStream instance (a std::cout like with print-out levels)
Identifier channelID(int stationName, int stationEta, int stationPhi, int multilayer, int gasGap, int channel) const
const Amg::Transform3D & transform() const
Returns HepGeom::Transform3D by reference.
VectorBranch< float > & m_NSWMM_depositEnergy