File indexing completed on 2023-03-17 13:03:33
0001 #include "Geometry/HGCalCommonData/interface/HGCalProperty.h"
0002 #include "Geometry/HGCalCommonData/interface/HGCalTileIndex.h"
0003
0004 int32_t HGCalTileIndex::tileIndex(int32_t layer, int32_t ring, int32_t phi) {
0005 int32_t id(0);
0006 id |= (((phi & HGCalProperty::kHGCalPhiMask) << HGCalProperty::kHGCalPhiOffset) |
0007 ((ring & HGCalProperty::kHGCalRingMask) << HGCalProperty::kHGCalRingOffset) |
0008 ((layer & HGCalProperty::kHGCalLayerMask) << HGCalProperty::kHGCalLayerOffset));
0009 return id;
0010 }
0011
0012 int32_t HGCalTileIndex::tileLayer(int32_t id) {
0013 return ((id >> HGCalProperty::kHGCalLayerOffset) & HGCalProperty::kHGCalLayerMask);
0014 }
0015
0016 int32_t HGCalTileIndex::tileRing(int32_t id) {
0017 return ((id >> HGCalProperty::kHGCalRingOffset) & HGCalProperty::kHGCalRingMask);
0018 }
0019
0020 int32_t HGCalTileIndex::tilePhi(int32_t id) {
0021 return ((id >> HGCalProperty::kHGCalPhiOffset) & HGCalProperty::kHGCalPhiMask);
0022 }
0023
0024 int32_t HGCalTileIndex::tileCassette(int32_t iphi, int32_t phiOffset, int32_t nphiCassette, int32_t cassettes) {
0025 int32_t cassette(0);
0026 if (nphiCassette > 1) {
0027 cassette = (iphi - phiOffset) / nphiCassette;
0028 if (cassette < 0)
0029 cassette += cassettes;
0030 else if (cassette >= cassettes)
0031 cassette = cassettes - 1;
0032 }
0033 return (cassette + 1);
0034 }
0035
0036 int32_t HGCalTileIndex::tileProperty(int32_t type, int32_t sipm) {
0037 return (((type % HGCalProperty::kHGCalFactor) * HGCalProperty::kHGCalOffsetType) +
0038 ((sipm % HGCalProperty::kHGCalFactor) * HGCalProperty::kHGCalOffsetSiPM));
0039 }
0040
0041 int32_t HGCalTileIndex::tileType(int32_t property) {
0042 return ((property / HGCalProperty::kHGCalOffsetType) % HGCalProperty::kHGCalFactor);
0043 }
0044
0045 int32_t HGCalTileIndex::tileSiPM(int32_t property) {
0046 return ((property / HGCalProperty::kHGCalOffsetSiPM) % HGCalProperty::kHGCalFactor);
0047 }
0048
0049 int32_t HGCalTileIndex::tilePack(int32_t ly, int32_t k1, int32_t k2) {
0050 return (
0051 ((ly % HGCalProperty::kHGCalTilePack) * HGCalProperty::kHGCalTilePack + (k1 % HGCalProperty::kHGCalTilePack)) *
0052 HGCalProperty::kHGCalTilePack +
0053 (k2 % HGCalProperty::kHGCalTilePack));
0054 }
0055
0056 std::tuple<int32_t, int32_t, int32_t> HGCalTileIndex::tileUnpack(int32_t index) {
0057 int32_t ly =
0058 (index / (HGCalProperty::kHGCalTilePack * HGCalProperty::kHGCalTilePack)) % HGCalProperty::kHGCalTilePack;
0059 int32_t k1 = (index / HGCalProperty::kHGCalTilePack) % HGCalProperty::kHGCalTilePack;
0060 int32_t k2 = (index % HGCalProperty::kHGCalTilePack);
0061 return std::make_tuple(ly, k1, k2);
0062 }
0063
0064 bool HGCalTileIndex::tileExist(const int32_t* hex, int32_t zside, int32_t iphi) {
0065 int32_t phi(iphi - 1);
0066 if (zside > 0) {
0067 phi += HGCalProperty::kHGCalTilePhisBy2;
0068 if (phi >= HGCalProperty::kHGCalTilePhis)
0069 phi -= HGCalProperty::kHGCalTilePhis;
0070 }
0071 int32_t jj = phi % HGCalProperty::kHGCalTilePhisBy3;
0072 int32_t iw = jj / HGCalProperty::kHGCalTilePhisBy12;
0073 int32_t ibit = HGCalProperty::kHGCalTilePhisBy12 - (jj % HGCalProperty::kHGCalTilePhisBy12) - 1;
0074 bool ok = (hex[iw] & (1 << ibit));
0075 return ok;
0076 }