ATLAS Offline Software
Public Member Functions | Private Types | Private Member Functions | Private Attributes | List of all members
Muon::DigitEffiData Class Reference

#include <DigitEffiData.h>

Inheritance diagram for Muon::DigitEffiData:
Collaboration diagram for Muon::DigitEffiData:

Public Member Functions

 DigitEffiData (const Muon::IMuonIdHelperSvc *idHelperSvc, double defaultEffi)
 Constructor taking the pointer to the IdHelperSvc & defining a default efficiency for cases wher the map doesn't know about the channel. More...
 
double getEfficiency (const Identifier &channelId, bool isInnerQ1=false) const
 Returns the signal generation efficiency of the sTgc channel. More...
 
StatusCode setEfficiency (const Identifier &sectionId, const double effi)
 Sets the efficiency for a given minimal section of the dector. 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...
 

Private Types

using EffiMap = std::unordered_map< Identifier, double >
 

Private Member Functions

Identifier getLookUpId (const Identifier &channelId, bool isInnerQ1=false) const
 
void initMessaging () const
 Initialize our message level and MessageSvc. More...
 

Private Attributes

const Muon::IMuonIdHelperSvcm_idHelperSvc {nullptr}
 
EffiMap m_effiData {}
 
double m_defaultEffi {1.}
 
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 23 of file DigitEffiData.h.

Member Typedef Documentation

◆ EffiMap

using Muon::DigitEffiData::EffiMap = std::unordered_map<Identifier, double>
private

Definition at line 35 of file DigitEffiData.h.

Constructor & Destructor Documentation

◆ DigitEffiData()

Muon::DigitEffiData::DigitEffiData ( const Muon::IMuonIdHelperSvc idHelperSvc,
double  defaultEffi 
)

Constructor taking the pointer to the IdHelperSvc & defining a default efficiency for cases wher the map doesn't know about the channel.

Definition at line 8 of file DigitEffiData.cxx.

8  :
9  AthMessaging{"DigitEffiData"},
10  m_idHelperSvc{idHelperSvc},
11  m_defaultEffi{defaultEffi}{}

Member Function Documentation

◆ getEfficiency()

double Muon::DigitEffiData::getEfficiency ( const Identifier channelId,
bool  isInnerQ1 = false 
) const

Returns the signal generation efficiency of the sTgc channel.

Definition at line 36 of file DigitEffiData.cxx.

36  {
37  EffiMap::const_iterator effi_itr = m_effiData.find(getLookUpId(channelId, isInnerQ1));
38  if (effi_itr != m_effiData.end()) {
39  ATH_MSG_VERBOSE("Channel "<<m_idHelperSvc->toString(channelId) <<" has an efficiency of "<<effi_itr->second);
40  return effi_itr->second;
41  }
42  ATH_MSG_VERBOSE("Efficiency of channel "<<m_idHelperSvc->toString(channelId)<<" is unknown. Return 1.");
43  return m_defaultEffi;
44  }

◆ getLookUpId()

Identifier Muon::DigitEffiData::getLookUpId ( const Identifier channelId,
bool  isInnerQ1 = false 
) const
private

Definition at line 13 of file DigitEffiData.cxx.

13  {
14  Identifier lookUpId{};
17  case TechIndex::MDT:
18  lookUpId = channelId;
19  break;
20  case TechIndex::RPC:
21  case TechIndex::TGC:
22  case TechIndex::CSCI:
23  lookUpId = m_idHelperSvc->gasGapId(channelId);
24  break;
25  case TechIndex::MM:
26  lookUpId = m_idHelperSvc->mmIdHelper().pcbID(channelId);
27  break;
28  case TechIndex::STGC:
29  lookUpId = m_idHelperSvc->stgcIdHelper().hvID(channelId, isInnerQ1);
30  break;
31  default:
32  THROW_EXCEPTION("Invalid muon technology");
33  };
34  return lookUpId;
35  }

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

◆ setEfficiency()

StatusCode Muon::DigitEffiData::setEfficiency ( const Identifier sectionId,
const double  effi 
)

Sets the efficiency for a given minimal section of the dector.

Definition at line 46 of file DigitEffiData.cxx.

46  {
47  const Identifier gasGapId = getLookUpId(channelId);
48  auto insert_itr = m_effiData.insert(std::make_pair(gasGapId, effi));
49  if (!insert_itr.second) {
50  ATH_MSG_ERROR("An efficiency for gasGap "<<m_idHelperSvc->toStringGasGap(gasGapId)
51  <<" has already been stored "<<m_effiData[gasGapId]<<" vs. "<<effi);
52  return StatusCode::FAILURE;
53  }
54  return StatusCode::SUCCESS;
55  }

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

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_defaultEffi

double Muon::DigitEffiData::m_defaultEffi {1.}
private

Definition at line 37 of file DigitEffiData.h.

◆ m_effiData

EffiMap Muon::DigitEffiData::m_effiData {}
private

Definition at line 36 of file DigitEffiData.h.

◆ m_idHelperSvc

const Muon::IMuonIdHelperSvc* Muon::DigitEffiData::m_idHelperSvc {nullptr}
private

Definition at line 34 of file DigitEffiData.h.

◆ m_imsg

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

MessageSvc pointer.

Definition at line 135 of file AthMessaging.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_nm

std::string AthMessaging::m_nm
privateinherited

Message source name.

Definition at line 129 of file AthMessaging.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
TGC
@ TGC
Definition: RegSelEnums.h:33
STGC
@ STGC
Definition: RegSelEnums.h:39
Muon::IMuonIdHelperSvc::stgcIdHelper
virtual const sTgcIdHelper & stgcIdHelper() const =0
access to TgcIdHelper
Muon::DigitEffiData::m_effiData
EffiMap m_effiData
Definition: DigitEffiData.h:36
MM
@ MM
Definition: RegSelEnums.h:38
Muon::DigitEffiData::m_idHelperSvc
const Muon::IMuonIdHelperSvc * m_idHelperSvc
Definition: DigitEffiData.h:34
ATH_MSG_VERBOSE
#define ATH_MSG_VERBOSE(x)
Definition: AthMsgStreamMacros.h:28
THROW_EXCEPTION
#define THROW_EXCEPTION(MSG)
Definition: MMReadoutElement.cxx:48
Muon::IMuonIdHelperSvc::mmIdHelper
virtual const MmIdHelper & mmIdHelper() const =0
access to CscIdHelper
AthMessaging::m_imsg
std::atomic< IMessageSvc * > m_imsg
MessageSvc pointer.
Definition: AthMessaging.h:135
python.SystemOfUnits.ms
int ms
Definition: SystemOfUnits.py:132
Athena::getMessageSvc
IMessageSvc * getMessageSvc(bool quiet=false)
Definition: getMessageSvc.cxx:20
sTgcDigitEffiDump.effi
list effi
Definition: sTgcDigitEffiDump.py:38
TrigConf::MSGTC::Level
Level
Definition: Trigger/TrigConfiguration/TrigConfBase/TrigConfBase/MsgStream.h:21
ATH_MSG_ERROR
#define ATH_MSG_ERROR(x)
Definition: AthMsgStreamMacros.h:33
Identifier
Definition: DetectorDescription/Identifier/Identifier/Identifier.h:32
Muon::DigitEffiData::getLookUpId
Identifier getLookUpId(const Identifier &channelId, bool isInnerQ1=false) const
Definition: DigitEffiData.cxx:13
Muon::IMuonIdHelperSvc::toStringGasGap
virtual std::string toStringGasGap(const Identifier &id) const =0
print all fields up to gas gap to string
AthMessaging
Class to provide easy MsgStream access and capabilities.
Definition: AthMessaging.h:55
CaloCondBlobAlgs_fillNoiseFromASCII.channelId
channelId
Definition: CaloCondBlobAlgs_fillNoiseFromASCII.py:122
AthMessaging::msg
MsgStream & msg() const
The standard message stream.
Definition: AthMessaging.h:164
Muon::IMuonIdHelperSvc::technologyIndex
virtual MuonStationIndex::TechnologyIndex technologyIndex(const Identifier &id) const =0
calculate layer index from Identifier
RPC
@ RPC
Definition: RegSelEnums.h:32
Muon::IMuonIdHelperSvc::gasGapId
virtual Identifier gasGapId(const Identifier &id) const =0
create a gasGap ID (will return layer Id for MDTs)
Muon::IMuonIdHelperSvc::toString
virtual std::string toString(const Identifier &id) const =0
print all fields to string
AthMessaging::m_nm
std::string m_nm
Message source name.
Definition: AthMessaging.h:129
MmIdHelper::pcbID
Identifier pcbID(int stationName, int stationEta, int stationPhi, int multilayer, int gasGap, int pcb) const
Definition: MmIdHelper.cxx:303
AthMessaging::initMessaging
void initMessaging() const
Initialize our message level and MessageSvc.
Definition: AthMessaging.cxx: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
sTgcIdHelper::hvID
Identifier hvID(int stationName, int stationEta, int stationPhi, int multilayer, int gasGap, bool isInnerQ1) const
Definition: sTgcIdHelper.cxx:338
Muon::DigitEffiData::m_defaultEffi
double m_defaultEffi
Definition: DigitEffiData.h:37
Muon::MuonStationIndex::TechnologyIndex
TechnologyIndex
enum to classify the different layers in the muon spectrometer
Definition: MuonStationIndex.h:54
MDT
@ MDT
Definition: RegSelEnums.h:31