ATLAS Offline Software
Loading...
Searching...
No Matches
xAOD::ICandData_v1 Class Reference

base class providing a common interface with shared variables for the L0 muon candidates from RPC/TGC SL to MDT-TP More...

#include <ICandData_v1.h>

Inheritance diagram for xAOD::ICandData_v1:
Collaboration diagram for xAOD::ICandData_v1:

Public Types

enum class  BC_ID {
  BC_UNDEFINED = 0 , BC_PREVIOUS , BC_CURRENT , BC_NEXT ,
  BC_NEXTNEXT
}
 Bunch crossing identifier. More...
enum class  Quality : uint8_t { Q_UNDEFINED = 0 , Q_BEST , Q_LOW }

Public Member Functions

 ICandData_v1 ()=default
 Default constructor.
virtual ~ICandData_v1 ()=default
uint16_t subdetectorId () const
 Retrieve the sub detector id.
uint16_t sectorId () const
 Retrieve the sector id.
uint16_t bcTag () const
 Retrieve the bunch crossing tag.
uint8_t threshold () const
 Retrieve the threshold.
uint8_t candCharge () const
 Retrieve the candidate charge.
uint8_t mdtFlag () const
 Retrieve the MDT flag.
uint8_t coinType () const
 Retrieve the coincidence type.
uint16_t eta () const
 Retrieve the eta.
uint16_t phi () const
 Retrieve the phi.
uint8_t pt () const
 Retrieve the pt.
Quality candQuality () const
 Retrieve the candidate quality.
void setSubdetectorId (uint16_t subdetectorId)
 Set the sub detector id.
void setSectorId (uint16_t sectorId)
 Set the sector id.
void setBcTag (uint16_t bcTag)
 Set the bunch crossing tag.
void setEta (float eta)
 Set the eta.
void setPhi (float phi)
 Set the phi.
void setPt (float pt)
 Set the pt.
void setThreshold (uint8_t threshold)
 Set the threshold.
void setCandCharge (uint8_t candCharge)
 Set the candidate charge.
void setMdtFlag (uint8_t mdtFlag)
 Set the MDT flag.
void setCoinType (uint8_t coinType)
 Set the coincidence type.
void setCandQuality (Quality candQuality)
 Set the candidate quality.
void initialize (uint16_t subdetectorId, uint16_t sectorId, uint16_t bcTag)
 Initialize candidate with basic properties.

Static Public Member Functions

static constexpr float etaRange ()
static constexpr uint16_t etaBitRange ()
static constexpr float phiRange ()
static constexpr uint16_t phiBitRange ()
static constexpr float ptRange ()
static constexpr uint8_t ptBitRange ()
static constexpr uint8_t coinTypeBitMask ()

Static Protected Attributes

static constexpr float s_etaRange = 2.7
 Variables range.
static constexpr float s_phiRange = 2.0 * M_PI
static constexpr float s_ptRange = 1000.0
static constexpr uint16_t s_etaBitRange = 0x3fff
 Variables bit size 14 bits for eta, 9 bits for phi, 8 bits for pt.
static constexpr uint16_t s_phiBitRange = 0x1ff
static constexpr uint8_t s_ptBitRange = 0xff
static constexpr uint8_t COINTYPE_BIT_MASK = 0x7
 Bit mask for Coincidence Types.

Detailed Description

base class providing a common interface with shared variables for the L0 muon candidates from RPC/TGC SL to MDT-TP

Definition at line 18 of file ICandData_v1.h.

Member Enumeration Documentation

◆ BC_ID

enum class xAOD::ICandData_v1::BC_ID
strong

Bunch crossing identifier.

Enumerator
BC_UNDEFINED 
BC_PREVIOUS 
BC_CURRENT 
BC_NEXT 
BC_NEXTNEXT 

Definition at line 27 of file ICandData_v1.h.

28 {
29 BC_UNDEFINED = 0,
30 BC_PREVIOUS,
31 BC_CURRENT,
32 BC_NEXT,
33 BC_NEXTNEXT
34 };

◆ Quality

enum class xAOD::ICandData_v1::Quality : uint8_t
strong
Enumerator
Q_UNDEFINED 
Q_BEST 
Q_LOW 

Definition at line 36 of file ICandData_v1.h.

37 {
38 Q_UNDEFINED = 0,
39 Q_BEST,
40 Q_LOW
41 };

Constructor & Destructor Documentation

◆ ICandData_v1()

xAOD::ICandData_v1::ICandData_v1 ( )
default

Default constructor.

◆ ~ICandData_v1()

virtual xAOD::ICandData_v1::~ICandData_v1 ( )
virtualdefault

Member Function Documentation

◆ bcTag()

uint16_t xAOD::ICandData_v1::bcTag ( ) const

Retrieve the bunch crossing tag.

Returns
Bunch crossing tag

◆ candCharge()

uint8_t xAOD::ICandData_v1::candCharge ( ) const

Retrieve the candidate charge.

Returns
Candidate charge

◆ candQuality()

Quality xAOD::ICandData_v1::candQuality ( ) const

Retrieve the candidate quality.

Returns
Candidate quality

◆ coinType()

uint8_t xAOD::ICandData_v1::coinType ( ) const

Retrieve the coincidence type.

Returns
Coincidence type

Definition at line 69 of file ICandData_v1.cxx.

69 {
70 static const SG::AuxElement::Accessor<uint8_t> acc(preFixStr + "coinType");
71 return acc(*this);
72 }
static const SG::AuxElement::Accessor< ElementLink< IParticleContainer > > acc("originalObjectLink")
Object used for setting/getting the dynamic decoration in question.

◆ coinTypeBitMask()

constexpr uint8_t xAOD::ICandData_v1::coinTypeBitMask ( )
inlinestaticconstexpr

Definition at line 175 of file ICandData_v1.h.

175{ return COINTYPE_BIT_MASK; }
static constexpr uint8_t COINTYPE_BIT_MASK
Bit mask for Coincidence Types.

◆ eta()

uint16_t xAOD::ICandData_v1::eta ( ) const

Retrieve the eta.

Returns
Eta

Definition at line 33 of file ICandData_v1.cxx.

33 {
34 static const SG::AuxElement::Accessor<uint16_t> acc(preFixStr + "eta");
35 return acc(*this);
36 }

◆ etaBitRange()

constexpr uint16_t xAOD::ICandData_v1::etaBitRange ( )
inlinestaticconstexpr

Definition at line 170 of file ICandData_v1.h.

170{ return s_etaBitRange; }
static constexpr uint16_t s_etaBitRange
Variables bit size 14 bits for eta, 9 bits for phi, 8 bits for pt.

◆ etaRange()

constexpr float xAOD::ICandData_v1::etaRange ( )
inlinestaticconstexpr

Definition at line 169 of file ICandData_v1.h.

169{ return s_etaRange; }
static constexpr float s_etaRange
Variables range.

◆ initialize()

void xAOD::ICandData_v1::initialize ( uint16_t subdetectorId,
uint16_t sectorId,
uint16_t bcTag )

Initialize candidate with basic properties.

Initialise the object given some input data

Parameters
subdetectorIdSubdetector ID
sectorIdSector ID
bcTagBunch crossing tag

Definition at line 74 of file ICandData_v1.cxx.

74 {
78 }
void setBcTag(uint16_t bcTag)
Set the bunch crossing tag.
uint16_t sectorId() const
Retrieve the sector id.
uint16_t bcTag() const
Retrieve the bunch crossing tag.
void setSubdetectorId(uint16_t subdetectorId)
Set the sub detector id.
uint16_t subdetectorId() const
Retrieve the sub detector id.
void setSectorId(uint16_t sectorId)
Set the sector id.

◆ mdtFlag()

uint8_t xAOD::ICandData_v1::mdtFlag ( ) const

Retrieve the MDT flag.

Returns
MDT flag

◆ phi()

uint16_t xAOD::ICandData_v1::phi ( ) const

Retrieve the phi.

Returns
Phi

Definition at line 44 of file ICandData_v1.cxx.

44 {
45 static const SG::AuxElement::Accessor<uint16_t> acc(preFixStr + "phi");
46 //return (static_cast<float>(acc(*this)) / static_cast<float>(s_phiBitRange)) * s_phiRange-M_PI;
47 return acc(*this);
48 }

◆ phiBitRange()

constexpr uint16_t xAOD::ICandData_v1::phiBitRange ( )
inlinestaticconstexpr

Definition at line 172 of file ICandData_v1.h.

172{ return s_phiBitRange; }
static constexpr uint16_t s_phiBitRange

◆ phiRange()

constexpr float xAOD::ICandData_v1::phiRange ( )
inlinestaticconstexpr

Definition at line 171 of file ICandData_v1.h.

171{ return s_phiRange; }
static constexpr float s_phiRange

◆ pt()

uint8_t xAOD::ICandData_v1::pt ( ) const

Retrieve the pt.

Returns
Pt

Definition at line 58 of file ICandData_v1.cxx.

58 {
59 static const SG::AuxElement::Accessor<uint8_t> acc(preFixStr + "pt");
60 return acc(*this);
61 }

◆ ptBitRange()

constexpr uint8_t xAOD::ICandData_v1::ptBitRange ( )
inlinestaticconstexpr

Definition at line 174 of file ICandData_v1.h.

174{ return s_ptBitRange; }
static constexpr uint8_t s_ptBitRange

◆ ptRange()

constexpr float xAOD::ICandData_v1::ptRange ( )
inlinestaticconstexpr

Definition at line 173 of file ICandData_v1.h.

173{ return s_ptRange; }
static constexpr float s_ptRange

◆ sectorId()

uint16_t xAOD::ICandData_v1::sectorId ( ) const

Retrieve the sector id.

Returns
Sector ID

◆ setBcTag()

void xAOD::ICandData_v1::setBcTag ( uint16_t bcTag)

Set the bunch crossing tag.

Parameters
bcTagBunch crossing tag

◆ setCandCharge()

void xAOD::ICandData_v1::setCandCharge ( uint8_t candCharge)

Set the candidate charge.

Parameters
candChargeCandidate charge

◆ setCandQuality()

void xAOD::ICandData_v1::setCandQuality ( Quality candQuality)

Set the candidate quality.

Parameters
candQualityCandidate quality

◆ setCoinType()

void xAOD::ICandData_v1::setCoinType ( uint8_t coinType)

Set the coincidence type.

Parameters
coinTypeCoincidence type

Definition at line 63 of file ICandData_v1.cxx.

63 {
64 uint8_t coinTypeBin = cointype & COINTYPE_BIT_MASK;
65 static const SG::AuxElement::Accessor<uint8_t> acc(preFixStr + "coinType");
66 acc(*this) = coinTypeBin;
67 }

◆ setEta()

void xAOD::ICandData_v1::setEta ( float eta)

Set the eta.

Parameters
etaEta

Definition at line 26 of file ICandData_v1.cxx.

26 {
27 float etaClamped = std::clamp(eta, -s_etaRange, s_etaRange);
28 uint16_t etaBinary = static_cast<uint16_t>(std::lround((etaClamped + s_etaRange) / (2.0f * s_etaRange) * static_cast<float>(s_etaBitRange)));
29 static const SG::AuxElement::Accessor<uint16_t> acc(preFixStr + "eta");
30 acc(*this) = etaBinary;
31 }
uint16_t eta() const
Retrieve the eta.
setWord1 uint16_t

◆ setMdtFlag()

void xAOD::ICandData_v1::setMdtFlag ( uint8_t mdtFlag)

Set the MDT flag.

Parameters
mdtFlagMDT flag

◆ setPhi()

void xAOD::ICandData_v1::setPhi ( float phi)

Set the phi.

Parameters
phiPhi

Definition at line 38 of file ICandData_v1.cxx.

38 {
39 uint16_t phiBinary = static_cast<uint16_t>(((phi + M_PI) / s_phiRange) * static_cast<float>(s_phiBitRange));
40 static const SG::AuxElement::Accessor<uint16_t> acc(preFixStr + "phi");
41 acc(*this) = phiBinary;
42 }
#define M_PI
uint16_t phi() const
Retrieve the phi.

◆ setPt()

void xAOD::ICandData_v1::setPt ( float pt)

Set the pt.

Parameters
ptPt

Definition at line 50 of file ICandData_v1.cxx.

50 {
51 const float ptClamped = std::clamp(pt, 0.0f, s_ptRange);
52 const uint8_t ptBinary = static_cast<uint8_t>(
53 std::lround((ptClamped / s_ptRange) * static_cast<float>(s_ptBitRange)));
54 static const SG::AuxElement::Accessor<uint8_t> acc(preFixStr + "pt");
55 acc(*this) = ptBinary;
56 }
uint8_t pt() const
Retrieve the pt.

◆ setSectorId()

void xAOD::ICandData_v1::setSectorId ( uint16_t sectorId)

Set the sector id.

Parameters
sectorIdSector ID

◆ setSubdetectorId()

void xAOD::ICandData_v1::setSubdetectorId ( uint16_t subdetectorId)

Set the sub detector id.

Parameters
subdetectorIdSubdetector ID

◆ setThreshold()

void xAOD::ICandData_v1::setThreshold ( uint8_t threshold)

Set the threshold.

Parameters
thresholdThreshold

◆ subdetectorId()

uint16_t xAOD::ICandData_v1::subdetectorId ( ) const

Retrieve the sub detector id.

Returns
Subdetector ID

◆ threshold()

uint8_t xAOD::ICandData_v1::threshold ( ) const

Retrieve the threshold.

Returns
Threshold

Member Data Documentation

◆ COINTYPE_BIT_MASK

uint8_t xAOD::ICandData_v1::COINTYPE_BIT_MASK = 0x7
staticconstexprprotected

Bit mask for Coincidence Types.

Definition at line 190 of file ICandData_v1.h.

◆ s_etaBitRange

uint16_t xAOD::ICandData_v1::s_etaBitRange = 0x3fff
staticconstexprprotected

Variables bit size 14 bits for eta, 9 bits for phi, 8 bits for pt.

Definition at line 185 of file ICandData_v1.h.

◆ s_etaRange

float xAOD::ICandData_v1::s_etaRange = 2.7
staticconstexprprotected

Variables range.

Definition at line 179 of file ICandData_v1.h.

◆ s_phiBitRange

uint16_t xAOD::ICandData_v1::s_phiBitRange = 0x1ff
staticconstexprprotected

Definition at line 186 of file ICandData_v1.h.

◆ s_phiRange

float xAOD::ICandData_v1::s_phiRange = 2.0 * M_PI
staticconstexprprotected

Definition at line 180 of file ICandData_v1.h.

◆ s_ptBitRange

uint8_t xAOD::ICandData_v1::s_ptBitRange = 0xff
staticconstexprprotected

Definition at line 187 of file ICandData_v1.h.

◆ s_ptRange

float xAOD::ICandData_v1::s_ptRange = 1000.0
staticconstexprprotected

Definition at line 181 of file ICandData_v1.h.


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