CMS 3D CMS Logo

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

#include <AHCalDetId.h>

Inheritance diagram for AHCalDetId:
DetId

Public Member Functions

 AHCalDetId ()
 
 AHCalDetId (uint32_t rawid)
 
 AHCalDetId (int row, int col, int depth)
 
 AHCalDetId (const DetId &id)
 
int depth () const
 
std::pair< double, double > getXY () const
 get the local coordinate in the plane and along depth More...
 
double getZ () const
 
int icol () const
 get the column number More...
 
int icolAbs () const
 
int irow () const
 get the row number More...
 
int irowAbs () const
 
AHCalDetIdoperator= (const DetId &id)
 
HcalSubdetector subdet () const
 get the subdetector 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 (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...
 

Public Attributes

const double deltaX_ = 3.0
 
const double deltaY_ = 3.0
 
const double deltaZ_ = 8.1
 
const double zFirst_ = 1.76
 

Static Public Attributes

static const int MaxDepth = 12
 get the layer number More...
 
static const AHCalDetId 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

Cell identifier class for the HCAL subdetectors, precision readout cells only

Definition at line 13 of file AHCalDetId.h.

Constructor & Destructor Documentation

AHCalDetId::AHCalDetId ( )

Create a null cellid

Definition at line 7 of file AHCalDetId.cc.

7 : DetId() {}
constexpr DetId()
Create an empty or null id (also for persistence)
Definition: DetId.h:30
AHCalDetId::AHCalDetId ( uint32_t  rawid)

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

Definition at line 9 of file AHCalDetId.cc.

9 : DetId(rawid) {}
constexpr DetId()
Create an empty or null id (also for persistence)
Definition: DetId.h:30
AHCalDetId::AHCalDetId ( int  row,
int  col,
int  depth 
)

Constructor from subdetector, signed tower ieta,iphi,and depth

Definition at line 11 of file AHCalDetId.cc.

References icol(), DetId::id_, irow(), HcalDetId::kHcalDepthMask2, HcalDetId::kHcalDepthOffset2, HcalDetId::kHcalEtaMask2, HcalDetId::kHcalEtaOffset2, HcalDetId::kHcalIdFormat2, HcalDetId::kHcalPhiMask2, and HcalDetId::kHcalZsideMask2.

11  : DetId(Hcal, HcalOther) {
12  int icol = (col > 0) ? col : 10 - col;
13  int irow = (row > 0) ? row : 10 - row;
14  id_ |=
19  (icol & HcalDetId::kHcalPhiMask2);
20 }
static uint32_t kHcalEtaMask2
Definition: HcalDetId.h:21
int irow() const
get the row number
Definition: AHCalDetId.cc:34
int depth() const
Definition: AHCalDetId.cc:46
int icol() const
get the column number
Definition: AHCalDetId.cc:40
static uint32_t kHcalDepthMask2
Definition: HcalDetId.h:27
static uint32_t kHcalPhiMask2
Definition: HcalDetId.h:17
uint32_t id_
Definition: DetId.h:62
static uint32_t kHcalEtaOffset2
Definition: HcalDetId.h:19
static uint32_t kHcalIdFormat2
Definition: HcalDetId.h:30
static uint32_t kHcalZsideMask2
Definition: HcalDetId.h:23
col
Definition: cuy.py:1010
static uint32_t kHcalDepthOffset2
Definition: HcalDetId.h:25
constexpr DetId()
Create an empty or null id (also for persistence)
Definition: DetId.h:30
AHCalDetId::AHCalDetId ( const DetId id)

Constructor from a generic cell id

Definition at line 22 of file AHCalDetId.cc.

References TauDecayModes::dec, DetId::det(), Exception, DetId::Hcal, HcalOther, DetId::id_, DetId::null(), DetId::rawId(), subdet(), and DetId::subdetId().

22  {
23  if (!gen.null()) {
24  HcalSubdetector subdet = (HcalSubdetector(gen.subdetId()));
25  if (gen.det() != Hcal || subdet != HcalOther) {
26  throw cms::Exception("Invalid DetId")
27  << "Cannot initialize AHCalDetId from " << std::hex << gen.rawId()
28  << std::dec;
29  }
30  }
31  id_ = gen.rawId();
32 }
HcalSubdetector subdet() const
get the subdetector
Definition: AHCalDetId.h:30
HcalSubdetector
Definition: HcalAssistant.h:31
uint32_t id_
Definition: DetId.h:62

Member Function Documentation

int AHCalDetId::depth ( void  ) const

Definition at line 46 of file AHCalDetId.cc.

References DetId::id_, HcalDetId::kHcalDepthMask2, and HcalDetId::kHcalDepthOffset2.

Referenced by HGCalTBAnalyzer::analyzeSimHits(), getZ(), and AHCalSD::unpackIndex().

46  {
48 }
static uint32_t kHcalDepthMask2
Definition: HcalDetId.h:27
uint32_t id_
Definition: DetId.h:62
static uint32_t kHcalDepthOffset2
Definition: HcalDetId.h:25
std::pair< double, double > AHCalDetId::getXY ( ) const

get the local coordinate in the plane and along depth

Definition at line 50 of file AHCalDetId.cc.

References cuy::col, deltaX_, deltaY_, icol(), and irow().

Referenced by HGCalTBAnalyzer::analyzeSimHits().

50  {
51  int row = irow();
52  int col = icol();
53  double shiftx = (col > 0) ? -0.5 * deltaX_ : 0.5 * deltaX_;
54  double shifty = (row > 0) ? -0.5 * deltaY_ : 0.5 * deltaY_;
55  return std::pair<double, double>(col * deltaX_ + shiftx,
56  row * deltaY_ + shifty);
57 }
int irow() const
get the row number
Definition: AHCalDetId.cc:34
int icol() const
get the column number
Definition: AHCalDetId.cc:40
col
Definition: cuy.py:1010
const double deltaX_
Definition: AHCalDetId.h:49
const double deltaY_
Definition: AHCalDetId.h:50
double AHCalDetId::getZ ( ) const

Definition at line 59 of file AHCalDetId.cc.

References deltaZ_, depth(), and zFirst_.

Referenced by HGCalTBAnalyzer::analyzeSimHits().

59  {
60  int lay = depth();
61  return (zFirst_ + (lay - 1) * deltaZ_);
62 }
const double zFirst_
Definition: AHCalDetId.h:52
int depth() const
Definition: AHCalDetId.cc:46
const double deltaZ_
Definition: AHCalDetId.h:51
int AHCalDetId::icol ( ) const

get the column number

Definition at line 40 of file AHCalDetId.cc.

References DetId::id_, HcalDetId::kHcalPhiMask2, and relativeConstraints::value.

Referenced by AHCalDetId(), HGCalTBAnalyzer::analyzeSimHits(), getXY(), irowAbs(), and AHCalSD::unpackIndex().

40  {
42  if (value >= 10) value = -(value % 10);
43  return value;
44 }
Definition: value.py:1
static uint32_t kHcalPhiMask2
Definition: HcalDetId.h:17
uint32_t id_
Definition: DetId.h:62
int AHCalDetId::icolAbs ( ) const
inline

Definition at line 40 of file AHCalDetId.h.

References DetId::id_, and HcalDetId::kHcalPhiMask2.

Referenced by HGCalTBAnalyzer::analyzeSimHits().

40 { return (id_ & HcalDetId::kHcalPhiMask2); }
static uint32_t kHcalPhiMask2
Definition: HcalDetId.h:17
uint32_t id_
Definition: DetId.h:62
int AHCalDetId::irow ( ) const

get the row number

Definition at line 34 of file AHCalDetId.cc.

References DetId::id_, HcalDetId::kHcalEtaMask2, HcalDetId::kHcalEtaOffset2, and relativeConstraints::value.

Referenced by AHCalDetId(), HGCalTBAnalyzer::analyzeSimHits(), getXY(), AHCalSD::unpackIndex(), and zside().

34  {
36  if (value >= 10) value = -(value % 10);
37  return value;
38 }
static uint32_t kHcalEtaMask2
Definition: HcalDetId.h:21
Definition: value.py:1
uint32_t id_
Definition: DetId.h:62
static uint32_t kHcalEtaOffset2
Definition: HcalDetId.h:19
int AHCalDetId::irowAbs ( ) const
inline

Definition at line 35 of file AHCalDetId.h.

References icol(), DetId::id_, HcalDetId::kHcalEtaMask2, and HcalDetId::kHcalEtaOffset2.

Referenced by HGCalTBAnalyzer::analyzeSimHits().

35  {
37  }
static uint32_t kHcalEtaMask2
Definition: HcalDetId.h:21
uint32_t id_
Definition: DetId.h:62
static uint32_t kHcalEtaOffset2
Definition: HcalDetId.h:19
AHCalDetId& AHCalDetId::operator= ( const DetId id)
inline

Assignment from a generic cell id

Definition at line 24 of file AHCalDetId.h.

References DetId::id_.

24  {
25  id_ = id.rawId();
26  return *this;
27  }
uint32_t id_
Definition: DetId.h:62
HcalSubdetector AHCalDetId::subdet ( ) const
inline

get the subdetector

Definition at line 30 of file AHCalDetId.h.

References HcalOther.

Referenced by AHCalDetId().

30 { return HcalOther; }
int AHCalDetId::zside ( ) const
inline

get the z-side of the cell (1/-1)

Definition at line 32 of file AHCalDetId.h.

References irow().

Referenced by HGCalTBAnalyzer::analyzeSimHits().

32 { return 1; }

Member Data Documentation

const double AHCalDetId::deltaX_ = 3.0

Definition at line 49 of file AHCalDetId.h.

Referenced by getXY().

const double AHCalDetId::deltaY_ = 3.0

Definition at line 50 of file AHCalDetId.h.

Referenced by getXY().

const double AHCalDetId::deltaZ_ = 8.1

Definition at line 51 of file AHCalDetId.h.

Referenced by getZ().

const int AHCalDetId::MaxDepth = 12
static

get the layer number

Definition at line 42 of file AHCalDetId.h.

Referenced by HGCalTBAnalyzer::analyze(), and HGCalTBAnalyzer::beginRun().

const AHCalDetId AHCalDetId::Undefined
static

Definition at line 48 of file AHCalDetId.h.

const double AHCalDetId::zFirst_ = 1.76

Definition at line 52 of file AHCalDetId.h.

Referenced by getZ().