Constructor with name, title, and type (0 for channel bins (144/HAPD), 1 for HAPD bins (1/HAPD), 2 for APD bins (4/HAPD))
22 : TH2Poly()
23{
24
26 SetName(name);
27 SetTitle(title);
29
30
31 const double rs[7] = {57.35, 65.81, 74.37, 82.868, 91.305, 99.794, 108.185};
32 const unsigned nhapds[7] = {42, 48, 54, 60, 66, 72, 78};
33 const unsigned chmap[144] = {88, 86, 96, 87, 75, 72, 97, 108, 73, 74, 98, 109, 84, 85, 120, 110, 76, 77, 132, 121, 136, 124, 99, 133, 125, 113, 122, 111, 101, 137, 134, 123, 89, 112, 100, 135, 52, 28, 3, 40, 41, 5, 15, 2, 17, 29, 27, 14, 4, 16, 1, 26, 53, 65, 0, 13, 48, 49, 39, 12, 61, 62, 25, 38, 63, 60, 24, 37, 64, 50, 51, 36, 91, 115, 140, 103, 102, 138, 128, 141, 126, 114, 116, 129, 139, 127, 142, 117, 90, 78, 143, 130, 95, 94, 104, 131, 82, 81, 118, 105, 80, 83, 119, 106, 79, 93, 92, 107, 55, 57, 47, 56, 68, 71, 46, 35, 70, 69, 45, 34, 59, 58, 23, 33, 67, 66, 11, 22, 7, 19, 44, 10, 18, 30, 21, 32, 42, 6, 9, 20, 54, 31, 43, 8};
34 const double chns[12] = { -2.88, -2.37, -1.86, -1.35, -0.84, -0.33, 0.33, 0.84, 1.35, 1.86, 2.37, 2.88};
35
36 float size = 0.5 / 2. - 0.01;
37 if (
m_type == 1) size = 7.0 / 2. - 0.5;
38 if (
m_type == 2) size = 3.3 / 2.;
39
40 float X[5], Y[5], globX[5], globY[5];
41 X[0] = -size; Y[0] = -size;
42 X[1] = size; Y[1] = -size;
43 X[2] = size; Y[2] = size;
44 X[3] = -size; Y[3] = size;
45 X[4] = -size; Y[4] = -size;
46
47 int nhapd = 1;
48 unsigned iring = 0;
49 unsigned ihapd = 0;
50
51 std::vector<unsigned> ids;
52 if (moduleIDs.size() > 0) ids = moduleIDs;
53 else {
54 for (int hapdID = 1; hapdID < 421; hapdID++) {
55 ids.push_back(hapdID);
56 }
57 }
58
59
61 for (int hapdID = 1; hapdID < 421; hapdID++) {
62
63
64
65 float r = rs[iring];
66 float dphi = 2.*M_PI / nhapds[iring];
67 float fi = dphi / 2. + ihapd * dphi;
68 ROOT::Math::XYVector centerPos(r * cos(fi), r * sin(fi));
69 for (int i = 0; i < 5; i++) {
70 float rotX = X[i] * cos(fi) - Y[i] * sin(fi);
71 float rotY = X[i] * sin(fi) + Y[i] * cos(fi);
72 globX[i] = rotX + centerPos.X();
73 globY[i] = rotY + centerPos.Y();
74 }
75 if (std::find(ids.begin(), ids.end(), hapdID) != ids.end()) {
77 nhapd++;
78 TGraph* mybox = new TGraph(5, globX, globY);
79 mybox->SetName((to_string(hapdID)).c_str());
80 AddBin(mybox);
81 }
82 ihapd++;
83 if (ihapd == nhapds[iring]) { iring++; ihapd = 0;}
84 }
85
87 for (int hapdID = 1; hapdID < 421; hapdID++) {
88
89
90
91 float dphi = 2.*M_PI / nhapds[iring];
92 float fi = dphi / 2. + ihapd * dphi;
93 float r = rs[iring];
94 for (int chID = 0; chID < 144; chID++) {
95
96 unsigned chX = chmap[chID] % 12;
97 unsigned chY = chmap[chID] / 12;
98 ROOT::Math::XYVector hapdPos(r * cos(fi), r * sin(fi));
99 ROOT::Math::XYVector locPos(chns[chX], chns[chY]);
100 ROOT::Math::XYVector rotatedLocPos(locPos.X() * std::cos(fi) - locPos.Y() * std::sin(fi),
101 locPos.X() * std::sin(fi) + locPos.Y() * std::cos(fi));
102 ROOT::Math::XYVector centerPos = hapdPos + rotatedLocPos;
103
104 for (int i = 0; i < 5; i++) {
105 float rotX = X[i] * cos(fi) - Y[i] * sin(fi);
106 float rotY = X[i] * sin(fi) + Y[i] * cos(fi);
107 globX[i] = rotX + centerPos.X();
108 globY[i] = rotY + centerPos.Y();
109 }
110 if (std::find(ids.begin(), ids.end(), hapdID) != ids.end()) {
112 if (chID == 143) nhapd++;
113 TGraph* mybox = new TGraph(5, globX, globY);
114 mybox->SetName((to_string(hapdID)).c_str());
115 AddBin(mybox);
116 }
117 }
118 ihapd++;
119 if (ihapd == nhapds[iring]) { iring++; ihapd = 0;}
120 }
122 size += 0.2;
123 for (int hapdID = 1; hapdID < 421; hapdID++) {
124 float dphi = 2.*M_PI / nhapds[iring];
125 float fi = dphi / 2. + ihapd * dphi;
126 float r = rs[iring];
127 ROOT::Math::XYVector hapdPos(r * cos(fi), r * sin(fi));
128 for (int chipID = 0; chipID < 4; chipID++) {
129 ROOT::Math::XYVector locPos(-size + (chipID / 2)*size * 2, size - (chipID % 2)*size * 2);
130 ROOT::Math::XYVector rotatedLocPos(locPos.X() * std::cos(fi) - locPos.Y() * std::sin(fi),
131 locPos.X() * std::sin(fi) + locPos.Y() * std::cos(fi));
132 ROOT::Math::XYVector centerPos = hapdPos + rotatedLocPos;
133
134 for (int i = 0; i < 5; i++) {
135 float rotX = X[i] * cos(fi) - Y[i] * sin(fi);
136 float rotY = X[i] * sin(fi) + Y[i] * cos(fi);
137 globX[i] = rotX + centerPos.X();
138 globY[i] = rotY + centerPos.Y();
139 }
140
141 if (std::find(ids.begin(), ids.end(), hapdID) != ids.end()) {
143 if (chipID == 3) nhapd++;
144 TGraph* mybox = new TGraph(5, globX, globY);
145 mybox->SetName((to_string(hapdID)).c_str());
146 AddBin(mybox);
147 }
148 }
149 ihapd++;
150 if (ihapd == nhapds[iring]) { iring++; ihapd = 0;}
151 }
152 } else std::cout << "Invalid histogram type! use 0 for channel bins or 1 for HAPD bins" << std::endl;
153 SetOption("colz");
154 SetStats(0);
155 GetXaxis()->SetLimits(-115., 115.);
156 GetYaxis()->SetLimits(-115., 115.);
157}
std::vector< unsigned > m_hapd2binMap
map of bins