File indexing completed on 2023-10-25 10:00:55
0001 #ifndef _RECOMET_METALGORITHMS_HCALHPDRBXMAP_H_
0002 #define _RECOMET_METALGORITHMS_HCALHPDRBXMAP_H_
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017
0018 #include "DataFormats/HcalDetId/interface/HcalDetId.h"
0019 #include <vector>
0020 #include <array>
0021
0022 class HcalHPDRBXMap {
0023 public:
0024
0025
0026 const static int NUM_HPDS = 288;
0027
0028 const static int NUM_HPDS_PER_SUBDET = 72;
0029
0030 const static int NUM_HPDS_PER_RBX = 4;
0031
0032 const static int NUM_RBXS = 72;
0033
0034 const static int NUM_RBXS_PER_SUBDET = 18;
0035
0036
0037 inline int static numHPDs(void) { return NUM_HPDS; }
0038 inline int static numHPDsPerSubdet(void) { return NUM_HPDS_PER_SUBDET; }
0039 inline int static numHPDsPerRBX(void) { return NUM_HPDS_PER_RBX; }
0040 inline int static numRBXs(void) { return NUM_RBXS; }
0041 inline int static numRBXsPerSubdet(void) { return NUM_RBXS_PER_SUBDET; }
0042
0043
0044
0045 bool static isValidHPD(int index);
0046 bool static isValidRBX(int index);
0047
0048
0049
0050 bool static isValid(const HcalDetId&);
0051
0052
0053 bool static isValid(int ieta, int iphi);
0054
0055
0056
0057 HcalSubdetector static subdetHPD(int index);
0058 HcalSubdetector static subdetRBX(int index);
0059 int static zsideHPD(int index);
0060 int static zsideRBX(int index);
0061 int static iphiloHPD(int index);
0062 int static iphiloRBX(int index);
0063 int static iphihiHPD(int index);
0064 int static iphihiRBX(int index);
0065
0066
0067
0068
0069 void static indicesHPDfromRBX(int rbxindex, std::array<int, NUM_HPDS_PER_RBX>& hpdindices);
0070
0071
0072
0073 int static indexRBXfromHPD(int hpdindex);
0074
0075
0076
0077 int static indexHPD(const HcalDetId&);
0078 int static indexRBX(const HcalDetId&);
0079
0080
0081
0082 void static indexHPDfromEtaPhi(int ieta, int iphi, std::vector<int>& hpdindices);
0083 void static indexRBXfromEtaPhi(int ieta, int iphi, std::vector<int>& rbxindices);
0084
0085 private:
0086 HcalHPDRBXMap();
0087 ~HcalHPDRBXMap();
0088 };
0089
0090 #endif