CMS 3D CMS Logo

List of all members | Public Types | Public Member Functions | Static Public Member Functions | Static Public Attributes
TotemTimingDetId Class Reference

Detector ID class for CTPPS Totem Timing detectors. Bits [19:31] : Assigend in CTPPSDetId Calss Bits [17:18] : 2 bits for UFSD plane 0,1,2,3 Bits [12:16] : 5 bits for UFSD channel numbers 1,2,3,..16 Bits [0:11] : unspecified yet. More...

#include <TotemTimingDetId.h>

Inheritance diagram for TotemTimingDetId:
CTPPSDetId DetId

Public Types

enum  { ID_NOT_SET = 28 }
 
- Public Types inherited from CTPPSDetId
enum  NameFlag { nShort, nFull, nPath }
 type of name returned by *Name functions More...
 
enum  SubDetector { sdTrackingStrip = 3, sdTrackingPixel = 4, sdTimingDiamond = 5, sdTimingFastSilicon = 6 }
 CTPPS sub-detectors. More...
 
- Public Types inherited from DetId
enum  Detector {
  Tracker =1, Muon =2, Ecal =3, Hcal =4,
  Calo =5, Forward =6, VeryForward =7, HGCalEE =8,
  HGCalHSi =9, HGCalHSc =10, HGCalTrigger =11
}
 

Public Member Functions

uint32_t channel () const
 
void channelName (std::string &name, NameFlag flag=nFull) const
 
TotemTimingDetId getPlaneId () const
 
uint32_t plane () const
 
void planeName (std::string &name, NameFlag flag=nFull) const
 
void setChannel (uint32_t channel)
 
void setPlane (uint32_t channel)
 
 TotemTimingDetId (uint32_t id)
 Construct from a raw id. More...
 
 TotemTimingDetId (const CTPPSDetId &id)
 
 TotemTimingDetId (uint32_t arm, uint32_t station, uint32_t romanPot=0, uint32_t plane=0, uint32_t channel=0)
 Construct from hierarchy indices. More...
 
- Public Member Functions inherited from CTPPSDetId
uint32_t arm () const
 
void armName (std::string &name, NameFlag flag=nFull) const
 
 CTPPSDetId (uint32_t id)
 Construct from a raw id. More...
 
 CTPPSDetId (uint32_t SubDet, uint32_t Arm, uint32_t Station, uint32_t RomanPot=0)
 Construct from hierarchy indeces. More...
 
CTPPSDetId getArmId () const
 
CTPPSDetId getRPId () const
 
CTPPSDetId getStationId () const
 
uint32_t rp () const
 
void rpName (std::string &name, NameFlag flag=nFull) const
 
void setArm (uint32_t arm)
 
void setRP (uint32_t rp)
 
void setStation (uint32_t station)
 
uint32_t station () const
 
void stationName (std::string &name, NameFlag flag=nFull) const
 
void subDetectorName (std::string &name, NameFlag flag=nFull) const
 
- Public Member Functions inherited from DetId
constexpr Detector det () const
 get the detector field from this detid More...
 
constexpr DetId ()
 Create an empty or null id (also for persistence) More...
 
constexpr DetId (uint32_t id)
 Create an id from a raw number. More...
 
constexpr DetId (Detector det, int subdet)
 Create an id, filling the detector and subdetector fields as specified. More...
 
constexpr bool null () const
 is this a null id ? More...
 
constexpr operator uint32_t () const
 
constexpr bool operator!= (DetId id) const
 inequality More...
 
constexpr uint32_t operator() () const
 
constexpr bool operator< (DetId id) const
 comparison More...
 
constexpr bool operator== (DetId id) const
 equality More...
 
constexpr uint32_t rawId () const
 get the raw id More...
 
constexpr int subdetId () const
 get the contents of the subdetector field (not cast into any detector's numbering enum) More...
 

Static Public Member Functions

static bool check (unsigned int raw)
 returns true if the raw ID is a PPS-timing one More...
 

Static Public Attributes

static uint32_t lowMaskChannel = 0xFFF
 
static uint32_t lowMaskPlane = 0x1FFFF
 
static uint32_t maskChannel = 0x1F
 
static uint32_t maskPlane = 0x3
 
static uint32_t maxChannel = 31
 
static uint32_t maxPlane = 3
 
static uint32_t startDetBit = 12
 
static uint32_t startPlaneBit = 17
 
- Static Public Attributes inherited from CTPPSDetId
static const uint32_t lowMaskArm = 0xFFFFFF
 
static const uint32_t lowMaskRP = 0x7FFFF
 
static const uint32_t lowMaskStation = 0x3FFFFF
 
static const uint32_t maskArm = 0x1
 
static const uint32_t maskRP = 0x7
 
static const uint32_t maskStation = 0x3
 
static const uint32_t maxArm = 1
 
static const uint32_t maxRP = 6
 
static const uint32_t maxStation = 2
 
static const uint32_t startArmBit = 24
 
static const uint32_t startRPBit = 19
 
static const uint32_t startStationBit = 22
 
- Static Public Attributes inherited from DetId
static const int kDetMask = 0xF
 
static const int kDetOffset = 28
 
static const int kSubdetMask = 0x7
 
static const int kSubdetOffset = 25
 

Additional Inherited Members

- Protected Attributes inherited from DetId
uint32_t id_
 

Detailed Description

Detector ID class for CTPPS Totem Timing detectors. Bits [19:31] : Assigend in CTPPSDetId Calss Bits [17:18] : 2 bits for UFSD plane 0,1,2,3 Bits [12:16] : 5 bits for UFSD channel numbers 1,2,3,..16 Bits [0:11] : unspecified yet.

This class is very similar to CTPPSDiamondDetId; however the detector is completely separated, therefore it is useful to keep them separate and independent.

Definition at line 27 of file TotemTimingDetId.h.

Member Enumeration Documentation

anonymous enum
Enumerator
ID_NOT_SET 

Definition at line 29 of file TotemTimingDetId.h.

Constructor & Destructor Documentation

TotemTimingDetId::TotemTimingDetId ( uint32_t  id)
explicit

Construct from a raw id.

Definition at line 11 of file TotemTimingDetId.cc.

References channel(), check(), Exception, and DetId::subdetId().

Referenced by getPlaneId(), and TotemTimingDetId().

11  : CTPPSDetId(id) {
12  if (!check(id)) {
13  throw cms::Exception("InvalidDetId") << "TotemTimingDetId ctor:"
14  << " channel: " << channel() << " subdet: " << subdetId()
15  << " is not a valid Totem Timing id";
16  }
17 }
uint32_t channel() const
constexpr int subdetId() const
get the contents of the subdetector field (not cast into any detector&#39;s numbering enum) ...
Definition: DetId.h:41
static bool check(unsigned int raw)
returns true if the raw ID is a PPS-timing one
CTPPSDetId(uint32_t id)
Construct from a raw id.
Definition: CTPPSDetId.cc:35
TotemTimingDetId::TotemTimingDetId ( const CTPPSDetId id)
inline

Definition at line 33 of file TotemTimingDetId.h.

References CTPPSDetId::arm(), channel(), plane(), CTPPSDetId::station(), and TotemTimingDetId().

33 : CTPPSDetId(id) {}
CTPPSDetId(uint32_t id)
Construct from a raw id.
Definition: CTPPSDetId.cc:35
TotemTimingDetId::TotemTimingDetId ( uint32_t  arm,
uint32_t  station,
uint32_t  romanPot = 0,
uint32_t  plane = 0,
uint32_t  channel = 0 
)

Construct from hierarchy indices.

Definition at line 21 of file TotemTimingDetId.cc.

References Exception, DetId::id_, CTPPSDetId::maskArm, maskChannel, maskPlane, CTPPSDetId::maskRP, CTPPSDetId::maskStation, CTPPSDetId::maxArm, maxChannel, maxPlane, CTPPSDetId::maxRP, CTPPSDetId::maxStation, convertSQLiteXML::ok, CTPPSDetId::startArmBit, startDetBit, startPlaneBit, CTPPSDetId::startRPBit, and CTPPSDetId::startStationBit.

22  : CTPPSDetId(sdTimingFastSilicon, arm, station, romanPot) {
23  if (arm > maxArm || station > maxStation || romanPot > maxRP || plane > maxPlane || channel > maxChannel) {
24  throw cms::Exception("InvalidDetId") << "TotemTimingDetId ctor:"
25  << " Invalid parameters:"
26  << " arm=" << arm << " station=" << station << " rp=" << romanPot
27  << " plane=" << plane << " detector=" << channel << std::endl;
28  }
29 
30  uint32_t ok = 0xfe000000;
31  id_ &= ok;
32 
33  id_ |= ((arm & maskArm) << startArmBit);
35  id_ |= ((romanPot & maskRP) << startRPBit);
36  id_ |= ((plane & maskPlane) << startPlaneBit);
37  id_ |= ((channel & maskChannel) << startDetBit);
38 }
uint32_t station() const
Definition: CTPPSDetId.h:58
static uint32_t startPlaneBit
static const uint32_t maxStation
Definition: CTPPSDetId.h:46
uint32_t channel() const
static const uint32_t startRPBit
Definition: CTPPSDetId.h:47
static uint32_t maskPlane
static const uint32_t maskStation
Definition: CTPPSDetId.h:46
static const uint32_t maskRP
Definition: CTPPSDetId.h:47
static const uint32_t maskArm
Definition: CTPPSDetId.h:45
static const uint32_t maxArm
Definition: CTPPSDetId.h:45
static uint32_t maxChannel
uint32_t arm() const
Definition: CTPPSDetId.h:51
static const uint32_t maxRP
Definition: CTPPSDetId.h:47
static uint32_t maxPlane
uint32_t plane() const
static uint32_t startDetBit
uint32_t id_
Definition: DetId.h:62
static uint32_t maskChannel
static const uint32_t startStationBit
Definition: CTPPSDetId.h:46
CTPPSDetId(uint32_t id)
Construct from a raw id.
Definition: CTPPSDetId.cc:35
static const uint32_t startArmBit
Definition: CTPPSDetId.h:45

Member Function Documentation

uint32_t TotemTimingDetId::channel ( ) const
inline

Definition at line 55 of file TotemTimingDetId.h.

References DetId::id_, and maskChannel.

Referenced by channelName(), CTPPSGeometryInfo::formatDetId(), TotemTimingDQMSource::globalEndLuminosityBlock(), and TotemTimingDetId().

55 { return ((id_ >> startDetBit) & maskChannel); }
static uint32_t startDetBit
uint32_t id_
Definition: DetId.h:62
static uint32_t maskChannel
void TotemTimingDetId::channelName ( std::string &  name,
NameFlag  flag = nFull 
) const
inline

Definition at line 85 of file TotemTimingDetId.h.

References channel(), RemoveAddSevLevel::flag, CTPPSDetId::nFull, CTPPSDetId::nPath, CTPPSDetId::nShort, operator<<(), and planeName().

Referenced by TotemTimingDQMSource::ChannelPlots::ChannelPlots().

85  {
86  switch (flag) {
87  case nShort:
88  name = "";
89  break;
90  case nFull:
92  name += "_";
93  break;
94  case nPath:
96  name += "/channel ";
97  break;
98  }
99  name += std::to_string(channel());
100  }
uint32_t channel() const
void planeName(std::string &name, NameFlag flag=nFull) const
static bool TotemTimingDetId::check ( unsigned int  raw)
inlinestatic

returns true if the raw ID is a PPS-timing one

Definition at line 42 of file TotemTimingDetId.h.

References DetId::kDetOffset, DetId::kSubdetOffset, CTPPSDetId::sdTimingFastSilicon, and DetId::VeryForward.

Referenced by TotemTimingDetId().

42  {
43  return (((raw >> DetId::kDetOffset) & 0xF) == DetId::VeryForward &&
44  ((raw >> DetId::kSubdetOffset) & 0x7) == sdTimingFastSilicon);
45  }
static const int kSubdetOffset
Definition: DetId.h:23
static const int kDetOffset
Definition: DetId.h:22
TotemTimingDetId TotemTimingDetId::getPlaneId ( ) const
inline

Definition at line 64 of file TotemTimingDetId.h.

References lowMaskPlane, DetId::rawId(), and TotemTimingDetId().

64 { return TotemTimingDetId(rawId() & (~lowMaskPlane)); }
static uint32_t lowMaskPlane
constexpr uint32_t rawId() const
get the raw id
Definition: DetId.h:50
TotemTimingDetId(uint32_t id)
Construct from a raw id.
uint32_t TotemTimingDetId::plane ( ) const
inline

Definition at line 48 of file TotemTimingDetId.h.

References DetId::id_, and maskPlane.

Referenced by CTPPSGeometryInfo::formatDetId(), TotemTimingDQMSource::globalEndLuminosityBlock(), planeName(), and TotemTimingDetId().

48 { return ((id_ >> startPlaneBit) & maskPlane); }
static uint32_t startPlaneBit
static uint32_t maskPlane
uint32_t id_
Definition: DetId.h:62
void TotemTimingDetId::planeName ( std::string &  name,
NameFlag  flag = nFull 
) const
inline

Definition at line 68 of file TotemTimingDetId.h.

References RemoveAddSevLevel::flag, CTPPSDetId::nFull, CTPPSDetId::nPath, CTPPSDetId::nShort, plane(), and CTPPSDetId::rpName().

Referenced by channelName(), and TotemTimingDQMSource::PlanePlots::PlanePlots().

68  {
69  switch (flag) {
70  case nShort:
71  name = "";
72  break;
73  case nFull:
74  rpName(name, flag);
75  name += "_";
76  break;
77  case nPath:
78  rpName(name, flag);
79  name += "/plane ";
80  break;
81  }
82  name += std::to_string(plane());
83  }
void rpName(std::string &name, NameFlag flag=nFull) const
Definition: CTPPSDetId.h:128
uint32_t plane() const
void TotemTimingDetId::setChannel ( uint32_t  channel)
inline

Definition at line 57 of file TotemTimingDetId.h.

References DetId::id_, maskChannel, and startDetBit.

Referenced by TotemTimingDQMSource::analyze(), and TotemTimingLocalTrackFitter::produce().

57  {
58  id_ &= ~(maskChannel << startDetBit);
59  id_ |= ((channel & maskChannel) << startDetBit);
60  }
uint32_t channel() const
static uint32_t startDetBit
uint32_t id_
Definition: DetId.h:62
static uint32_t maskChannel
void TotemTimingDetId::setPlane ( uint32_t  channel)
inline

Definition at line 50 of file TotemTimingDetId.h.

References DetId::id_, maskPlane, and startPlaneBit.

Referenced by TotemTimingDQMSource::analyze().

50  {
51  id_ &= ~(maskPlane << startPlaneBit);
52  id_ |= ((channel & maskPlane) << startPlaneBit);
53  }
static uint32_t startPlaneBit
uint32_t channel() const
static uint32_t maskPlane
uint32_t id_
Definition: DetId.h:62

Member Data Documentation

uint32_t TotemTimingDetId::lowMaskChannel = 0xFFF
static

Definition at line 39 of file TotemTimingDetId.h.

uint32_t TotemTimingDetId::lowMaskPlane = 0x1FFFF
static

Definition at line 38 of file TotemTimingDetId.h.

Referenced by getPlaneId().

uint32_t TotemTimingDetId::maskChannel = 0x1F
static

Definition at line 39 of file TotemTimingDetId.h.

Referenced by channel(), setChannel(), and TotemTimingDetId().

uint32_t TotemTimingDetId::maskPlane = 0x3
static

Definition at line 38 of file TotemTimingDetId.h.

Referenced by plane(), setPlane(), and TotemTimingDetId().

uint32_t TotemTimingDetId::maxChannel = 31
static

Definition at line 39 of file TotemTimingDetId.h.

Referenced by TotemTimingDetId().

uint32_t TotemTimingDetId::maxPlane = 3
static

Definition at line 38 of file TotemTimingDetId.h.

Referenced by TotemTimingDetId().

uint32_t TotemTimingDetId::startDetBit = 12
static

Definition at line 39 of file TotemTimingDetId.h.

Referenced by setChannel(), and TotemTimingDetId().

uint32_t TotemTimingDetId::startPlaneBit = 17
static

Definition at line 38 of file TotemTimingDetId.h.

Referenced by setPlane(), and TotemTimingDetId().