ATLAS Offline Software
Loading...
Searching...
No Matches
MuonCalib::MdtTubeCalibContainer Class Reference

Holds single-tube calibration constants of one chamber. More...

#include <MdtTubeCalibContainer.h>

Inheritance diagram for MuonCalib::MdtTubeCalibContainer:
Collaboration diagram for MuonCalib::MdtTubeCalibContainer:

Classes

struct  SingleTubeCalib

Public Types

using SingleTubeCalibPtr = GeoModel::TransientConstSharedPtr<SingleTubeCalib>

Public Member Functions

 MdtTubeCalibContainer (const Muon::IMuonIdHelperSvc *idHelperSvc, const Identifier &moduleID)
 nMl = number of multilayres, nLayers = number of layers in multilayer (3 or 4); nTubes = number of tubes in one layer
const SingleTubeCalibgetCalib (const Identifier &tubeId) const
 return calibration constants of a single tube
bool setCalib (SingleTubeCalib val, const Identifier &tubeId, MsgStream &msg)
 set the calibration constants of a single tube
const Identifieridentify () const
 return container name and dimensions
unsigned int size () const
unsigned int numMultilayers () const
unsigned int numLayers () const
unsigned int numTubes () const
const Muon::IMuonIdHelperSvcidHelperSvc () const

Protected Member Functions

unsigned int vectorIndex (const Identifier &measID) const
 calculate postion of tube in vector

Protected Attributes

const Identifier m_moduleID {}
const Muon::IMuonIdHelperSvcm_idHelperSvc {nullptr}
const MdtIdHelperm_idHelper {m_idHelperSvc->mdtIdHelper()}
uint8_t m_nMl {0}
 number of multilayers in chamber
uint8_t m_nLayers {0}
 number of layer
uint8_t m_nTubes {0}
 number of tubes
std::vector< SingleTubeCalibm_data {}

Detailed Description

Holds single-tube calibration constants of one chamber.

Definition at line 17 of file MdtTubeCalibContainer.h.

Member Typedef Documentation

◆ SingleTubeCalibPtr

Constructor & Destructor Documentation

◆ MdtTubeCalibContainer()

MuonCalib::MdtTubeCalibContainer::MdtTubeCalibContainer ( const Muon::IMuonIdHelperSvc * idHelperSvc,
const Identifier & moduleID )

nMl = number of multilayres, nLayers = number of layers in multilayer (3 or 4); nTubes = number of tubes in one layer

Definition at line 6 of file MdtTubeCalibContainer.cxx.

7 :
8 m_moduleID{idHelperSvc->chamberId(moduleID)},
10
11 m_nMl = m_idHelper.numberOfMultilayers(moduleID);
12 const Identifier secondMl = m_idHelper.multilayerID(m_moduleID, m_nMl);
13 m_nLayers = std::max(m_idHelper.tubeLayerMax(m_moduleID),
14 m_idHelper.tubeLayerMax(secondMl));
15 m_nTubes = std::max(m_idHelper.tubeMax(m_moduleID),
16 m_idHelper.tubeMax(secondMl));
17 m_data.resize(m_nLayers * m_nTubes * m_nMl);
18}
std::vector< SingleTubeCalib > m_data
uint8_t m_nMl
number of multilayers in chamber
const Muon::IMuonIdHelperSvc * idHelperSvc() const
const Muon::IMuonIdHelperSvc * m_idHelperSvc

Member Function Documentation

◆ getCalib()

const SingleTubeCalib * MuonCalib::MdtTubeCalibContainer::getCalib ( const Identifier & tubeId) const
inline

return calibration constants of a single tube

Definition at line 35 of file MdtTubeCalibContainer.h.

35 {
36 unsigned int idx = vectorIndex(tubeId);
37 if (idx >= m_data.size()) return nullptr;
38 return &m_data[idx];
39 };
unsigned int vectorIndex(const Identifier &measID) const
calculate postion of tube in vector

◆ identify()

const Identifier & MuonCalib::MdtTubeCalibContainer::identify ( ) const
inline

return container name and dimensions

Definition at line 45 of file MdtTubeCalibContainer.h.

45{ return m_moduleID; }

◆ idHelperSvc()

const Muon::IMuonIdHelperSvc * MuonCalib::MdtTubeCalibContainer::idHelperSvc ( ) const

Definition at line 39 of file MdtTubeCalibContainer.cxx.

39 {
40 return m_idHelperSvc;
41}

◆ numLayers()

unsigned int MuonCalib::MdtTubeCalibContainer::numLayers ( ) const
inline

Definition at line 48 of file MdtTubeCalibContainer.h.

48{ return m_nLayers; }

◆ numMultilayers()

unsigned int MuonCalib::MdtTubeCalibContainer::numMultilayers ( ) const
inline

Definition at line 47 of file MdtTubeCalibContainer.h.

47{ return m_nMl; }

◆ numTubes()

unsigned int MuonCalib::MdtTubeCalibContainer::numTubes ( ) const
inline

Definition at line 49 of file MdtTubeCalibContainer.h.

49{ return m_nTubes; }

◆ setCalib()

bool MuonCalib::MdtTubeCalibContainer::setCalib ( SingleTubeCalib val,
const Identifier & tubeId,
MsgStream & msg )

set the calibration constants of a single tube

Make enough space for the calibration constants

Definition at line 19 of file MdtTubeCalibContainer.cxx.

19 {
21 const unsigned int index = vectorIndex(tubeId);
22 if (m_moduleID != m_idHelperSvc->chamberId(tubeId)) {
23 msg << MSG::ERROR<<__FILE__<<":"<<__LINE__<<" The channel "<<m_idHelperSvc->toString(tubeId)
24 <<" does not correspond to chamber "<<m_idHelperSvc->chamberNameString(tubeId) <<endmsg;
25 return false;
26 }
27 if (index >= m_data.size()) {
28 msg << MSG::WARNING<<__FILE__<<":"<<__LINE__<<" The channel "<<m_idHelperSvc->toString(tubeId)
29 <<"does not seem to match the anticipated chamber sizes of "
30 <<m_idHelperSvc->chamberNameString(m_moduleID)<<endmsg;
31 m_data.resize(index +1);
32 }
33 m_data[index] = std::move(val);
34 if (msg.level() <= MSG::VERBOSE) {
35 msg << MSG::VERBOSE<<" Succesfully stored calibration data for channel "<<m_idHelperSvc->toString(tubeId) << endmsg;
36 }
37 return true;
38}
#define endmsg
str index
Definition DeMoScan.py:362
MsgStream & msg
Definition testRead.cxx:32

◆ size()

unsigned int MuonCalib::MdtTubeCalibContainer::size ( ) const
inline

Definition at line 46 of file MdtTubeCalibContainer.h.

46{ return m_data.size(); }

◆ vectorIndex()

unsigned int MuonCalib::MdtTubeCalibContainer::vectorIndex ( const Identifier & measID) const
inlineprotected

calculate postion of tube in vector

Definition at line 59 of file MdtTubeCalibContainer.h.

59 {
60 return (m_idHelper.multilayer(measID) - 1) * (m_nLayers * m_nTubes) +
61 (m_idHelper.tubeLayer(measID) - 1) * m_nTubes +
62 (m_idHelper.tube(measID) -1);
63 }

Member Data Documentation

◆ m_data

std::vector<SingleTubeCalib> MuonCalib::MdtTubeCalibContainer::m_data {}
protected

Definition at line 67 of file MdtTubeCalibContainer.h.

67{};

◆ m_idHelper

const MdtIdHelper& MuonCalib::MdtTubeCalibContainer::m_idHelper {m_idHelperSvc->mdtIdHelper()}
protected

Definition at line 56 of file MdtTubeCalibContainer.h.

56{m_idHelperSvc->mdtIdHelper()};

◆ m_idHelperSvc

const Muon::IMuonIdHelperSvc* MuonCalib::MdtTubeCalibContainer::m_idHelperSvc {nullptr}
protected

Definition at line 55 of file MdtTubeCalibContainer.h.

55{nullptr};

◆ m_moduleID

const Identifier MuonCalib::MdtTubeCalibContainer::m_moduleID {}
protected

Definition at line 54 of file MdtTubeCalibContainer.h.

54{};

◆ m_nLayers

uint8_t MuonCalib::MdtTubeCalibContainer::m_nLayers {0}
protected

number of layer

Definition at line 65 of file MdtTubeCalibContainer.h.

65{0};

◆ m_nMl

uint8_t MuonCalib::MdtTubeCalibContainer::m_nMl {0}
protected

number of multilayers in chamber

Definition at line 64 of file MdtTubeCalibContainer.h.

64{0};

◆ m_nTubes

uint8_t MuonCalib::MdtTubeCalibContainer::m_nTubes {0}
protected

number of tubes

Definition at line 66 of file MdtTubeCalibContainer.h.

66{0};

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