#include <EcalPreshowerNumberingScheme.h>
Public Member Functions | |
EcalPreshowerNumberingScheme () | |
virtual uint32_t | getUnitID (const EcalBaseNumber &baseNumber) const |
~EcalPreshowerNumberingScheme () | |
Private Attributes | |
int | L0ax [23] |
int | L0ay [23] |
int | L0bx [1] |
int | L0by [1] |
int | L0cx [1] |
int | L0cy [1] |
int | L1ax [26] |
int | L1ay [26] |
int | L1bx [1] |
int | L1by [1] |
int | L1cx [1] |
int | L1cy [1] |
int | L1dx [1] |
int | L1dy [1] |
int | L1ex [1] |
int | L1ey [1] |
int | L2ax [3] |
int | L2ay [3] |
int | L2bx [1] |
int | L2by [1] |
int | L3ax [3] |
int | L3ay [3] |
int | L3bx [1] |
int | L3by [1] |
Definition at line 10 of file EcalPreshowerNumberingScheme.h.
EcalPreshowerNumberingScheme::EcalPreshowerNumberingScheme | ( | ) |
Definition at line 12 of file EcalPreshowerNumberingScheme.cc.
References i, L0ax, L0ay, L0bx, L0by, L0cx, L0cy, L1ax, L1ay, L1bx, L1by, L1cx, L1cy, L1dx, L1dy, L1ex, L1ey, L2ax, L2ay, L2bx, L2by, L3ax, L3ay, L3bx, and L3by.
: EcalNumberingScheme() { // For SFLX2a, we use copy# 1-3 int vL2ax[3] = { 4, 6, 10}; int vL2ay[3] = {29, 31, 35}; // For SFLX2b, we use copy# 1 int vL2bx[1] = {2}; int vL2by[1] = {25}; // For SFLX3a, we use copy# 4-6 int vL3ax[3] = {30, 34, 36}; int vL3ay[3] = {35, 31, 29}; // For SFLX3b, we use copy# 2 int vL3bx[1] = {38}; int vL3by[1] = {25}; // For SFLX1a, we use odd number in copy# 1-52 int vL1ax[26] = { 2, 4, 4, 8, 8, 8, 8, 10, 12, 12, 14, 14, 20, 20, 26, 26, 28, 28, 30, 32, 32, 32, 32, 36, 36, 38}; int vL1ay[26] = {21, 25, 21, 33, 29, 25, 21, 21, 25, 21, 31, 27, 32, 28, 31, 27, 25, 21, 21, 33, 29, 25, 21, 25, 21, 21}; // For SFLX1b, we use copy# 2 int vL1bx[1] = {22}; int vL1by[1] = {27}; // For SFLX1c, we use copy# 1 int vL1cx[1] = {18}; int vL1cy[1] = {27}; // For SFLX1d, we use copy# 2 int vL1dx[1] = {26}; int vL1dy[1] = {23}; // For SFLX1e, we use copy# 1 int vL1ex[1] = {14}; int vL1ey[1] = {23}; // For SFLX0a, we use odd number if copy# 1-46 int vL0ax[23] = { 6, 6, 10, 10, 12, 12, 14, 16, 16, 18, 18, 20, 22, 22, 24, 24, 26, 28, 28, 30, 30, 34, 34}; int vL0ay[23] = {26, 21, 30, 25, 34, 29, 35, 36, 31, 36, 31, 36, 36, 31, 36, 31, 35, 34, 29, 30, 25, 26, 21}; // For SFL0b, we use copy# 2 int vL0bx[1] = {24}; int vL0by[1] = {26}; // For SFL0c, we use copy# 1 int vL0cx[1] = {16}; int vL0cy[1] = {26}; for (int i=0; i<1; ++i) { L1bx[i] = vL1bx[i]; L1by[i] = vL1by[i]; L1cx[i] = vL1cx[i]; L1cy[i] = vL1cy[i]; L1dx[i] = vL1dx[i]; L1dy[i] = vL1dy[i]; L1ex[i] = vL1ex[i]; L1ey[i] = vL1ey[i]; L0bx[i] = vL0bx[i]; L0by[i] = vL0by[i]; L0cx[i] = vL0cx[i]; L0cy[i] = vL0cy[i]; L3bx[i] = vL3bx[i]; L3by[i] = vL3by[i]; L2bx[i] = vL2bx[i]; L2by[i] = vL2by[i]; } for (int i=0; i<3; ++i) { L3ax[i] = vL3ax[i]; L3ay[i] = vL3ay[i]; L2ax[i] = vL2ax[i]; L2ay[i] = vL2ay[i]; } for (int i=0; i<23; ++i) { L0ax[i] = vL0ax[i]; L0ay[i] = vL0ay[i]; } for (int i=0; i<26; ++i) { L1ax[i] = vL1ax[i]; L1ay[i] = vL1ay[i]; } edm::LogInfo("EcalGeom") << "Creating EcalPreshowerNumberingScheme"; }
EcalPreshowerNumberingScheme::~EcalPreshowerNumberingScheme | ( | ) |
Definition at line 91 of file EcalPreshowerNumberingScheme.cc.
{ edm::LogInfo("EcalGeom") << "Deleting EcalPreshowerNumberingScheme"; }
uint32_t EcalPreshowerNumberingScheme::getUnitID | ( | const EcalBaseNumber & | baseNumber | ) | const [virtual] |
Implements EcalNumberingScheme.
Definition at line 95 of file EcalPreshowerNumberingScheme.cc.
References EcalBaseNumber::getCopyNumber(), EcalBaseNumber::getLevelName(), EcalBaseNumber::getLevels(), L0ax, L0ay, L0bx, L0by, L0cx, L0cy, L1ax, L1ay, L1bx, L1by, L1cx, L1cy, L1dx, L1dy, L1ex, L1ey, L2ax, L2ay, L2bx, L2by, L3ax, L3ay, L3bx, L3by, testEve_cfg::level, LogDebug, DetId::rawId(), strip(), x, and detailsBasic3DVector::y.
{ int level = baseNumber.getLevels(); uint32_t intIndex = 0; if (level > 0) { // depth index - silicon layer 1-st or 2-nd int layer = 0; if(baseNumber.getLevelName(0) == "SFSX") { layer = 1; } else if (baseNumber.getLevelName(0) == "SFSY") { layer = 2; } else { edm::LogWarning("EcalGeom") << "EcalPreshowerNumberingScheme: Wrong name" << " of Presh. Si. Strip : " << baseNumber.getLevelName(0); } // Z index +Z = 1 ; -Z = 2 int zside = baseNumber.getCopyNumber("EREG"); zside=2*(1-zside)+1; // box number int box = baseNumber.getCopyNumber(2); int x=0,y=0,ix,iy,id; int mapX[10] ={0,0,0,0,0,0,0,0,0,0}; int mapY[10] ={0,0,0,0,0,0,0,0,0,0}; std::string ladd = baseNumber.getLevelName(3); int ladd_copy = baseNumber.getCopyNumber(3); if(ladd=="SFLX0a" || ladd=="SFLY0a" ) { mapX[5] = mapX[6] = mapX[7] = mapX[8] = mapX[9] = 1; mapY[0] = 0; mapY[1] = 1; mapY[2] = 2; mapY[3] = 3; mapY[4] = 4; mapY[5] = 0; mapY[6] = 1; mapY[7] = 2; mapY[8] = 3; mapY[9] = 4; id = (int) ((float)ladd_copy/2+0.5); x = L0ax[id-1] + mapX[box-1000-1]; y = L0ay[id-1] + mapY[box-1000-1]; if ((ladd_copy%2) == 0) { if (mapX[box-1000-1]==0) x += 1; else if (mapX[box-1000-1]==1) x -= 1; y = 41 - y; } } if(ladd=="SFLX0b" || ladd=="SFLY0b") { mapX[4] = mapX[5] = mapX[6] = mapX[7] = mapX[8] = 1; mapY[0] = 1; mapY[1] = 2; mapY[2] = 3; mapY[3] = 4; mapY[4] = 0; mapY[5] = 1; mapY[6] = 2; mapY[7] = 3; mapY[8] = 4; mapY[9] = 0; x = L0bx[0] + mapX[box-2000-1]; y = L0by[0] + mapY[box-2000-1]; if (ladd_copy == 1) { x = 41 - x; y = 41 - y; } } if(ladd=="SFLX0c" || ladd=="SFLY0c") { mapX[5] = mapX[6] = mapX[7] = mapX[8] = 1; mapY[0] = 0; mapY[1] = 1; mapY[2] = 2; mapY[3] = 3; mapY[4] = 4; mapY[5] = 1; mapY[6] = 2; mapY[7] = 3; mapY[8] = 4; mapY[9] = 0; x = L0cx[0] + mapX[box-3000-1]; y = L0cy[0] + mapY[box-3000-1]; if (ladd_copy == 2) { x = 41 - x; y = 41 - y; } } if(ladd=="SFLX1a" || ladd=="SFLY1a" ) { mapX[4] = mapX[5] = mapX[6] = mapX[7] = 1; mapY[0] = 0; mapY[1] = 1; mapY[2] = 2; mapY[3] = 3; mapY[4] = 0; mapY[5] = 1; mapY[6] = 2; mapY[7] = 3; mapY[8] = 0; mapY[9] = 0; id = (int) ((float)ladd_copy/2+0.5); x = L1ax[id-1] + mapX[box-4000-1]; y = L1ay[id-1] + mapY[box-4000-1]; if ((ladd_copy%2) == 0) { if (mapX[box-4000-1]==0) x += 1; else if (mapX[box-4000-1]==1) x -= 1; y = 41 - y; } } if(ladd=="SFLX1b" || ladd=="SFLY1b" ) { mapX[3] = mapX[4] = mapX[5] = mapX[6] = 1; mapY[0] = 1; mapY[1] = 2; mapY[2] = 3; mapY[3] = 0; mapY[4] = 1; mapY[5] = 2; mapY[6] = 3; mapY[7] = 0; mapY[8] = 0; mapY[9] = 0; x = L1bx[0] + mapX[box-5000-1]; y = L1by[0] + mapY[box-5000-1]; if (ladd_copy == 1) { x = 41 - x; y = 41 - y; } } if(ladd=="SFLX1c" || ladd=="SFLY1c" ) { mapX[4] = mapX[5] = mapX[6] = 1; mapY[0] = 0; mapY[1] = 1; mapY[2] = 2; mapY[3] = 3; mapY[4] = 1; mapY[5] = 2; mapY[6] = 3; mapY[7] = 0; mapY[8] = 0; mapY[9] = 0; x = L1cx[0] + mapX[box-6000-1]; y = L1cy[0] + mapY[box-6000-1]; if (ladd_copy == 2) { x = 41 - x; y = 41 - y; } } if(ladd=="SFLX1d" || ladd=="SFLY1d" ) { mapX[2] = mapX[3] = mapX[4] = mapX[5] = 1; mapY[0] = 2; mapY[1] = 3; mapY[2] = 0; mapY[3] = 1; mapY[4] = 2; mapY[5] = 3; mapY[6] = 0; mapY[7] = 0; mapY[8] = 0; mapY[9] = 0; x = L1dx[0] + mapX[box-7000-1]; y = L1dy[0] + mapY[box-7000-1]; if (ladd_copy == 1) { x = 41 - x; y = 41 - y; } } if(ladd=="SFLX1e" || ladd=="SFLY1e") { mapX[4] = mapX[5] = 1; mapY[0] = 0; mapY[1] = 1; mapY[2] = 2; mapY[3] = 3; mapY[4] = 2; mapY[5] = 3; mapY[6] = 0; mapY[7] = 0; mapY[8] = 0; mapY[9] = 0; x = L1ex[0] + mapX[box-8000-1]; y = L1ey[0] + mapY[box-8000-1]; if (ladd_copy == 2) { x = 41 - x; y = 41 - y; } } if(ladd=="SFLX3a" || ladd=="SFLY3a" ) { mapX[4] = mapX[5] = mapX[6] = 1; mapY[0] = 0; mapY[1] = 1; mapY[2] = 2; mapY[3] = 3; mapY[4] = 0; mapY[5] = 1; mapY[6] = 2; mapY[7] = 0; mapY[8] = 0; mapY[9] = 0; id = (ladd_copy>3)? ladd_copy-3 : 4-ladd_copy; x = L3ax[id-1] + mapX[box-9000-1]; y = L3ay[id-1] + mapY[box-9000-1]; if (ladd_copy<4) { x = 41 - x; y = 41 - y; } } if(ladd=="SFLX3b" || ladd=="SFLY3b") { mapX[4] = mapX[5] = 1; mapY[0] = 0; mapY[1] = 1; mapY[2] = 2; mapY[3] = 3; mapY[4] = 0; mapY[5] = 1; mapY[6] = 0; mapY[7] = 0; mapY[8] = 0; mapY[9] = 0; x = L3bx[0] + mapX[box-11000-1]; y = L3by[0] + mapY[box-11000-1]; if (ladd_copy == 1) { x = 41 - x; y = 41 - y; } } if(ladd=="SFLX2a" || ladd=="SFLY2a") { mapX[3] = mapX[4] = mapX[5] = mapX[6] = 1; mapY[0] = 0; mapY[1] = 1; mapY[2] = 2; mapY[3] = 0; mapY[4] = 1; mapY[5] = 2; mapY[6] = 3; mapY[7] = 0; mapY[8] = 0; mapY[9] = 0; id = (ladd_copy>3)? 7-ladd_copy : ladd_copy; x = L2ax[id-1] + mapX[box-10000-1]; y = L2ay[id-1] + mapY[box-10000-1]; if (ladd_copy>3) { x = 41 - x; y = 41 - y; } } if(ladd=="SFLX2b" || ladd=="SFLY2b") { mapX[2] = mapX[3] = mapX[4] = mapX[5] = 1; mapY[0] = 0; mapY[1] = 1; mapY[2] = 0; mapY[3] = 1; mapY[4] = 2; mapY[5] = 3; mapY[6] = 0; mapY[7] = 0; mapY[8] = 0; mapY[9] = 0; x = L2bx[0] + mapX[box-12000-1]; y = L2by[0] + mapY[box-12000-1]; if (ladd_copy == 2) { x = 41 - x; y = 41 - y; } } if (zside<0 && layer == 1) x = 41 - x; ix = x; iy = y; if (layer == 2) { x = (zside>0) ? iy : 41 - iy; y = 41 - ix; } // strip number inside wafer int strip = baseNumber.getCopyNumber(0); if (layer == 1) { if (zside>0 && y<=20) strip = 33 - strip; else if (zside<0 && y>20) strip = 33 - strip; } else if (layer == 2) { if (zside>0 && x<=20) strip = 33 - strip; else if (zside<0 && x>20) strip = 33 -strip; } intIndex = ESDetId(strip, x, y, layer, zside).rawId(); LogDebug("EcalGeom") << "EcalPreshowerNumberingScheme : zside "<<zside<<" Ladd "<< ladd << " ladd_copy: "<<ladd_copy<<" box "<<box<<" x "<<x<<" y "<<y<<" layer "<<layer<<" strip " << strip<<" UnitID 0x" << std::hex << intIndex << std::dec; for (int ich = 0; ich < level; ich++) { LogDebug("EcalGeom") << "Name = " << baseNumber.getLevelName(ich) << " copy = " << baseNumber.getCopyNumber(ich); } } return intIndex; }
int EcalPreshowerNumberingScheme::L0ax[23] [private] |
Definition at line 38 of file EcalPreshowerNumberingScheme.h.
Referenced by EcalPreshowerNumberingScheme(), and getUnitID().
int EcalPreshowerNumberingScheme::L0ay[23] [private] |
Definition at line 39 of file EcalPreshowerNumberingScheme.h.
Referenced by EcalPreshowerNumberingScheme(), and getUnitID().
int EcalPreshowerNumberingScheme::L0bx[1] [private] |
Definition at line 40 of file EcalPreshowerNumberingScheme.h.
Referenced by EcalPreshowerNumberingScheme(), and getUnitID().
int EcalPreshowerNumberingScheme::L0by[1] [private] |
Definition at line 41 of file EcalPreshowerNumberingScheme.h.
Referenced by EcalPreshowerNumberingScheme(), and getUnitID().
int EcalPreshowerNumberingScheme::L0cx[1] [private] |
Definition at line 42 of file EcalPreshowerNumberingScheme.h.
Referenced by EcalPreshowerNumberingScheme(), and getUnitID().
int EcalPreshowerNumberingScheme::L0cy[1] [private] |
Definition at line 43 of file EcalPreshowerNumberingScheme.h.
Referenced by EcalPreshowerNumberingScheme(), and getUnitID().
int EcalPreshowerNumberingScheme::L1ax[26] [private] |
Definition at line 28 of file EcalPreshowerNumberingScheme.h.
Referenced by EcalPreshowerNumberingScheme(), and getUnitID().
int EcalPreshowerNumberingScheme::L1ay[26] [private] |
Definition at line 29 of file EcalPreshowerNumberingScheme.h.
Referenced by EcalPreshowerNumberingScheme(), and getUnitID().
int EcalPreshowerNumberingScheme::L1bx[1] [private] |
Definition at line 30 of file EcalPreshowerNumberingScheme.h.
Referenced by EcalPreshowerNumberingScheme(), and getUnitID().
int EcalPreshowerNumberingScheme::L1by[1] [private] |
Definition at line 31 of file EcalPreshowerNumberingScheme.h.
Referenced by EcalPreshowerNumberingScheme(), and getUnitID().
int EcalPreshowerNumberingScheme::L1cx[1] [private] |
Definition at line 32 of file EcalPreshowerNumberingScheme.h.
Referenced by EcalPreshowerNumberingScheme(), and getUnitID().
int EcalPreshowerNumberingScheme::L1cy[1] [private] |
Definition at line 33 of file EcalPreshowerNumberingScheme.h.
Referenced by EcalPreshowerNumberingScheme(), and getUnitID().
int EcalPreshowerNumberingScheme::L1dx[1] [private] |
Definition at line 34 of file EcalPreshowerNumberingScheme.h.
Referenced by EcalPreshowerNumberingScheme(), and getUnitID().
int EcalPreshowerNumberingScheme::L1dy[1] [private] |
Definition at line 35 of file EcalPreshowerNumberingScheme.h.
Referenced by EcalPreshowerNumberingScheme(), and getUnitID().
int EcalPreshowerNumberingScheme::L1ex[1] [private] |
Definition at line 36 of file EcalPreshowerNumberingScheme.h.
Referenced by EcalPreshowerNumberingScheme(), and getUnitID().
int EcalPreshowerNumberingScheme::L1ey[1] [private] |
Definition at line 37 of file EcalPreshowerNumberingScheme.h.
Referenced by EcalPreshowerNumberingScheme(), and getUnitID().
int EcalPreshowerNumberingScheme::L2ax[3] [private] |
Definition at line 24 of file EcalPreshowerNumberingScheme.h.
Referenced by EcalPreshowerNumberingScheme(), and getUnitID().
int EcalPreshowerNumberingScheme::L2ay[3] [private] |
Definition at line 25 of file EcalPreshowerNumberingScheme.h.
Referenced by EcalPreshowerNumberingScheme(), and getUnitID().
int EcalPreshowerNumberingScheme::L2bx[1] [private] |
Definition at line 26 of file EcalPreshowerNumberingScheme.h.
Referenced by EcalPreshowerNumberingScheme(), and getUnitID().
int EcalPreshowerNumberingScheme::L2by[1] [private] |
Definition at line 27 of file EcalPreshowerNumberingScheme.h.
Referenced by EcalPreshowerNumberingScheme(), and getUnitID().
int EcalPreshowerNumberingScheme::L3ax[3] [private] |
Definition at line 20 of file EcalPreshowerNumberingScheme.h.
Referenced by EcalPreshowerNumberingScheme(), and getUnitID().
int EcalPreshowerNumberingScheme::L3ay[3] [private] |
Definition at line 21 of file EcalPreshowerNumberingScheme.h.
Referenced by EcalPreshowerNumberingScheme(), and getUnitID().
int EcalPreshowerNumberingScheme::L3bx[1] [private] |
Definition at line 22 of file EcalPreshowerNumberingScheme.h.
Referenced by EcalPreshowerNumberingScheme(), and getUnitID().
int EcalPreshowerNumberingScheme::L3by[1] [private] |
Definition at line 23 of file EcalPreshowerNumberingScheme.h.
Referenced by EcalPreshowerNumberingScheme(), and getUnitID().