CMS 3D CMS Logo

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

#include <HGCScintillatorDetId.h>

Inheritance diagram for HGCScintillatorDetId:
DetId

Public Member Functions

std::vector< HGCScintillatorDetIddetectorCells () const
 trigger or detector cell More...
 
HGCScintillatorDetId geometryCell () const
 
 HGCScintillatorDetId ()
 
 HGCScintillatorDetId (const DetId &id)
 
 HGCScintillatorDetId (int type, int layer, int iradius, int iphi, bool trigger=false, int sipm=0)
 
 HGCScintillatorDetId (uint32_t rawid)
 
int ieta () const
 
int ietaAbs () const
 
std::pair< int, int > ietaphi () const
 
int iphi () const
 get the phi index More...
 
int iphiTrigger () const
 
int iradius () const
 
int iradiusAbs () const
 get the eta index More...
 
std::pair< int, int > iradiusphi () const
 
int iradiusTrigger () const
 
int iradiusTriggerAbs () const
 
bool isEE () const
 consistency check : no bits left => no overhead More...
 
bool isForward () const
 
bool isHE () const
 
int layer () const
 get the layer # More...
 
HGCScintillatorDetIdoperator= (const DetId &id)
 
void setSiPM (int sipm)
 
void setType (int type)
 
int sipm () const
 get/set the sipm size More...
 
DetId::Detector subdet () const
 get the subdetector More...
 
bool trigger () const
 
HGCScintillatorDetId triggerCell () const
 
int type () const
 get/set the type More...
 
int zside () const
 get the z-side of the cell (1/-1) More...
 
- 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 (Detector det, int subdet)
 Create an id, filling the detector and subdetector fields as specified. More...
 
constexpr DetId (uint32_t id)
 Create an id from a raw number. 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 Attributes

static const int kHGCalLayerMask = 0x1F
 
static const int kHGCalLayerOffset = 17
 
static const int kHGCalPhiMask = 0x1FF
 
static const int kHGCalPhiOffset = 0
 
static const int kHGCalRadiusMask = 0xFF
 
static const int kHGCalRadiusOffset = 9
 
static const int kHGCalSiPMMask = 0x1
 
static const int kHGCalSiPMMask0 = 0xFF7FFFFF
 
static const int kHGCalSiPMOffset = 23
 
static const int kHGCalTriggerMask = 0x1
 
static const int kHGCalTriggerOffset = 22
 
static const int kHGCalTypeMask = 0x3
 
static const int kHGCalTypeMask0 = 0xF3FFFFFF
 
static const int kHGCalTypeOffset = 26
 
static const int kHGCalZsideMask = 0x1
 
static const int kHGCalZsideOffset = 25
 
static const HGCScintillatorDetId Undefined
 
- 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

- 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
}
 
- Protected Attributes inherited from DetId
uint32_t id_
 

Detailed Description

Definition at line 23 of file HGCScintillatorDetId.h.

Constructor & Destructor Documentation

◆ HGCScintillatorDetId() [1/4]

HGCScintillatorDetId::HGCScintillatorDetId ( )

Create a null cellid

Definition at line 8 of file HGCScintillatorDetId.cc.

8 : DetId() {}

Referenced by detectorCells(), geometryCell(), and triggerCell().

◆ HGCScintillatorDetId() [2/4]

HGCScintillatorDetId::HGCScintillatorDetId ( uint32_t  rawid)

Create cellid from raw id (0=invalid tower id)

Definition at line 10 of file HGCScintillatorDetId.cc.

10 : DetId(rawid) {}

◆ HGCScintillatorDetId() [3/4]

HGCScintillatorDetId::HGCScintillatorDetId ( int  type,
int  layer,
int  iradius,
int  iphi,
bool  trigger = false,
int  sipm = 0 
)

◆ HGCScintillatorDetId() [4/4]

HGCScintillatorDetId::HGCScintillatorDetId ( const DetId id)

Constructor from a generic cell id

Definition at line 23 of file HGCScintillatorDetId.cc.

23  {
24  if (!gen.null()) {
25  if (gen.det() != HGCalHSc) {
26  throw cms::Exception("Invalid DetId")
27  << "Cannot initialize HGCScintillatorDetId from " << std::hex << gen.rawId() << std::dec;
28  }
29  }
30  id_ = gen.rawId();
31 }

References TauDecayModes::dec, Exception, DetId::HGCalHSc, and DetId::id_.

Member Function Documentation

◆ detectorCells()

std::vector< HGCScintillatorDetId > HGCScintillatorDetId::detectorCells ( ) const

trigger or detector cell

Definition at line 82 of file HGCScintillatorDetId.cc.

82  {
83  std::vector<HGCScintillatorDetId> cells;
84  int irad = iradiusAbs();
85  int ifi = iphi();
86  int iz = zside();
87  if (trigger()) {
88  cells.emplace_back(HGCScintillatorDetId(type(), layer(), (2 * irad - 1) * iz, 2 * ifi - 1, false));
89  cells.emplace_back(HGCScintillatorDetId(type(), layer(), 2 * irad * iz, 2 * ifi - 1, false));
90  cells.emplace_back(HGCScintillatorDetId(type(), layer(), (2 * irad - 1) * iz, 2 * ifi, false));
91  cells.emplace_back(HGCScintillatorDetId(type(), layer(), 2 * irad * iz, 2 * ifi, false));
92  } else {
93  cells.emplace_back(HGCScintillatorDetId(type(), layer(), irad * iz, ifi, false));
94  }
95  return cells;
96 }

References postprocess-scan-build::cells, HGCScintillatorDetId(), iphi(), iradiusAbs(), layer(), trigger(), type(), and zside().

◆ geometryCell()

HGCScintillatorDetId HGCScintillatorDetId::geometryCell ( ) const

Converter for a geometry cell id

Definition at line 98 of file HGCScintillatorDetId.cc.

98  {
99  if (trigger()) {
100  return HGCScintillatorDetId(type(), layer(), iradiusTrigger(), iphiTrigger(), false);
101  } else {
102  return HGCScintillatorDetId(type(), layer(), iradius(), iphi(), false);
103  }
104 }

References HGCScintillatorDetId(), iphi(), iphiTrigger(), iradius(), iradiusTrigger(), layer(), trigger(), and type().

◆ ieta()

int HGCScintillatorDetId::ieta ( ) const
inline

◆ ietaAbs()

int HGCScintillatorDetId::ietaAbs ( ) const
inline

◆ ietaphi()

std::pair<int, int> HGCScintillatorDetId::ietaphi ( ) const
inline

Definition at line 60 of file HGCScintillatorDetId.h.

60 { return std::pair<int, int>(ieta(), iphi()); }

References ieta(), and iphi().

◆ iphi()

int HGCScintillatorDetId::iphi ( ) const

◆ iphiTrigger()

int HGCScintillatorDetId::iphiTrigger ( ) const

Definition at line 65 of file HGCScintillatorDetId.cc.

65  {
66  if (trigger())
67  return ((iphi() + 1) / 2);
68  else
69  return iphi();
70 }

References iphi(), and trigger().

Referenced by geometryCell(), and triggerCell().

◆ iradius()

int HGCScintillatorDetId::iradius ( ) const
inline

Definition at line 54 of file HGCScintillatorDetId.h.

54 { return zside() * iradiusAbs(); }

References iradiusAbs(), and zside().

Referenced by geometryCell(), iradiusphi(), and triggerCell().

◆ iradiusAbs()

int HGCScintillatorDetId::iradiusAbs ( ) const

get the eta index

Definition at line 44 of file HGCScintillatorDetId.cc.

44  {
45  if (trigger())
46  return (2 * ((id_ >> kHGCalRadiusOffset) & kHGCalRadiusMask));
47  else
48  return ((id_ >> kHGCalRadiusOffset) & kHGCalRadiusMask);
49 }

References DetId::id_, kHGCalRadiusMask, kHGCalRadiusOffset, and trigger().

Referenced by detectorCells(), HGCalCoarseTriggerCellMapping::getConstituentTriggerCells(), ietaAbs(), iradius(), and iradiusTriggerAbs().

◆ iradiusphi()

std::pair<int, int> HGCScintillatorDetId::iradiusphi ( ) const
inline

Definition at line 61 of file HGCScintillatorDetId.h.

61 { return std::pair<int, int>(iradius(), iphi()); }

References iphi(), and iradius().

◆ iradiusTrigger()

int HGCScintillatorDetId::iradiusTrigger ( ) const
inline

Definition at line 98 of file HGCScintillatorDetId.h.

98 { return zside() * iradiusTriggerAbs(); }

References iradiusTriggerAbs(), and zside().

Referenced by geometryCell(), and triggerCell().

◆ iradiusTriggerAbs()

int HGCScintillatorDetId::iradiusTriggerAbs ( ) const

Definition at line 51 of file HGCScintillatorDetId.cc.

51  {
52  if (trigger())
53  return ((iradiusAbs() + 1) / 2);
54  else
55  return iradiusAbs();
56 }

References iradiusAbs(), and trigger().

Referenced by iradiusTrigger().

◆ isEE()

bool HGCScintillatorDetId::isEE ( ) const
inline

consistency check : no bits left => no overhead

Definition at line 73 of file HGCScintillatorDetId.h.

73 { return false; }

◆ isForward()

bool HGCScintillatorDetId::isForward ( ) const
inline

Definition at line 75 of file HGCScintillatorDetId.h.

75 { return true; }

◆ isHE()

bool HGCScintillatorDetId::isHE ( ) const
inline

Definition at line 74 of file HGCScintillatorDetId.h.

74 { return true; }

◆ layer()

int HGCScintillatorDetId::layer ( ) const
inline

◆ operator=()

HGCScintillatorDetId & HGCScintillatorDetId::operator= ( const DetId id)

Assignment from a generic cell id

Definition at line 33 of file HGCScintillatorDetId.cc.

33  {
34  if (!gen.null()) {
35  if (gen.det() != HGCalHSc) {
36  throw cms::Exception("Invalid DetId")
37  << "Cannot assign HGCScintillatorDetId from " << std::hex << gen.rawId() << std::dec;
38  }
39  }
40  id_ = gen.rawId();
41  return (*this);
42 }

References TauDecayModes::dec, Exception, DetId::HGCalHSc, and DetId::id_.

◆ setSiPM()

void HGCScintillatorDetId::setSiPM ( int  sipm)

Definition at line 77 of file HGCScintillatorDetId.cc.

77  {
80 }

References DetId::id_, kHGCalSiPMMask, kHGCalSiPMMask0, kHGCalSiPMOffset, and sipm().

◆ setType()

void HGCScintillatorDetId::setType ( int  type)

Definition at line 72 of file HGCScintillatorDetId.cc.

72  {
75 }

References DetId::id_, kHGCalTypeMask, kHGCalTypeMask0, and kHGCalTypeOffset.

◆ sipm()

int HGCScintillatorDetId::sipm ( ) const
inline

get/set the sipm size

Definition at line 64 of file HGCScintillatorDetId.h.

64 { return (id_ >> kHGCalSiPMOffset) & kHGCalSiPMMask; }

References DetId::id_, kHGCalSiPMMask, and kHGCalSiPMOffset.

Referenced by HGCScintillatorDetId(), and setSiPM().

◆ subdet()

DetId::Detector HGCScintillatorDetId::subdet ( ) const
inline

get the subdetector

Definition at line 40 of file HGCScintillatorDetId.h.

40 { return det(); }

References DetId::det().

Referenced by HGCalTriggerNtupleHGCTriggerSums::fill(), and HGCalTriggerNtupleHGCTriggerCells::fill().

◆ trigger()

bool HGCScintillatorDetId::trigger ( ) const
inline

◆ triggerCell()

HGCScintillatorDetId HGCScintillatorDetId::triggerCell ( ) const

Definition at line 106 of file HGCScintillatorDetId.cc.

106  {
107  if (trigger())
108  return HGCScintillatorDetId(type(), layer(), iradius(), iphi(), true);
109  else
110  return HGCScintillatorDetId(type(), layer(), iradiusTrigger(), iphiTrigger(), true);
111 }

References HGCScintillatorDetId(), iphi(), iphiTrigger(), iradius(), iradiusTrigger(), layer(), trigger(), and type().

◆ type()

int HGCScintillatorDetId::type ( ) const
inline

◆ zside()

int HGCScintillatorDetId::zside ( ) const
inline

Member Data Documentation

◆ kHGCalLayerMask

const int HGCScintillatorDetId::kHGCalLayerMask = 0x1F
static

Definition at line 85 of file HGCScintillatorDetId.h.

Referenced by HGCScintillatorDetId(), and layer().

◆ kHGCalLayerOffset

const int HGCScintillatorDetId::kHGCalLayerOffset = 17
static

Definition at line 84 of file HGCScintillatorDetId.h.

Referenced by HGCScintillatorDetId(), and layer().

◆ kHGCalPhiMask

const int HGCScintillatorDetId::kHGCalPhiMask = 0x1FF
static

◆ kHGCalPhiOffset

const int HGCScintillatorDetId::kHGCalPhiOffset = 0
static

◆ kHGCalRadiusMask

const int HGCScintillatorDetId::kHGCalRadiusMask = 0xFF
static

◆ kHGCalRadiusOffset

const int HGCScintillatorDetId::kHGCalRadiusOffset = 9
static

◆ kHGCalSiPMMask

const int HGCScintillatorDetId::kHGCalSiPMMask = 0x1
static

Definition at line 89 of file HGCScintillatorDetId.h.

Referenced by HGCScintillatorDetId(), setSiPM(), and sipm().

◆ kHGCalSiPMMask0

const int HGCScintillatorDetId::kHGCalSiPMMask0 = 0xFF7FFFFF
static

Definition at line 90 of file HGCScintillatorDetId.h.

Referenced by setSiPM().

◆ kHGCalSiPMOffset

const int HGCScintillatorDetId::kHGCalSiPMOffset = 23
static

Definition at line 88 of file HGCScintillatorDetId.h.

Referenced by HGCScintillatorDetId(), setSiPM(), and sipm().

◆ kHGCalTriggerMask

const int HGCScintillatorDetId::kHGCalTriggerMask = 0x1
static

Definition at line 87 of file HGCScintillatorDetId.h.

Referenced by HGCScintillatorDetId(), and trigger().

◆ kHGCalTriggerOffset

const int HGCScintillatorDetId::kHGCalTriggerOffset = 22
static

Definition at line 86 of file HGCScintillatorDetId.h.

Referenced by HGCScintillatorDetId(), and trigger().

◆ kHGCalTypeMask

const int HGCScintillatorDetId::kHGCalTypeMask = 0x3
static

Definition at line 94 of file HGCScintillatorDetId.h.

Referenced by HGCScintillatorDetId(), setType(), and type().

◆ kHGCalTypeMask0

const int HGCScintillatorDetId::kHGCalTypeMask0 = 0xF3FFFFFF
static

Definition at line 95 of file HGCScintillatorDetId.h.

Referenced by setType().

◆ kHGCalTypeOffset

const int HGCScintillatorDetId::kHGCalTypeOffset = 26
static

Definition at line 93 of file HGCScintillatorDetId.h.

Referenced by HGCScintillatorDetId(), setType(), and type().

◆ kHGCalZsideMask

const int HGCScintillatorDetId::kHGCalZsideMask = 0x1
static

Definition at line 92 of file HGCScintillatorDetId.h.

Referenced by HGCScintillatorDetId(), and zside().

◆ kHGCalZsideOffset

const int HGCScintillatorDetId::kHGCalZsideOffset = 25
static

Definition at line 91 of file HGCScintillatorDetId.h.

Referenced by HGCScintillatorDetId(), and zside().

◆ Undefined

const HGCScintillatorDetId HGCScintillatorDetId::Undefined
static

Definition at line 77 of file HGCScintillatorDetId.h.

HGCScintillatorDetId::iradiusAbs
int iradiusAbs() const
get the eta index
Definition: HGCScintillatorDetId.cc:44
HGCScintillatorDetId::iphi
int iphi() const
get the phi index
Definition: HGCScintillatorDetId.cc:58
ForwardEmpty
Definition: ForwardSubdetector.h:5
HGCScintillatorDetId::ieta
int ieta() const
Definition: HGCScintillatorDetId.h:56
HGCScintillatorDetId::kHGCalTypeOffset
static const int kHGCalTypeOffset
Definition: HGCScintillatorDetId.h:93
HGCScintillatorDetId::kHGCalTriggerOffset
static const int kHGCalTriggerOffset
Definition: HGCScintillatorDetId.h:86
DetId::det
constexpr Detector det() const
get the detector field from this detid
Definition: DetId.h:46
HGCScintillatorDetId::kHGCalTriggerMask
static const int kHGCalTriggerMask
Definition: HGCScintillatorDetId.h:87
HGCScintillatorDetId::iphiTrigger
int iphiTrigger() const
Definition: HGCScintillatorDetId.cc:65
HGCScintillatorDetId::kHGCalTypeMask
static const int kHGCalTypeMask
Definition: HGCScintillatorDetId.h:94
HGCScintillatorDetId::iradiusTrigger
int iradiusTrigger() const
Definition: HGCScintillatorDetId.h:98
HGCScintillatorDetId::layer
int layer() const
get the layer #
Definition: HGCScintillatorDetId.h:50
HGCScintillatorDetId::iradiusTriggerAbs
int iradiusTriggerAbs() const
Definition: HGCScintillatorDetId.cc:51
HGCScintillatorDetId::trigger
bool trigger() const
Definition: HGCScintillatorDetId.h:69
HGCScintillatorDetId::ietaAbs
int ietaAbs() const
Definition: HGCScintillatorDetId.h:55
HGCScintillatorDetId::kHGCalSiPMMask0
static const int kHGCalSiPMMask0
Definition: HGCScintillatorDetId.h:90
HGCScintillatorDetId::kHGCalLayerMask
static const int kHGCalLayerMask
Definition: HGCScintillatorDetId.h:85
gen
Definition: PythiaDecays.h:13
HGCScintillatorDetId::zside
int zside() const
get the z-side of the cell (1/-1)
Definition: HGCScintillatorDetId.h:47
DetId::id_
uint32_t id_
Definition: DetId.h:69
HGCScintillatorDetId::kHGCalRadiusOffset
static const int kHGCalRadiusOffset
Definition: HGCScintillatorDetId.h:82
type
type
Definition: SiPixelVCal_PayloadInspector.cc:37
HGCScintillatorDetId::iradius
int iradius() const
Definition: HGCScintillatorDetId.h:54
HGCScintillatorDetId::kHGCalPhiOffset
static const int kHGCalPhiOffset
Definition: HGCScintillatorDetId.h:80
HGCScintillatorDetId::kHGCalRadiusMask
static const int kHGCalRadiusMask
Definition: HGCScintillatorDetId.h:83
HGCScintillatorDetId::type
int type() const
get/set the type
Definition: HGCScintillatorDetId.h:43
HGCScintillatorDetId::kHGCalPhiMask
static const int kHGCalPhiMask
Definition: HGCScintillatorDetId.h:81
HGCScintillatorDetId::kHGCalSiPMOffset
static const int kHGCalSiPMOffset
Definition: HGCScintillatorDetId.h:88
HGCScintillatorDetId::HGCScintillatorDetId
HGCScintillatorDetId()
Definition: HGCScintillatorDetId.cc:8
DDAxes::phi
HGCScintillatorDetId::kHGCalZsideMask
static const int kHGCalZsideMask
Definition: HGCScintillatorDetId.h:92
DetId::HGCalHSc
Definition: DetId.h:34
HGCScintillatorDetId::kHGCalZsideOffset
static const int kHGCalZsideOffset
Definition: HGCScintillatorDetId.h:91
Exception
Definition: hltDiff.cc:246
postprocess-scan-build.cells
cells
Definition: postprocess-scan-build.py:13
CosmicsPD_Skims.radius
radius
Definition: CosmicsPD_Skims.py:135
DetId::DetId
constexpr DetId()
Create an empty or null id (also for persistence)
Definition: DetId.h:38
trigger
Definition: HLTPrescaleTableCond.h:8
funct::abs
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
HGCScintillatorDetId::kHGCalLayerOffset
static const int kHGCalLayerOffset
Definition: HGCScintillatorDetId.h:84
HGCScintillatorDetId::kHGCalTypeMask0
static const int kHGCalTypeMask0
Definition: HGCScintillatorDetId.h:95
TauDecayModes.dec
dec
Definition: TauDecayModes.py:143
HGCScintillatorDetId::sipm
int sipm() const
get/set the sipm size
Definition: HGCScintillatorDetId.h:64
HGCScintillatorDetId::kHGCalSiPMMask
static const int kHGCalSiPMMask
Definition: HGCScintillatorDetId.h:89