CMS 3D CMS Logo

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

Detector identifier class for the Barrel Timing Layer. The crystal count must start from 0, copy number must be scaled by 1 unit. More...

#include <BTLDetId.h>

Inheritance diagram for BTLDetId:
MTDDetId DetId

Public Types

enum  CrysLayout { CrysLayout::tile = 1, CrysLayout::bar = 2, CrysLayout::barzflat = 3, CrysLayout::barphiflat = 4 }
 
- Public Types inherited from MTDDetId
enum  MTDType { typeUNKNOWN =0, BTL =1, ETL =2 }
 
enum  SubDetector { subUNKNOWN =0, FastTime =1 }
 
- 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

 BTLDetId ()
 
 BTLDetId (const uint32_t &raw_id)
 
 BTLDetId (const DetId &det_id)
 
 BTLDetId (uint32_t zside, uint32_t rod, uint32_t module, uint32_t modtyp, uint32_t crystal)
 
int column (unsigned nrows=16) const
 
int crystal () const
 
BTLDetId geographicalId (CrysLayout lay) const
 
BTLDetId getUnhashedIndex (int hi, CrysLayout lay) const
 
int hashedIndex (CrysLayout lay) const
 
int ieta (CrysLayout lay) const
 
int ietaAbs (CrysLayout lay) const
 
int iphi (CrysLayout lay) const
 
int modType () const
 
int module () const
 
int modulesPerType (CrysLayout lay) const
 
int row (unsigned nrows=16) const
 
- Public Member Functions inherited from MTDDetId
 MTDDetId ()
 
 MTDDetId (const uint32_t &raw_id)
 
 MTDDetId (const DetId &det_id)
 
 MTDDetId (Detector det, int subdet)
 
int mtdRR () const
 
int mtdSide () const
 
int mtdSubDetector () const
 
SubDetector subDetector () const
 
int zside () 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 validHashedIndex (uint32_t din)
 

Static Public Attributes

static constexpr int HALF_ROD = 36
 
static constexpr uint32_t kBTLCrystalMask = 0x3F
 
static constexpr uint32_t kBTLCrystalOffset = 0
 
static constexpr uint32_t kBTLmodTypeMask = 0x3
 
static constexpr uint32_t kBTLmodTypeOffset = 8
 
static constexpr uint32_t kBTLmoduleMask = 0x3F
 
static constexpr uint32_t kBTLmoduleOffset = 10
 
static constexpr int kCrystalsInEtaBar = 16
 
static constexpr int kCrystalsInEtaBarPhi = 16
 
static constexpr int kCrystalsInEtaBarZ = 1
 
static constexpr int kCrystalsInEtaTile = 4
 
static constexpr int kCrystalsInPhiBar = 4
 
static constexpr int kCrystalsInPhiBarPhi = 3
 
static constexpr int kCrystalsInPhiBarZ = 64
 
static constexpr int kCrystalsInPhiTile = 16
 
static constexpr int kCrystalsPerROD = kModulesPerROD*kCrystalsInPhiTile*kCrystalsInEtaTile
 
static constexpr int kCrystalsPerRODBarPhiFlat = kModulesPerRODBarPhiFlat*kCrystalsInPhiBarPhi*kCrystalsInEtaBarPhi
 
static constexpr int kCrystalsPerRODBarZflat = kModulesPerRODBarZflat*kCrystalsInPhiBarZ*kCrystalsInEtaBarZ
 
static constexpr int kModulesPerROD = 54
 range constants, need two sets for the time being (one for tiles and one for bars) More...
 
static constexpr int kModulesPerRODBarPhiFlat = 48
 
static constexpr int kModulesPerRODBarZflat = 42
 
static constexpr int kSizeForDenseIndexing = MAX_HASH + 1
 
static constexpr std::array< int, 4 > kTypeBoundariesBarPhiFlat { { 0, 16, 32, 48 } }
 
static constexpr std::array< int, 4 > kTypeBoundariesBarZflat { { 0, 14, 28, 42 } }
 
static constexpr std::array< int, 4 > kTypeBoundariesReference { { 0, 18, 36, 54 } }
 
static constexpr int MAX_HASH = 2*MAX_IPHI_TILE*MAX_IETA_TILE-1
 
static constexpr int MAX_IETA_BAR = kCrystalsInEtaBar*kModulesPerROD
 
static constexpr int MAX_IETA_BARPHIFLAT = kCrystalsInEtaBarPhi*kModulesPerRODBarPhiFlat
 
static constexpr int MAX_IETA_BARZ = kCrystalsInEtaBarZ*kModulesPerROD
 
static constexpr int MAX_IETA_BARZFLAT = kCrystalsInEtaBarZ*kModulesPerRODBarZflat
 
static constexpr int MAX_IETA_TILE = kCrystalsInEtaTile*kModulesPerROD
 
static constexpr int MAX_IPHI_BAR = kCrystalsInPhiBar*HALF_ROD
 
static constexpr int MAX_IPHI_BARPHIFLAT = kCrystalsInPhiBarPhi*HALF_ROD
 
static constexpr int MAX_IPHI_BARZ = kCrystalsInPhiBarZ*HALF_ROD
 
static constexpr int MAX_IPHI_BARZFLAT = kCrystalsInPhiBarZ*HALF_ROD
 
static constexpr int MAX_IPHI_TILE = kCrystalsInPhiTile*HALF_ROD
 
static constexpr int MAX_ROD = 72
 
static constexpr int MIN_HASH = 0
 
static constexpr int MIN_IETA = 1
 
static constexpr int MIN_IPHI = 1
 
static constexpr int MIN_ROD = 1
 
- Static Public Attributes inherited from MTDDetId
static const uint32_t kMTDsubdMask = 0x3
 
static const uint32_t kMTDsubdOffset = 23
 
static const uint32_t kRodRingMask = 0x3F
 
static const uint32_t kRodRingOffset = 16
 
static const uint32_t kZsideMask = 0x1
 
static const uint32_t kZsideOffset = 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 identifier class for the Barrel Timing Layer. The crystal count must start from 0, copy number must be scaled by 1 unit.

bit 15-10: module sequential number bit 9-8 : crystal type (1 - 3) bit 7-0 : crystal sequential number within a module ( 0 - 63 )

Definition at line 18 of file BTLDetId.h.

Member Enumeration Documentation

enum BTLDetId::CrysLayout
strong
Enumerator
tile 
bar 
barzflat 
barphiflat 

Definition at line 66 of file BTLDetId.h.

Constructor & Destructor Documentation

BTLDetId::BTLDetId ( )
inline

Construct a null id

Definition at line 71 of file BTLDetId.h.

References DetId::id_, MTDDetId::kMTDsubdMask, and MTDDetId::kMTDsubdOffset.

Referenced by geographicalId(), and getUnhashedIndex().

MTDDetId()
Definition: MTDDetId.h:41
static const uint32_t kMTDsubdOffset
Definition: MTDDetId.h:31
static const uint32_t kMTDsubdMask
Definition: MTDDetId.h:32
uint32_t id_
Definition: DetId.h:62
BTLDetId::BTLDetId ( const uint32_t &  raw_id)
inline

Construct from a raw value

Definition at line 74 of file BTLDetId.h.

74 : MTDDetId( raw_id ) {;}
MTDDetId()
Definition: MTDDetId.h:41
BTLDetId::BTLDetId ( const DetId det_id)
inline

Construct from generic DetId

Definition at line 77 of file BTLDetId.h.

77 : MTDDetId( det_id.rawId() ) {;}
MTDDetId()
Definition: MTDDetId.h:41
constexpr uint32_t rawId() const
get the raw id
Definition: DetId.h:50
BTLDetId::BTLDetId ( uint32_t  zside,
uint32_t  rod,
uint32_t  module,
uint32_t  modtyp,
uint32_t  crystal 
)
inline

Construct and fill only the det and sub-det fields.

Definition at line 80 of file BTLDetId.h.

References DetId::id_, kBTLCrystalMask, kBTLmodTypeMask, MTDDetId::kMTDsubdMask, MTDDetId::kMTDsubdOffset, MTDDetId::kRodRingMask, MTDDetId::kRodRingOffset, MTDDetId::kZsideMask, and MTDDetId::kZsideOffset.

85  id_ |= ( MTDType::BTL& kMTDsubdMask ) << kMTDsubdOffset |
86  ( zside& kZsideMask ) << kZsideOffset |
87  ( rod& kRodRingMask ) << kRodRingOffset |
89  ( modtyp& kBTLmodTypeMask ) << kBTLmodTypeOffset |
91  }
static const uint32_t kRodRingOffset
Definition: MTDDetId.h:35
MTDDetId()
Definition: MTDDetId.h:41
static constexpr uint32_t kBTLmodTypeOffset
Definition: BTLDetId.h:24
static constexpr uint32_t kBTLmodTypeMask
Definition: BTLDetId.h:25
static const uint32_t kZsideOffset
Definition: MTDDetId.h:33
static const uint32_t kMTDsubdOffset
Definition: MTDDetId.h:31
static const uint32_t kRodRingMask
Definition: MTDDetId.h:36
static constexpr uint32_t kBTLmoduleOffset
Definition: BTLDetId.h:22
static const uint32_t kMTDsubdMask
Definition: MTDDetId.h:32
static const uint32_t kZsideMask
Definition: MTDDetId.h:34
uint32_t id_
Definition: DetId.h:62
int zside() const
Definition: MTDDetId.h:63
static constexpr uint32_t kBTLCrystalOffset
Definition: BTLDetId.h:26
Definition: vlib.h:208
static constexpr uint32_t kBTLmoduleMask
Definition: BTLDetId.h:23
int crystal() const
Definition: BTLDetId.h:102
static constexpr uint32_t kBTLCrystalMask
Definition: BTLDetId.h:27

Member Function Documentation

int BTLDetId::column ( unsigned  nrows = 16) const
inline

return the column in GeomDetLanguage

Definition at line 110 of file BTLDetId.h.

References crystal(), ietaAbs(), and iphi().

Referenced by BtlDigiHitsValidation::analyze(), BtlRecHitsValidation::analyze(), BtlSimHitsValidation::analyze(), BTLTileDeviceSim::getHitsResponse(), and BTLBarDeviceSim::getHitsResponse().

110  {
111  return (crystal()-1)/nrows;
112  }
int crystal() const
Definition: BTLDetId.h:102
int BTLDetId::crystal ( ) const
inline

Returns BTL crystal number.

Definition at line 102 of file BTLDetId.h.

References DetId::id_.

Referenced by column(), getUnhashedIndex(), ietaAbs(), iphi(), and row().

102 { return ((id_>>kBTLCrystalOffset)&kBTLCrystalMask) + 1; }
uint32_t id_
Definition: DetId.h:62
static constexpr uint32_t kBTLCrystalOffset
Definition: BTLDetId.h:26
static constexpr uint32_t kBTLCrystalMask
Definition: BTLDetId.h:27
BTLDetId BTLDetId::geographicalId ( CrysLayout  lay) const

create a Geographical DetId for Tracking

Definition at line 162 of file BTLDetId.cc.

References BTLDetId(), modType(), module(), modulesPerType(), MTDDetId::mtdRR(), and MTDDetId::mtdSide().

Referenced by BtlDigiHitsValidation::analyze(), BtlRecHitsValidation::analyze(), BtlSimHitsValidation::analyze(), MTDTimeCalib::getTimeCalib(), and validHashedIndex().

162  {
163  // reorganize the modules to count from 0 to 54
164  // (0 to 42 in the case of BarZflat geometry)
165  // remove module type
166  // remove crystal index
167 
168  int boundRef = modulesPerType(lay);
169 
170  return BTLDetId(mtdSide(),mtdRR(),module()+boundRef*(modType()-1),0,1);
171 }
int modulesPerType(CrysLayout lay) const
Definition: BTLDetId.cc:155
BTLDetId()
Definition: BTLDetId.h:71
int mtdRR() const
Definition: MTDDetId.h:66
int mtdSide() const
Definition: MTDDetId.h:61
int module() const
Definition: BTLDetId.h:96
int modType() const
Definition: BTLDetId.h:99
BTLDetId BTLDetId::getUnhashedIndex ( int  hi,
CrysLayout  lay 
) const

get a DetId from a compact index for arrays

Definition at line 102 of file BTLDetId.cc.

References bar, barphiflat, barzflat, BTLDetId(), crystal(), kCrystalsInEtaBar, kCrystalsInEtaBarPhi, kCrystalsInEtaBarZ, kCrystalsInEtaTile, kCrystalsInPhiBar, kCrystalsInPhiBarPhi, kCrystalsInPhiBarZ, kCrystalsInPhiTile, kTypeBoundariesBarPhiFlat, kTypeBoundariesBarZflat, kTypeBoundariesReference, MAX_IETA_BAR, MAX_IETA_BARPHIFLAT, MAX_IETA_BARZFLAT, MAX_IETA_TILE, MAX_IPHI_BAR, MAX_IPHI_BARPHIFLAT, MAX_IPHI_BARZFLAT, MAX_IPHI_TILE, tile, and MTDDetId::zside().

Referenced by validHashedIndex().

102  {
103  int max_iphi =1 ,max_ieta = 1, nphi = 0, keta = 0, tmphi = hi + 1;
104  std::array<int,4> kTypeBoundaries = {};
105  switch ( lay ) {
106  case CrysLayout::tile : {
107  max_iphi = MAX_IPHI_TILE;
108  max_ieta = MAX_IETA_TILE;
109  nphi = kCrystalsInPhiTile;
110  keta = kCrystalsInEtaTile;
111  kTypeBoundaries = kTypeBoundariesReference;
112  break ;
113  }
114  case CrysLayout::bar : {
115  max_iphi = MAX_IPHI_BAR;
116  max_ieta = MAX_IETA_BAR;
117  nphi = kCrystalsInPhiBar;
118  keta = kCrystalsInEtaBar;
119  kTypeBoundaries = kTypeBoundariesReference;
120  break ;
121  }
122  case CrysLayout::barzflat : {
123  max_iphi = MAX_IPHI_BARZFLAT;
124  max_ieta = MAX_IETA_BARZFLAT;
125  nphi = kCrystalsInPhiBarZ;
126  keta = kCrystalsInEtaBarZ;
127  kTypeBoundaries = kTypeBoundariesBarZflat;
128  break ;
129  }
130  case CrysLayout::barphiflat : {
131  max_iphi = MAX_IPHI_BARPHIFLAT;
132  max_ieta = MAX_IETA_BARPHIFLAT;
133  nphi = kCrystalsInPhiBarPhi;
134  keta = kCrystalsInEtaBarPhi;
135  kTypeBoundaries = kTypeBoundariesBarPhiFlat;
136  break ;
137  }
138  default: {
139  break ;
140  }
141  }
142  int zside = 0, rod = 0, module = 0, modtype = 1, crystal = 0;
143  if ( tmphi > max_ieta*max_iphi ) { zside = 1; }
144  int ip = (tmphi-1)%max_iphi+1;
145  int ie = (tmphi-1)/max_iphi - max_ieta;
146  ie = ( zside == 1 ? ie + 1 : -ie ) ;
147  rod = (ip-1)/nphi+1;
148  module = (ie-1)/keta+1 ;
149  if ( module > kTypeBoundaries[1] ) { modtype = (module > kTypeBoundaries[2] ? 3 : 2 ) ; }
150  if ( modtype > 1 ) { module = module - kTypeBoundaries[modtype-1]; }
151  crystal = zside == 1 ? ((ip-1)%nphi+1)+((ie-1)%keta)*nphi : ((ip-1)%nphi+1)+(keta - 1 - (ie-1)%keta)*nphi ;
152  return BTLDetId( zside, rod, module, modtype, crystal);
153 }
static constexpr int MAX_IETA_BAR
Definition: BTLDetId.h:54
static constexpr int kCrystalsInPhiBarPhi
Definition: BTLDetId.h:42
static constexpr std::array< int, 4 > kTypeBoundariesReference
Definition: BTLDetId.h:33
static constexpr int MAX_IPHI_BAR
Definition: BTLDetId.h:55
BTLDetId()
Definition: BTLDetId.h:71
static constexpr int MAX_IETA_TILE
Definition: BTLDetId.h:52
static constexpr int MAX_IPHI_BARZFLAT
Definition: BTLDetId.h:59
static constexpr int MAX_IPHI_TILE
Definition: BTLDetId.h:53
static constexpr int kCrystalsInPhiBar
Definition: BTLDetId.h:38
static constexpr int MAX_IETA_BARPHIFLAT
Definition: BTLDetId.h:60
static constexpr std::array< int, 4 > kTypeBoundariesBarZflat
Definition: BTLDetId.h:34
static constexpr std::array< int, 4 > kTypeBoundariesBarPhiFlat
Definition: BTLDetId.h:35
static constexpr int kCrystalsInEtaBarPhi
Definition: BTLDetId.h:43
static constexpr int kCrystalsInPhiTile
Definition: BTLDetId.h:36
static constexpr int kCrystalsInEtaBar
Definition: BTLDetId.h:39
static constexpr int MAX_IETA_BARZFLAT
Definition: BTLDetId.h:58
static constexpr int kCrystalsInEtaBarZ
Definition: BTLDetId.h:41
int zside() const
Definition: MTDDetId.h:63
static constexpr int kCrystalsInEtaTile
Definition: BTLDetId.h:37
static constexpr int kCrystalsInPhiBarZ
Definition: BTLDetId.h:40
Definition: vlib.h:208
static constexpr int MAX_IPHI_BARPHIFLAT
Definition: BTLDetId.h:61
int crystal() const
Definition: BTLDetId.h:102
int BTLDetId::hashedIndex ( CrysLayout  lay) const

define a dense index of arrays from a DetId

Definition at line 70 of file BTLDetId.cc.

References bar, barphiflat, barzflat, ietaAbs(), iphi(), MAX_IETA_BAR, MAX_IETA_BARPHIFLAT, MAX_IETA_BARZFLAT, MAX_IETA_TILE, MAX_IPHI_BAR, MAX_IPHI_BARPHIFLAT, MAX_IPHI_BARZFLAT, MAX_IPHI_TILE, tile, and MTDDetId::zside().

Referenced by ieta().

70  {
71  int max_iphi = 1, max_ieta = 1;
72  switch ( lay ) {
73  case CrysLayout::tile : {
74  max_iphi = MAX_IPHI_TILE;
75  max_ieta = MAX_IETA_TILE;
76  break ;
77  }
78  case CrysLayout::bar : {
79  max_iphi = MAX_IPHI_BAR;
80  max_ieta = MAX_IETA_BAR;
81  break ;
82  }
83  case CrysLayout::barzflat : {
84  max_iphi = MAX_IPHI_BARZFLAT;
85  max_ieta = MAX_IETA_BARZFLAT;
86  break ;
87  }
88  case CrysLayout::barphiflat : {
89  max_iphi = MAX_IPHI_BARPHIFLAT;
90  max_ieta = MAX_IETA_BARPHIFLAT;
91  break ;
92  }
93  default: {
94  break ;
95  }
96  }
97  return (max_ieta + ( zside() > 0 ? ietaAbs( lay ) - 1 : -ietaAbs( lay ) ) )*max_iphi+ iphi( lay ) - 1;
98 }
static constexpr int MAX_IETA_BAR
Definition: BTLDetId.h:54
int ietaAbs(CrysLayout lay) const
Definition: BTLDetId.cc:32
static constexpr int MAX_IPHI_BAR
Definition: BTLDetId.h:55
static constexpr int MAX_IETA_TILE
Definition: BTLDetId.h:52
static constexpr int MAX_IPHI_BARZFLAT
Definition: BTLDetId.h:59
static constexpr int MAX_IPHI_TILE
Definition: BTLDetId.h:53
static constexpr int MAX_IETA_BARPHIFLAT
Definition: BTLDetId.h:60
int iphi(CrysLayout lay) const
Definition: BTLDetId.cc:4
static constexpr int MAX_IETA_BARZFLAT
Definition: BTLDetId.h:58
int zside() const
Definition: MTDDetId.h:63
static constexpr int MAX_IPHI_BARPHIFLAT
Definition: BTLDetId.h:61
int BTLDetId::ieta ( CrysLayout  lay) const
inline

Definition at line 120 of file BTLDetId.h.

References hashedIndex(), ietaAbs(), and MTDDetId::zside().

120 { return zside()*ietaAbs( lay ); }
int ietaAbs(CrysLayout lay) const
Definition: BTLDetId.cc:32
int zside() const
Definition: MTDDetId.h:63
int BTLDetId::ietaAbs ( CrysLayout  lay) const

Returns BTL ieta index for crystal according to type tile or bar

Definition at line 32 of file BTLDetId.cc.

References bar, barphiflat, barzflat, crystal(), kCrystalsInEtaBar, kCrystalsInEtaBarPhi, kCrystalsInEtaBarZ, kCrystalsInEtaTile, kCrystalsInPhiBar, kCrystalsInPhiBarPhi, kCrystalsInPhiBarZ, kCrystalsInPhiTile, kTypeBoundariesBarPhiFlat, kTypeBoundariesBarZflat, kTypeBoundariesReference, modType(), module(), tile, and MTDDetId::zside().

Referenced by column(), hashedIndex(), and ieta().

32  {
33  int kCrystalsInEta = 1, kCrystalsInPhi = 1;
34  std::array<int,4> kTypeBoundaries = {};
35  switch ( lay ) {
36  case CrysLayout::tile : {
37  kCrystalsInEta = kCrystalsInEtaTile;
38  kCrystalsInPhi = kCrystalsInPhiTile;
39  kTypeBoundaries = kTypeBoundariesReference;
40  break ;
41  }
42  case CrysLayout::bar : {
43  kCrystalsInEta = kCrystalsInEtaBar ;
44  kCrystalsInPhi = kCrystalsInPhiBar ;
45  kTypeBoundaries = kTypeBoundariesReference;
46  break ;
47  }
48  case CrysLayout::barzflat : {
49  kCrystalsInEta = kCrystalsInEtaBarZ ;
50  kCrystalsInPhi = kCrystalsInPhiBarZ ;
51  kTypeBoundaries = kTypeBoundariesBarZflat ;
52  break ;
53  }
54  case CrysLayout::barphiflat : {
55  kCrystalsInEta = kCrystalsInEtaBarPhi ;
56  kCrystalsInPhi = kCrystalsInPhiBarPhi ;
57  kTypeBoundaries = kTypeBoundariesBarPhiFlat ;
58  break ;
59  }
60  default: {
61  break ;
62  }
63  }
64  int etaRowInModule = zside() > 0 ? (crystal()-1)/kCrystalsInPhi + 1 : kCrystalsInEta - (crystal()-1)/kCrystalsInPhi;
65  return kCrystalsInEta * ( module() -1 )
66  + kCrystalsInEta * kTypeBoundaries[(modType() -1)]
67  + etaRowInModule;
68 }
static constexpr int kCrystalsInPhiBarPhi
Definition: BTLDetId.h:42
static constexpr std::array< int, 4 > kTypeBoundariesReference
Definition: BTLDetId.h:33
static constexpr int kCrystalsInPhiBar
Definition: BTLDetId.h:38
static constexpr std::array< int, 4 > kTypeBoundariesBarZflat
Definition: BTLDetId.h:34
static constexpr std::array< int, 4 > kTypeBoundariesBarPhiFlat
Definition: BTLDetId.h:35
static constexpr int kCrystalsInEtaBarPhi
Definition: BTLDetId.h:43
static constexpr int kCrystalsInPhiTile
Definition: BTLDetId.h:36
static constexpr int kCrystalsInEtaBar
Definition: BTLDetId.h:39
int module() const
Definition: BTLDetId.h:96
static constexpr int kCrystalsInEtaBarZ
Definition: BTLDetId.h:41
int zside() const
Definition: MTDDetId.h:63
static constexpr int kCrystalsInEtaTile
Definition: BTLDetId.h:37
static constexpr int kCrystalsInPhiBarZ
Definition: BTLDetId.h:40
int modType() const
Definition: BTLDetId.h:99
int crystal() const
Definition: BTLDetId.h:102
int BTLDetId::iphi ( CrysLayout  lay) const

Returns BTL iphi index for crystal according to type tile or bar

Definition at line 4 of file BTLDetId.cc.

References bar, barphiflat, barzflat, crystal(), HALF_ROD, kCrystalsInPhiBar, kCrystalsInPhiBarPhi, kCrystalsInPhiBarZ, kCrystalsInPhiTile, MTDDetId::mtdRR(), and tile.

Referenced by column(), and hashedIndex().

4  {
5  int kCrystalsInPhi = 1;
6  switch ( lay ) {
7  case CrysLayout::tile : {
8  kCrystalsInPhi = kCrystalsInPhiTile ;
9  break ;
10  }
11  case CrysLayout::bar : {
12  kCrystalsInPhi = kCrystalsInPhiBar ;
13  break ;
14  }
15  case CrysLayout::barzflat : {
16  kCrystalsInPhi = kCrystalsInPhiBarZ ;
17  break ;
18  }
19  case CrysLayout::barphiflat : {
20  kCrystalsInPhi = kCrystalsInPhiBarPhi ;
21  break ;
22  }
23  default: {
24  break ;
25  }
26  }
27  return kCrystalsInPhi * ( ( mtdRR()%HALF_ROD > 0 ? mtdRR()%HALF_ROD : HALF_ROD ) -1 )
28  + ( crystal()%kCrystalsInPhi > 0 ? crystal()%kCrystalsInPhi : kCrystalsInPhi ) ;
29 }
static constexpr int kCrystalsInPhiBarPhi
Definition: BTLDetId.h:42
static constexpr int HALF_ROD
Definition: BTLDetId.h:49
static constexpr int kCrystalsInPhiBar
Definition: BTLDetId.h:38
int mtdRR() const
Definition: MTDDetId.h:66
static constexpr int kCrystalsInPhiTile
Definition: BTLDetId.h:36
static constexpr int kCrystalsInPhiBarZ
Definition: BTLDetId.h:40
int crystal() const
Definition: BTLDetId.h:102
int BTLDetId::modType ( ) const
inline

Returns BTL crystal type number.

Definition at line 99 of file BTLDetId.h.

References DetId::id_, and kBTLmodTypeMask.

Referenced by reco::HitPattern::encode(), geographicalId(), BTLTileDeviceSim::getHitsResponse(), BTLBarDeviceSim::getHitsResponse(), and ietaAbs().

static constexpr uint32_t kBTLmodTypeOffset
Definition: BTLDetId.h:24
static constexpr uint32_t kBTLmodTypeMask
Definition: BTLDetId.h:25
uint32_t id_
Definition: DetId.h:62
int BTLDetId::module ( ) const
inline

Returns BTL module number.

Definition at line 96 of file BTLDetId.h.

References DetId::id_, and kBTLmoduleMask.

Referenced by geographicalId(), BTLTileDeviceSim::getHitsResponse(), BTLBarDeviceSim::getHitsResponse(), and ietaAbs().

96 { return (id_>>kBTLmoduleOffset)&kBTLmoduleMask; }
static constexpr uint32_t kBTLmoduleOffset
Definition: BTLDetId.h:22
uint32_t id_
Definition: DetId.h:62
static constexpr uint32_t kBTLmoduleMask
Definition: BTLDetId.h:23
int BTLDetId::modulesPerType ( CrysLayout  lay) const

return the number of modules per type according to scenario

Definition at line 155 of file BTLDetId.cc.

References barphiflat, barzflat, kTypeBoundariesBarPhiFlat, kTypeBoundariesBarZflat, kTypeBoundariesReference, and mod().

Referenced by geographicalId(), BTLBarDeviceSim::getHitsResponse(), and validHashedIndex().

155  {
156  int mod = kTypeBoundariesReference[1];
157  if ( lay == CrysLayout::barzflat ) { mod = kTypeBoundariesBarZflat[1]; }
158  else if ( lay == CrysLayout::barphiflat ) { mod = kTypeBoundariesBarPhiFlat[1]; }
159  return mod;
160 }
static constexpr std::array< int, 4 > kTypeBoundariesReference
Definition: BTLDetId.h:33
static constexpr std::array< int, 4 > kTypeBoundariesBarZflat
Definition: BTLDetId.h:34
static constexpr std::array< int, 4 > kTypeBoundariesBarPhiFlat
Definition: BTLDetId.h:35
T mod(const T &a, const T &b)
Definition: ecalDccMap.h:4
int BTLDetId::row ( unsigned  nrows = 16) const
inline

return the row in GeomDet language

Definition at line 105 of file BTLDetId.h.

References crystal().

Referenced by BtlDigiHitsValidation::analyze(), BtlRecHitsValidation::analyze(), BtlSimHitsValidation::analyze(), BTLTileDeviceSim::getHitsResponse(), and BTLBarDeviceSim::getHitsResponse().

105  {
106  return (crystal()-1)%nrows; // anything else for now
107  }
int crystal() const
Definition: BTLDetId.h:102
static bool BTLDetId::validHashedIndex ( uint32_t  din)
inlinestatic

Definition at line 125 of file BTLDetId.h.

References geographicalId(), getUnhashedIndex(), modulesPerType(), and operator<<().

125 { return ( din < kSizeForDenseIndexing ) ; }
static constexpr int kSizeForDenseIndexing
Definition: BTLDetId.h:64

Member Data Documentation

constexpr int BTLDetId::HALF_ROD = 36
static

Definition at line 49 of file BTLDetId.h.

Referenced by BTLDetLayerGeometryBuilder::buildLayers(), and iphi().

constexpr uint32_t BTLDetId::kBTLCrystalMask = 0x3F
static

Definition at line 27 of file BTLDetId.h.

Referenced by BTLDetId().

constexpr uint32_t BTLDetId::kBTLCrystalOffset = 0
static

Definition at line 26 of file BTLDetId.h.

constexpr uint32_t BTLDetId::kBTLmodTypeMask = 0x3
static

Definition at line 25 of file BTLDetId.h.

Referenced by BTLDetId(), and modType().

constexpr uint32_t BTLDetId::kBTLmodTypeOffset = 8
static

Definition at line 24 of file BTLDetId.h.

constexpr uint32_t BTLDetId::kBTLmoduleMask = 0x3F
static

Definition at line 23 of file BTLDetId.h.

Referenced by module().

constexpr uint32_t BTLDetId::kBTLmoduleOffset = 10
static

Definition at line 22 of file BTLDetId.h.

constexpr int BTLDetId::kCrystalsInEtaBar = 16
static

Definition at line 39 of file BTLDetId.h.

Referenced by getUnhashedIndex(), and ietaAbs().

constexpr int BTLDetId::kCrystalsInEtaBarPhi = 16
static

Definition at line 43 of file BTLDetId.h.

Referenced by getUnhashedIndex(), and ietaAbs().

constexpr int BTLDetId::kCrystalsInEtaBarZ = 1
static

Definition at line 41 of file BTLDetId.h.

Referenced by getUnhashedIndex(), and ietaAbs().

constexpr int BTLDetId::kCrystalsInEtaTile = 4
static

Definition at line 37 of file BTLDetId.h.

Referenced by getUnhashedIndex(), and ietaAbs().

constexpr int BTLDetId::kCrystalsInPhiBar = 4
static

Definition at line 38 of file BTLDetId.h.

Referenced by getUnhashedIndex(), ietaAbs(), and iphi().

constexpr int BTLDetId::kCrystalsInPhiBarPhi = 3
static

Definition at line 42 of file BTLDetId.h.

Referenced by getUnhashedIndex(), ietaAbs(), and iphi().

constexpr int BTLDetId::kCrystalsInPhiBarZ = 64
static

Definition at line 40 of file BTLDetId.h.

Referenced by getUnhashedIndex(), ietaAbs(), and iphi().

constexpr int BTLDetId::kCrystalsInPhiTile = 16
static

Definition at line 36 of file BTLDetId.h.

Referenced by getUnhashedIndex(), ietaAbs(), and iphi().

constexpr int BTLDetId::kCrystalsPerROD = kModulesPerROD*kCrystalsInPhiTile*kCrystalsInEtaTile
static

Definition at line 44 of file BTLDetId.h.

constexpr int BTLDetId::kCrystalsPerRODBarPhiFlat = kModulesPerRODBarPhiFlat*kCrystalsInPhiBarPhi*kCrystalsInEtaBarPhi
static

Definition at line 46 of file BTLDetId.h.

constexpr int BTLDetId::kCrystalsPerRODBarZflat = kModulesPerRODBarZflat*kCrystalsInPhiBarZ*kCrystalsInEtaBarZ
static

Definition at line 45 of file BTLDetId.h.

constexpr int BTLDetId::kModulesPerROD = 54
static

range constants, need two sets for the time being (one for tiles and one for bars)

Definition at line 30 of file BTLDetId.h.

Referenced by BTLDetLayerGeometryBuilder::buildLayers().

constexpr int BTLDetId::kModulesPerRODBarPhiFlat = 48
static

Definition at line 32 of file BTLDetId.h.

constexpr int BTLDetId::kModulesPerRODBarZflat = 42
static

Definition at line 31 of file BTLDetId.h.

constexpr int BTLDetId::kSizeForDenseIndexing = MAX_HASH + 1
static

Definition at line 64 of file BTLDetId.h.

constexpr std::array<int,4> BTLDetId::kTypeBoundariesBarPhiFlat { { 0, 16, 32, 48 } }
static

Definition at line 35 of file BTLDetId.h.

Referenced by getUnhashedIndex(), ietaAbs(), and modulesPerType().

constexpr std::array<int,4> BTLDetId::kTypeBoundariesBarZflat { { 0, 14, 28, 42 } }
static

Definition at line 34 of file BTLDetId.h.

Referenced by getUnhashedIndex(), ietaAbs(), and modulesPerType().

constexpr std::array<int,4> BTLDetId::kTypeBoundariesReference { { 0, 18, 36, 54 } }
static
constexpr int BTLDetId::MAX_HASH = 2*MAX_IPHI_TILE*MAX_IETA_TILE-1
static

Definition at line 63 of file BTLDetId.h.

constexpr int BTLDetId::MAX_IETA_BAR = kCrystalsInEtaBar*kModulesPerROD
static

Definition at line 54 of file BTLDetId.h.

Referenced by getUnhashedIndex(), and hashedIndex().

constexpr int BTLDetId::MAX_IETA_BARPHIFLAT = kCrystalsInEtaBarPhi*kModulesPerRODBarPhiFlat
static

Definition at line 60 of file BTLDetId.h.

Referenced by getUnhashedIndex(), and hashedIndex().

constexpr int BTLDetId::MAX_IETA_BARZ = kCrystalsInEtaBarZ*kModulesPerROD
static

Definition at line 56 of file BTLDetId.h.

constexpr int BTLDetId::MAX_IETA_BARZFLAT = kCrystalsInEtaBarZ*kModulesPerRODBarZflat
static

Definition at line 58 of file BTLDetId.h.

Referenced by getUnhashedIndex(), and hashedIndex().

constexpr int BTLDetId::MAX_IETA_TILE = kCrystalsInEtaTile*kModulesPerROD
static

Definition at line 52 of file BTLDetId.h.

Referenced by getUnhashedIndex(), and hashedIndex().

constexpr int BTLDetId::MAX_IPHI_BAR = kCrystalsInPhiBar*HALF_ROD
static

Definition at line 55 of file BTLDetId.h.

Referenced by getUnhashedIndex(), and hashedIndex().

constexpr int BTLDetId::MAX_IPHI_BARPHIFLAT = kCrystalsInPhiBarPhi*HALF_ROD
static

Definition at line 61 of file BTLDetId.h.

Referenced by getUnhashedIndex(), and hashedIndex().

constexpr int BTLDetId::MAX_IPHI_BARZ = kCrystalsInPhiBarZ*HALF_ROD
static

Definition at line 57 of file BTLDetId.h.

constexpr int BTLDetId::MAX_IPHI_BARZFLAT = kCrystalsInPhiBarZ*HALF_ROD
static

Definition at line 59 of file BTLDetId.h.

Referenced by getUnhashedIndex(), and hashedIndex().

constexpr int BTLDetId::MAX_IPHI_TILE = kCrystalsInPhiTile*HALF_ROD
static

Definition at line 53 of file BTLDetId.h.

Referenced by getUnhashedIndex(), and hashedIndex().

constexpr int BTLDetId::MAX_ROD = 72
static

Definition at line 48 of file BTLDetId.h.

constexpr int BTLDetId::MIN_HASH = 0
static

Definition at line 62 of file BTLDetId.h.

constexpr int BTLDetId::MIN_IETA = 1
static

Definition at line 50 of file BTLDetId.h.

constexpr int BTLDetId::MIN_IPHI = 1
static

Definition at line 51 of file BTLDetId.h.

constexpr int BTLDetId::MIN_ROD = 1
static

Definition at line 47 of file BTLDetId.h.

Referenced by BTLDetLayerGeometryBuilder::buildLayers().