]>
Commit | Line | Data |
---|---|---|
2906f4c2 | 1 | /************************************************************************** |
2 | * Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. * | |
3 | * * | |
4 | * Author: The ALICE Off-line Project. * | |
5 | * Contributors are mentioned in the code where appropriate. * | |
6 | * * | |
7 | * Permission to use, copy, modify and distribute this software and its * | |
8 | * documentation strictly for non-commercial purposes is hereby granted * | |
9 | * without fee, provided that the above copyright notice appears in all * | |
10 | * copies and that both the copyright notice and this permission notice * | |
11 | * appear in the supporting documentation. The authors make no claims * | |
12 | * about the suitability of this software for any purpose. It is * | |
13 | * provided "as is" without express or implied warranty. * | |
14 | **************************************************************************/ | |
15 | ||
16 | /* $Id$ */ | |
17 | ||
18 | /////////////////////////////////////////////////////////////////////////////// | |
19 | /// | |
20 | /// This class provides access to ITS SSD digits in raw data. | |
bd1231b5 | 21 | // Revised by Enrico Fragiacomo |
22 | // Last update: 2007/09/06 | |
2906f4c2 | 23 | /// |
24 | /////////////////////////////////////////////////////////////////////////////// | |
25 | ||
8297cd8f | 26 | #include "Riostream.h" |
5c3b40f1 | 27 | #include "TGeoManager.h" |
28 | #include "TGeoVolume.h" | |
83d029cd | 29 | #include <TClass.h> |
5c3b40f1 | 30 | |
2906f4c2 | 31 | #include "AliITSRawStreamSSD.h" |
32 | #include "AliRawReader.h" | |
812a6a14 | 33 | #include "AliLog.h" |
2906f4c2 | 34 | |
35 | ClassImp(AliITSRawStreamSSD) | |
83d029cd | 36 | |
37 | Bool_t AliITSRawStreamSSD::fgkDDLModuleMapInit = kFALSE; | |
5c3b40f1 | 38 | Int_t AliITSRawStreamSSD::fgkDDLModuleMap[kDDLsNumber][kModulesPerDDL] = { |
39 | {0,0,0,0,0,0,0,0,0,0,0,0, | |
40 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
41 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
42 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
43 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
44 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
45 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
46 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
47 | 0,0,0,0,0,0,0,0,0,0,0,0}, | |
48 | ||
49 | {0,0,0,0,0,0,0,0,0,0,0,0, | |
50 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
51 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
52 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
53 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
54 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
55 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
56 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
57 | 0,0,0,0,0,0,0,0,0,0,0,0}, | |
58 | ||
59 | {0,0,0,0,0,0,0,0,0,0,0,0, | |
60 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
61 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
62 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
63 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
64 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
65 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
66 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
67 | 0,0,0,0,0,0,0,0,0,0,0,0}, | |
68 | ||
69 | {0,0,0,0,0,0,0,0,0,0,0,0, | |
70 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
71 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
72 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
73 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
74 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
75 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
76 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
77 | 0,0,0,0,0,0,0,0,0,0,0,0}, | |
78 | ||
79 | {0,0,0,0,0,0,0,0,0,0,0,0, | |
80 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
81 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
82 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
83 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
84 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
85 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
86 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
87 | 0,0,0,0,0,0,0,0,0,0,0,0}, | |
88 | ||
89 | {0,0,0,0,0,0,0,0,0,0,0,0, | |
90 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
91 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
92 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
93 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
94 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
95 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
96 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
97 | 0,0,0,0,0,0,0,0,0,0,0,0}, | |
98 | ||
99 | {0,0,0,0,0,0,0,0,0,0,0,0, | |
100 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
101 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
102 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
103 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
104 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
105 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
106 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
107 | 0,0,0,0,0,0,0,0,0,0,0,0}, | |
108 | ||
109 | {0,0,0,0,0,0,0,0,0,0,0,0, | |
110 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
111 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
112 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
113 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
114 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
115 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
116 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
117 | 0,0,0,0,0,0,0,0,0,0,0,0}, | |
118 | ||
119 | {0,0,0,0,0,0,0,0,0,0,0,0, | |
120 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
121 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
122 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
123 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
124 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
125 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
126 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
127 | 0,0,0,0,0,0,0,0,0,0,0,0}, | |
128 | ||
129 | {0,0,0,0,0,0,0,0,0,0,0,0, | |
130 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
131 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
132 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
133 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
134 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
135 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
136 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
137 | 0,0,0,0,0,0,0,0,0,0,0,0}, | |
138 | ||
139 | {0,0,0,0,0,0,0,0,0,0,0,0, | |
140 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
141 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
142 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
143 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
144 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
145 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
146 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
147 | 0,0,0,0,0,0,0,0,0,0,0,0}, | |
148 | ||
149 | {0,0,0,0,0,0,0,0,0,0,0,0, | |
150 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
151 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
152 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
153 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
154 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
155 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
156 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
157 | 0,0,0,0,0,0,0,0,0,0,0,0}, | |
158 | ||
159 | {0,0,0,0,0,0,0,0,0,0,0,0, | |
160 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
161 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
162 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
163 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
164 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
165 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
166 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
167 | 0,0,0,0,0,0,0,0,0,0,0,0}, | |
168 | ||
169 | {0,0,0,0,0,0,0,0,0,0,0,0, | |
170 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
171 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
172 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
173 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
174 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
175 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
176 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
177 | 0,0,0,0,0,0,0,0,0,0,0,0}, | |
178 | ||
179 | {0,0,0,0,0,0,0,0,0,0,0,0, | |
180 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
181 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
182 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
183 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
184 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
185 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
186 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
187 | 0,0,0,0,0,0,0,0,0,0,0,0}, | |
188 | ||
189 | {0,0,0,0,0,0,0,0,0,0,0,0, | |
190 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
191 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
192 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
193 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
194 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
195 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
196 | 0,0,0,0,0,0,0,0,0,0,0,0, | |
197 | 0,0,0,0,0,0,0,0,0,0,0,0} | |
198 | }; | |
199 | ||
200 | AliITSRawStreamSSD::AliITSRawStreamSSD(AliRawReader* rawReader) : | |
201 | AliITSRawStream(rawReader), | |
202 | fddl(0), | |
203 | fad(0), | |
204 | fadc(0), | |
205 | flag(0), | |
206 | fData(0) { | |
207 | // create an object to read ITS SSD raw digits | |
bd1231b5 | 208 | |
5c3b40f1 | 209 | if(!gGeoManager){ |
210 | AliError("Geometry is not initialized\n"); | |
211 | return; | |
212 | } | |
213 | TGeoVolume *v = NULL; | |
214 | v = gGeoManager->GetVolume("ITSssdSensitivL5"); | |
215 | if(!v) { | |
5c3b40f1 | 216 | // new geometry AliITSvPPRasymmFMD |
901a011d | 217 | AliDebugClass(1,"Enabling the SSD DDL mapping for the AliITSvPPRasymmFMD"); |
5c3b40f1 | 218 | SetvPPRasymmFMDDDLMapping(); |
219 | } | |
b7980dfe | 220 | else { |
221 | // new geometry AliITSv11Hybrid | |
901a011d | 222 | AliDebugClass(1,"Enabling the SSD DDL mapping for the AliITSv11Hybrid"); |
b7980dfe | 223 | Setv11HybridDDLMapping(); |
224 | } | |
5c3b40f1 | 225 | // fRawReader->Reset(); |
226 | fRawReader->Select("ITSSSD"); | |
227 | } | |
228 | ||
83d029cd | 229 | Int_t AliITSRawStreamSSD::GetModuleNumber(UInt_t iDDL, UInt_t iModule) |
230 | { | |
231 | if (!fgkDDLModuleMapInit) { | |
232 | if (!InitDDLModuleMap()) return -1; | |
233 | } | |
234 | return fgkDDLModuleMap[iDDL][iModule]; | |
235 | } | |
236 | ||
237 | Bool_t AliITSRawStreamSSD::InitDDLModuleMap() | |
238 | { | |
239 | // Initialize the DDL | |
240 | // module map | |
241 | if(!gGeoManager){ | |
242 | AliErrorClass("Geometry is not initialized\n"); | |
243 | return kFALSE; | |
244 | } | |
245 | TGeoVolume *v = NULL; | |
246 | v = gGeoManager->GetVolume("ITSssdSensitivL5"); | |
247 | if(!v) { | |
248 | // new geometry AliITSvPPRasymmFMD | |
901a011d | 249 | AliDebugClass(1,"Enabling the SSD DDL mapping for the AliITSvPPRasymmFMD"); |
83d029cd | 250 | SetvPPRasymmFMDDDLMapping(); |
251 | } | |
252 | else { | |
253 | // new geometry AliITSv11Hybrid | |
901a011d | 254 | AliDebugClass(1,"Enabling the SSD DDL mapping for the AliITSv11Hybrid"); |
83d029cd | 255 | Setv11HybridDDLMapping(); |
256 | } | |
257 | fgkDDLModuleMapInit = kTRUE; | |
258 | return kTRUE; | |
259 | } | |
260 | ||
5c3b40f1 | 261 | void AliITSRawStreamSSD::Setv11HybridDDLMapping() { |
262 | //DDL mapping v11Hybrid | |
263 | Int_t kDDLModuleMap[kDDLsNumber][kModulesPerDDL] = { | |
264 | ||
29f71fab | 265 | // ddl0 |
266 | {753,752,743,742,745,744,747,746,749,748,751,750,775,774,765,764,767,766,769,768,771,770,773,772,797,796,787,786,789,788,791,790,793,792,795,794,1549,1548,1551,1550,1553,1552,1555,1554,1557,1556,1559,1558,1599,1598,1601,1600,1603,1602,1605,1604,1607,1606,1609,1608,1624,1623,1626,1625,1628,1627,1630,1629,1632,1631,1634,1633,731,730,721,720,723,722,725,724,727,726,729,728,1524,1523,1526,1525,1528,1527,1530,1529,1532,1531,1534,1533,1574,1573,1576,1575,1578,1577,1580,1579,1582,1581,1584,1583}, | |
267 | ||
268 | // ddl1 | |
269 | {819,818,809,808,811,810,813,812,815,814,817,816,841,840,831,830,833,832,835,834,837,836,839,838,863,862,853,852,855,854,857,856,859,858,861,860,1649,1648,1651,1650,1653,1652,1655,1654,1657,1656,1659,1658,1674,1673,1676,1675,1678,1677,1680,1679,1682,1681,1684,1683,1724,1723,1726,1725,1728,1727,1730,1729,1732,1731,1734,1733,885,884,875,874,877,876,879,878,881,880,883,882,907,906,897,896,899,898,901,900,903,902,905,904,1699,1698,1701,1700,1703,1702,1705,1704,1707,1706,1709,1708}, | |
270 | ||
271 | // ddl2 | |
272 | {951,950,941,940,943,942,945,944,947,946,949,948,973,972,963,962,965,964,967,966,969,968,971,970,995,994,985,984,987,986,989,988,991,990,993,992,1774,1773,1776,1775,1778,1777,1780,1779,1782,1781,1784,1783,1824,1823,1826,1825,1828,1827,1830,1829,1832,1831,1834,1833,1849,1848,1851,1850,1853,1852,1855,1854,1857,1856,1859,1858,929,928,919,918,921,920,923,922,925,924,927,926,1749,1748,1751,1750,1753,1752,1755,1754,1757,1756,1759,1758,1799,1798,1801,1800,1803,1802,1805,1804,1807,1806,1809,1808}, | |
273 | ||
274 | // ddl3 | |
275 | {1017,1016,1007,1006,1009,1008,1011,1010,1013,1012,1015,1014,1039,1038,1029,1028,1031,1030,1033,1032,1035,1034,1037,1036,1061,1060,1051,1050,1053,1052,1055,1054,1057,1056,1059,1058,1874,1873,1876,1875,1878,1877,1880,1879,1882,1881,1884,1883,1899,1898,1901,1900,1903,1902,1905,1904,1907,1906,1909,1908,1949,1948,1951,1950,1953,1952,1955,1954,1957,1956,1959,1958,1083,1082,1073,1072,1075,1074,1077,1076,1079,1078,1081,1080,1924,1923,1926,1925,1928,1927,1930,1929,1932,1931,1934,1933,1974,1973,1976,1975,1978,1977,1980,1979,1982,1981,1984,1983}, | |
276 | ||
277 | // ddl4 | |
278 | {1127,1126,1117,1116,1119,1118,1121,1120,1123,1122,1125,1124,1149,1148,1139,1138,1141,1140,1143,1142,1145,1144,1147,1146,1171,1170,1161,1160,1163,1162,1165,1164,1167,1166,1169,1168,2024,2023,2026,2025,2028,2027,2030,2029,2032,2031,2034,2033,2074,2073,2076,2075,2078,2077,2080,2079,2082,2081,2084,2083,2099,2098,2101,2100,2103,2102,2105,2104,2107,2106,2109,2108,1105,1104,1095,1094,1097,1096,1099,1098,1101,1100,1103,1102,1999,1998,2001,2000,2003,2002,2005,2004,2007,2006,2009,2008,2049,2048,2051,2050,2053,2052,2055,2054,2057,2056,2059,2058}, | |
279 | ||
280 | // ddl5 | |
281 | {1193,1192,1183,1182,1185,1184,1187,1186,1189,1188,1191,1190,1215,1214,1205,1204,1207,1206,1209,1208,1211,1210,1213,1212,1237,1236,1227,1226,1229,1228,1231,1230,1233,1232,1235,1234,1249,1248,1251,1250,1253,1252,1255,1254,1257,1256,1259,1258,2124,2123,2126,2125,2128,2127,2130,2129,2132,2131,2134,2133,2149,2148,2151,2150,2153,2152,2155,2154,2157,2156,2159,2158,511,510,501,500,503,502,505,504,507,506,509,508,533,532,523,522,525,524,527,526,529,528,531,530,2174,2173,2176,2175,2178,2177,2180,2179,2182,2181,2184,2183}, | |
282 | ||
283 | // ddl6 | |
284 | {577,576,567,566,569,568,571,570,573,572,575,574,599,598,589,588,591,590,593,592,595,594,597,596,621,620,611,610,613,612,615,614,617,616,619,618,1299,1298,1301,1300,1303,1302,1305,1304,1307,1306,1309,1308,1349,1348,1351,1350,1353,1352,1355,1354,1357,1356,1359,1358,1374,1373,1376,1375,1378,1377,1380,1379,1382,1381,1384,1383,555,554,545,544,547,546,549,548,551,550,553,552,1274,1273,1276,1275,1278,1277,1280,1279,1282,1281,1284,1283,1324,1323,1326,1325,1328,1327,1330,1329,1332,1331,1334,1333}, | |
285 | ||
286 | // ddl7 | |
287 | {643,642,633,632,635,634,637,636,639,638,641,640,665,664,655,654,657,656,659,658,661,660,663,662,687,686,677,676,679,678,681,680,683,682,685,684,1399,1398,1401,1400,1403,1402,1405,1404,1407,1406,1409,1408,1424,1423,1426,1425,1428,1427,1430,1429,1432,1431,1434,1433,1474,1473,1476,1475,1478,1477,1480,1479,1482,1481,1484,1483,709,708,699,698,701,700,703,702,705,704,707,706,1449,1448,1451,1450,1453,1452,1455,1454,1457,1456,1459,1458,1499,1498,1501,1500,1503,1502,1505,1504,1507,1506,1509,1508}, | |
288 | ||
289 | // ddl8 | |
704b0bab | 290 | {1560,-1,762,763,760,761,758,759,756,757,754,755,1635,-1,784,785,782,783,780,781,778,779,776,777,1610,-1,806,807,804,805,802,803,800,801,798,799,1571,1572,1569,1570,1567,1568,1565,1566,1563,1564,1561,1562,1621,1622,1619,1620,1617,1618,1615,1616,1613,1614,1611,1612,1646,1647,1644,1645,1642,1643,1640,1641,1638,1639,1636,1637,1535,1585,740,741,738,739,736,737,734,735,732,733,1546,1547,1544,1545,1542,1543,1540,1541,1538,1539,1536,1537,1596,1597,1594,1595,1592,1593,1590,1591,1588,1589,1586,1587}, |
29f71fab | 291 | |
292 | // ddl9 | |
704b0bab | 293 | {1685,-1,828,829,826,827,824,825,822,823,820,821,1660,-1,850,851,848,849,846,847,844,845,842,843,1735,-1,872,873,870,871,868,869,866,867,864,865,1671,1672,1669,1670,1667,1668,1665,1666,1663,1664,1661,1662,1696,1697,1694,1695,1692,1693,1690,1691,1688,1689,1686,1687,1746,1747,1744,1745,1742,1743,1740,1741,1738,1739,1736,1737,-1,1710,894,895,892,893,890,891,888,889,886,887,-1,-1,916,917,914,915,912,913,910,911,908,909,1721,1722,1719,1720,1717,1718,1715,1716,1713,1714,1711,1712}, |
29f71fab | 294 | |
295 | // ddl10 | |
704b0bab | 296 | {1785,-1,960,961,958,959,956,957,954,955,952,953,1860,-1,982,983,980,981,978,979,976,977,974,975,1835,-1,1004,1005,1002,1003,1000,1001,998,999,996,997,1796,1797,1794,1795,1792,1793,1790,1791,1788,1789,1786,1787,1846,1847,1844,1845,1842,1843,1840,1841,1838,1839,1836,1837,1871,1872,1869,1870,1867,1868,1865,1866,1863,1864,1861,1862,1760,1810,938,939,936,937,934,935,932,933,930,931,1771,1772,1769,1770,1767,1768,1765,1766,1763,1764,1761,1762,1821,1822,1819,1820,1817,1818,1815,1816,1813,1814,1811,1812}, |
29f71fab | 297 | |
298 | // ddl11 | |
704b0bab | 299 | {1910,-1,1026,1027,1024,1025,1022,1023,1020,1021,1018,1019,1885,-1,1048,1049,1046,1047,1044,1045,1042,1043,1040,1041,1960,-1,1070,1071,1068,1069,1066,1067,1064,1065,1062,1063,1896,1897,1894,1895,1892,1893,1890,1891,1888,1889,1886,1887,1921,1922,1919,1920,1917,1918,1915,1916,1913,1914,1911,1912,1971,1972,1969,1970,1967,1968,1965,1966,1963,1964,1961,1962,1985,1935,1092,1093,1090,1091,1088,1089,1086,1087,1084,1085,1946,1947,1944,1945,1942,1943,1940,1941,1938,1939,1936,1937,1996,1997,1994,1995,1992,1993,1990,1991,1988,1989,1986,1987}, |
29f71fab | 300 | |
301 | // ddl12 | |
704b0bab | 302 | {2035,-1,1136,1137,1134,1135,1132,1133,1130,1131,1128,1129,2110,-1,1158,1159,1156,1157,1154,1155,1152,1153,1150,1151,2085,-1,1180,1181,1178,1179,1176,1177,1174,1175,1172,1173,2046,2047,2044,2045,2042,2043,2040,2041,2038,2039,2036,2037,2096,2097,2094,2095,2092,2093,2090,2091,2088,2089,2086,2087,2121,2122,2119,2120,2117,2118,2115,2116,2113,2114,2111,2112,2010,2060,1114,1115,1112,1113,1110,1111,1108,1109,1106,1107,2021,2022,2019,2020,2017,2018,2015,2016,2013,2014,2011,2012,2071,2072,2069,2070,2067,2068,2065,2066,2063,2064,2061,2062}, |
29f71fab | 303 | |
304 | // ddl13 | |
704b0bab | 305 | {2160,-1,1202,1203,1200,1201,1198,1199,1196,1197,1194,1195,2135,-1,1224,1225,1222,1223,1220,1221,1218,1219,1216,1217,1260,-1,1246,1247,1244,1245,1242,1243,1240,1241,1238,1239,1271,1272,1269,1270,1267,1268,1265,1266,1263,1264,1261,1262,2146,2147,2144,2145,2142,2143,2140,2141,2138,2139,2136,2137,2171,2172,2169,2170,2167,2168,2165,2166,2163,2164,2161,2162,-1,2185,520,521,518,519,516,517,514,515,512,513,-1,-1,542,543,540,541,538,539,536,537,534,535,2196,2197,2194,2195,2192,2193,2190,2191,2188,2189,2186,2187}, |
29f71fab | 306 | |
307 | // ddl14 | |
704b0bab | 308 | {1310,-1,586,587,584,585,582,583,580,581,578,579,1385,-1,608,609,606,607,604,605,602,603,600,601,1360,-1,630,631,628,629,626,627,624,625,622,623,1321,1322,1319,1320,1317,1318,1315,1316,1313,1314,1311,1312,1371,1372,1369,1370,1367,1368,1365,1366,1363,1364,1361,1362,1396,1397,1394,1395,1392,1393,1390,1391,1388,1389,1386,1387,1285,1335,564,565,562,563,560,561,558,559,556,557,1296,1297,1294,1295,1292,1293,1290,1291,1288,1289,1286,1287,1346,1347,1344,1345,1342,1343,1340,1341,1338,1339,1336,1337}, |
29f71fab | 309 | |
310 | // ddl15 | |
704b0bab | 311 | {1435,-1,652,653,650,651,648,649,646,647,644,645,1410,-1,674,675,672,673,670,671,668,669,666,667,1485,-1,696,697,694,695,692,693,690,691,688,689,1421,1422,1419,1420,1417,1418,1415,1416,1413,1414,1411,1412,1446,1447,1444,1445,1442,1443,1440,1441,1438,1439,1436,1437,1496,1497,1494,1495,1492,1493,1490,1491,1488,1489,1486,1487,1510,1460,718,719,716,717,714,715,712,713,710,711,1471,1472,1469,1470,1467,1468,1465,1466,1463,1464,1461,1462,1521,1522,1519,1520,1517,1518,1515,1516,1513,1514,1511,1512} |
5c3b40f1 | 312 | |
313 | }; | |
314 | for(Int_t iddl = 0; iddl < kDDLsNumber; iddl++) { | |
315 | for(Int_t imodule = 0; imodule < kModulesPerDDL; imodule++) { | |
316 | fgkDDLModuleMap[iddl][imodule] = kDDLModuleMap[iddl][imodule]; | |
317 | } | |
318 | } | |
319 | } | |
320 | ||
321 | void AliITSRawStreamSSD::SetvPPRasymmFMDDDLMapping() { | |
322 | //DDL mapping AliITSvPPRasymmFMD | |
323 | Int_t kDDLModuleMap[kDDLsNumber][kModulesPerDDL] = { | |
bd1231b5 | 324 | |
b42cfa25 | 325 | // ddl0 |
326 | {1214,1215,1224,1225,1222,1223,1220,1221,1218,1219,1216,1217, | |
327 | 1192,1193,1202,1203,1200,1201,1198,1199,1196,1197,1194,1195, | |
328 | 1170,1171,1180,1181,1178,1179,1176,1177,1174,1175,1172,1173, | |
329 | 1148,1149,1158,1159,1156,1157,1154,1155,1152,1153,1150,1151, | |
330 | 2121,2122,2119,2120,2117,2118,2115,2116,2113,2114,2111,2112, | |
331 | 2096,2097,2094,2095,2092,2093,2090,2091,2088,2089,2086,2087, | |
332 | 2071,2072,2069,2070,2067,2068,2065,2066,2063,2064,2061,2062, | |
333 | 2046,2047,2044,2045,2042,2043,2040,2041,2038,2039,2036,2037, | |
334 | 2021,2022,2019,2020,2017,2018,2015,2016,2013,2014,2011,2012}, | |
335 | ||
336 | // ddl1 | |
bd1231b5 | 337 | {1126,1127,1136,1137,1134,1135,1132,1133,1130,1131,1128,1129, |
338 | 1104,1105,1114,1115,1112,1113,1110,1111,1108,1109,1106,1107, | |
339 | 1082,1083,1092,1093,1090,1091,1088,1089,1086,1087,1084,1085, | |
340 | 1060,1061,1070,1071,1068,1069,1066,1067,1064,1065,1062,1063, | |
341 | 1038,1039,1048,1049,1046,1047,1044,1045,1042,1043,1040,1041, | |
342 | 1996,1997,1994,1995,1992,1993,1990,1991,1988,1989,1986,1987, | |
343 | 1971,1972,1969,1970,1967,1968,1965,1966,1963,1964,1961,1962, | |
344 | 1946,1947,1944,1945,1942,1943,1940,1941,1938,1939,1936,1937, | |
345 | 1921,1922,1919,1920,1917,1918,1915,1916,1913,1914,1911,1912}, | |
5c3b40f1 | 346 | |
b42cfa25 | 347 | // ddl2 |
bd1231b5 | 348 | {1016,1017,1026,1027,1024,1025,1022,1023,1020,1021,1018,1019, |
b42cfa25 | 349 | 994,995,1004,1005,1002,1003,1000,1001,998,999,996,997, |
350 | 972,973,982,983,980,981,978,979,976,977,974,975, | |
351 | 950,951,960,961,958,959,956,957,954,955,952,953, | |
bd1231b5 | 352 | 1896,1897,1894,1895,1892,1893,1890,1891,1888,1889,1886,1887, |
353 | 1871,1872,1869,1870,1867,1868,1865,1866,1863,1864,1861,1862, | |
354 | 1846,1847,1844,1845,1842,1843,1840,1841,1838,1839,1836,1837, | |
355 | 1821,1822,1819,1820,1817,1818,1815,1816,1813,1814,1811,1812, | |
356 | 1796,1797,1794,1795,1792,1793,1790,1791,1788,1789,1786,1787}, | |
357 | ||
b42cfa25 | 358 | // ddl3 |
359 | {928,929,938,939,936,937,934,935,932,933,930,931, | |
360 | 906,907,916,917,914,915,912,913,910,911,908,909, | |
361 | 884,885,894,895,892,893,890,891,888,889,886,887, | |
362 | 862,863,872,873,870,871,868,869,866,867,864,865 | |
363 | ,1771,1772,1769,1770,1767,1768,1765,1766,1763,1764,1761,1762, | |
bd1231b5 | 364 | 1746,1747,1744,1745,1742,1743,1740,1741,1738,1739,1736,1737, |
365 | 1721,1722,1719,1720,1717,1718,1715,1716,1713,1714,1711,1712, | |
366 | 1696,1697,1694,1695,1692,1693,1690,1691,1688,1689,1686,1687, | |
367 | 1671,1672,1669,1670,1667,1668,1665,1666,1663,1664,1661,1662}, | |
368 | ||
b42cfa25 | 369 | // ddl4 |
370 | {840,841,850,851,848,849,846,847,844,845,842,843, | |
371 | 818,819,828,829,826,827,824,825,822,823,820,821, | |
372 | 796,797,806,807,804,805,802,803,800,801,798,799, | |
373 | 774,775,784,785,782,783,780,781,778,779,776,777, | |
bd1231b5 | 374 | 1646,1647,1644,1645,1642,1643,1640,1641,1638,1639,1636,1637, |
375 | 1621,1622,1619,1620,1617,1618,1615,1616,1613,1614,1611,1612, | |
376 | 1596,1597,1594,1595,1592,1593,1590,1591,1588,1589,1586,1587, | |
377 | 1571,1572,1569,1570,1567,1568,1565,1566,1563,1564,1561,1562, | |
378 | 1546,1547,1544,1545,1542,1543,1540,1541,1538,1539,1536,1537}, | |
379 | ||
b42cfa25 | 380 | // ddl5 |
381 | {752,753,762,763,760,761,758,759,756,757,754,755, | |
382 | 730,731,740,741,738,739,736,737,734,735,732,733, | |
383 | 708,709,718,719,716,717,714,715,712,713,710,711, | |
384 | 686,687,696,697,694,695,692,693,690,691,688,689, | |
385 | 664,665,674,675,672,673,670,671,668,669,666,667, | |
bd1231b5 | 386 | 1521,1522,1519,1520,1517,1518,1515,1516,1513,1514,1511,1512, |
387 | 1496,1497,1494,1495,1492,1493,1490,1491,1488,1489,1486,1487, | |
388 | 1471,1472,1469,1470,1467,1468,1465,1466,1463,1464,1461,1462, | |
389 | 1446,1447,1444,1445,1442,1443,1440,1441,1438,1439,1436,1437}, | |
390 | ||
b42cfa25 | 391 | // ddl6 |
392 | {642,643,652,653,650,651,648,649,646,647,644,645, | |
393 | 620,621,630,631,628,629,626,627,624,625,622,623, | |
394 | 598,599,608,609,606,607,604,605,602,603,600,601, | |
395 | 576,577,586,587,584,585,582,583,580,581,578,579, | |
bd1231b5 | 396 | 1421,1422,1419,1420,1417,1418,1415,1416,1413,1414,1411,1412, |
397 | 1396,1397,1394,1395,1392,1393,1390,1391,1388,1389,1386,1387, | |
398 | 1369,1371,1365,1367,1361,1363,1357,1359,1353,1355,1349,1351, | |
399 | 1346,1347,1344,1345,1342,1343,1340,1341,1338,1339,1336,1337, | |
400 | 1321,1322,1319,1320,1317,1318,1315,1316,1313,1314,1311,1312}, | |
401 | ||
b42cfa25 | 402 | // ddl7 |
403 | {554,555,564,565,562,563,560,561,558,559,556,557, | |
404 | 532,533,542,543,540,541,538,539,536,537,534,535, | |
405 | 510,511,520,521,518,519,516,517,514,515,512,513, | |
bd1231b5 | 406 | 1236,1237,1246,1247,1244,1245,1242,1243,1240,1241,1238,1239, |
407 | 1296,1297,1294,1295,1292,1293,1290,1291,1288,1289,1286,1287, | |
408 | 1271,1272,1269,1270,1267,1268,1265,1266,1263,1264,1261,1262, | |
409 | 2196,2197,2194,2195,2192,2193,2190,2191,2188,2189,2186,2187, | |
410 | 2171,2172,2169,2170,2167,2168,2165,2166,2163,2164,2161,2162, | |
411 | 2146,2147,2144,2145,2142,2143,2140,2141,2138,2139,2136,2137}, | |
5c3b40f1 | 412 | |
b42cfa25 | 413 | // ddl8 |
414 | {2085,-1,1183,1182,1184,1185,1187,1186,1189,1188,1191,1190, | |
415 | 2010,-1,1161,1160,1162,1163,1165,1164,1167,1166,1169,1168, | |
416 | 2035,-1,1139,1138,1140,1141,1143,1142,1145,1144,1147,1146, | |
bd1231b5 | 417 | 2074,2073,2076,2075,2078,2077,2080,2079,2082,2081,2084,2083, |
bd1231b5 | 418 | 2024,2023,2026,2025,2028,2027,2030,2029,2032,2031,2034,2033, |
b42cfa25 | 419 | 1999,1998,2001,2000,2003,2002,2005,2004,2007,2006,2009,2008, |
420 | 2110,2060,1205,1204,1206,1207,1209,1208,1211,1210,1213,1212, | |
421 | 2099,2098,2101,2100,2103,2102,2105,2104,2107,2106,2109,2108, | |
422 | 2049,2048,2051,2050,2053,2052,2055,2054,2057,2056,2059,2058}, | |
5c3b40f1 | 423 | |
b42cfa25 | 424 | // ddl9 |
425 | {1960,-1,1117,1116,1118,1119,1121,1120,1123,1122,1125,1124, | |
426 | 1985,-1,1095,1094,1096,1097,1099,1098,1101,1100,1103,1102, | |
427 | 1910,-1,1073,1072,1074,1075,1077,1076,1079,1078,1081,1080, | |
bd1231b5 | 428 | 1974,1973,1976,1975,1978,1977,1980,1979,1982,1981,1984,1983, |
429 | 1949,1948,1951,1950,1953,1952,1955,1954,1957,1956,1959,1958, | |
b42cfa25 | 430 | 1899,1898,1901,1900,1903,1902,1905,1904,1907,1906,1909,1908, |
431 | -1,1935,1051,1050,1052,1053,1055,1054,1057,1056,1059,1058, | |
432 | -1,-1,1029,1028,1030,1031,1033,1032,1035,1034,1037,1036, | |
433 | 1924,1923,1926,1925,1928,1927,1930,1929,1932,1931,1934,1933}, | |
bd1231b5 | 434 | |
b42cfa25 | 435 | // ddl10 |
436 | {1860,-1,985,984,986,987,989,988,991,990,993,992, | |
437 | 1785,-1,963,962,964,965,967,966,969,968,971,970, | |
438 | 1810,-1,941,940,942,943,945,944,947,946,949,948, | |
bd1231b5 | 439 | 1849,1848,1851,1850,1853,1852,1855,1854,1857,1856,1859,1858, |
bd1231b5 | 440 | 1799,1798,1801,1800,1803,1802,1805,1804,1807,1806,1809,1808, |
b42cfa25 | 441 | 1774,1773,1776,1775,1778,1777,1780,1779,1782,1781,1784,1783, |
442 | 1885,1835,1007,1006,1008,1009,1011,1010,1013,1012,1015,1014, | |
443 | 1874,1873,1876,1875,1878,1877,1880,1879,1882,1881,1884,1883, | |
444 | 1824,1823,1826,1825,1828,1827,1830,1829,1832,1831,1834,1833}, | |
bd1231b5 | 445 | |
b42cfa25 | 446 | // ddl11 |
447 | {1735,-1,919,918,920,921,923,922,925,924,927,926, | |
448 | 1760,-1,897,896,898,899,901,900,903,902,905,904, | |
449 | 1685,-1,875,874,876,877,879,878,881,880,883,882, | |
bd1231b5 | 450 | 1749,1748,1751,1750,1753,1752,1755,1754,1757,1756,1759,1758, |
451 | 1724,1723,1726,1725,1728,1727,1730,1729,1732,1731,1734,1733, | |
bd1231b5 | 452 | 1674,1673,1676,1675,1678,1677,1680,1679,1682,1681,1684,1683, |
b42cfa25 | 453 | 1660,1710,853,852,854,855,857,856,859,858,861,860, |
454 | 1699,1698,1701,1700,1703,1702,1705,1704,1707,1706,1709,1708, | |
bd1231b5 | 455 | 1649,1648,1651,1650,1653,1652,1655,1654,1657,1656,1659,1658}, |
5c3b40f1 | 456 | |
b42cfa25 | 457 | // ddl12 |
458 | {1610,-1,809,808,810,811,813,812,815,814,817,816, | |
459 | 1535,-1,787,786,788,789,791,790,793,792,795,794, | |
460 | 1560,-1,765,764,766,767,769,768,771,770,773,772, | |
bd1231b5 | 461 | 1599,1598,1601,1600,1603,1602,1605,1604,1607,1606,1609,1608, |
bd1231b5 | 462 | 1549,1548,1551,1550,1553,1552,1555,1554,1557,1556,1559,1558, |
b42cfa25 | 463 | 1524,1523,1526,1525,1528,1527,1530,1529,1532,1531,1534,1533, |
464 | 1635,1585,831,830,832,833,835,834,837,836,839,838, | |
465 | 1624,1623,1626,1625,1628,1627,1630,1629,1632,1631,1634,1633, | |
466 | 1574,1573,1576,1575,1578,1577,1580,1579,1582,1581,1584,1583}, | |
bd1231b5 | 467 | |
b42cfa25 | 468 | // ddl13 |
469 | {1485,-1,743,742,744,745,747,746,749,748,751,750, | |
470 | 1510,-1,721,720,722,723,725,724,727,726,729,728, | |
471 | 1435,-1,699,698,700,701,703,702,705,704,707,706, | |
472 | 1424,1423,1426,1425,1428,1427,1430,1429,1432,1431,1434,1433, | |
bd1231b5 | 473 | 1499,1498,1501,1500,1503,1502,1505,1504,1507,1506,1509,1508, |
474 | 1474,1473,1476,1475,1478,1477,1480,1479,1482,1481,1484,1483, | |
b42cfa25 | 475 | -1,1460,677,676,678,679,681,680,683,682,685,684, |
476 | -1,-1,655,654,656,657,659,658,661,660,663,662, | |
477 | 1449,1448,1451,1450,1453,1452,1455,1454,1457,1456,1459,1458}, | |
bd1231b5 | 478 | |
b42cfa25 | 479 | // ddl14 |
480 | {1385,-1,611,610,612,613,615,614,617,616,619,618, | |
481 | 1310,-1,589,588,590,591,593,592,595,594,597,596, | |
482 | 1335,-1,567,566,568,569,571,570,573,572,575,574, | |
bd1231b5 | 483 | 1374,1373,1376,1375,1378,1377,1380,1379,1382,1381,1384,1383, |
bd1231b5 | 484 | 1324,1323,1326,1325,1328,1327,1330,1329,1332,1331,1334,1333, |
b42cfa25 | 485 | 1299,1298,1301,1300,1303,1302,1305,1304,1307,1306,1309,1308, |
486 | 1410,1372,633,632,634,635,637,636,639,638,641,640, | |
487 | 1399,1398,1401,1400,1403,1402,1405,1404,1407,1406,1409,1408, | |
488 | 1350,1348,1354,1352,1358,1356,1362,1360,1366,1364,1370,1368}, | |
bd1231b5 | 489 | |
b42cfa25 | 490 | // ddl15 |
491 | {1260,-1,545,544,546,547,549,548,551,550,553,552, | |
492 | 1285,-1,523,522,524,525,527,526,529,528,531,530, | |
493 | 2160,-1,501,500,502,503,505,504,507,506,509,508, | |
bd1231b5 | 494 | 1274,1273,1276,1275,1278,1277,1280,1279,1282,1281,1284,1283, |
495 | 1249,1248,1251,1250,1253,1252,1255,1254,1257,1256,1259,1258, | |
bd1231b5 | 496 | 2149,2148,2151,2150,2153,2152,2155,2154,2157,2156,2159,2158, |
b42cfa25 | 497 | 2135,2185,1227,1226,1228,1229,1231,1230,1233,1232,1235,1234, |
498 | 2174,2173,2176,2175,2178,2177,2180,2179,2182,2181,2184,2183, | |
bd1231b5 | 499 | 2124,2123,2126,2125,2128,2127,2130,2129,2132,2131,2134,2133} |
500 | ||
501 | }; | |
2906f4c2 | 502 | |
5c3b40f1 | 503 | for(Int_t iddl = 0; iddl < kDDLsNumber; iddl++) { |
504 | for(Int_t imodule = 0; imodule < kModulesPerDDL; imodule++) { | |
505 | fgkDDLModuleMap[iddl][imodule] = kDDLModuleMap[iddl][imodule]; | |
506 | } | |
507 | } | |
2906f4c2 | 508 | } |
509 | ||
2906f4c2 | 510 | Bool_t AliITSRawStreamSSD::Next() |
511 | { | |
bd1231b5 | 512 | // read the next raw digit |
513 | // returns kFALSE if there is no digit left | |
8297cd8f | 514 | |
515 | flag=0; | |
2906f4c2 | 516 | fPrevModuleID = fModuleID; |
517 | if (!fRawReader->ReadNextInt(fData)) return kFALSE; | |
518 | ||
bd1231b5 | 519 | // new coding following IGF Memo - M.Rossewij - 22-06-2004 |
520 | fSignal = (fData & 0x00000FFF); // signal coded in the first 12 bits | |
521 | fSignal = (fSignal > 2048) ? fSignal - 4096 : fSignal; | |
522 | ||
523 | UInt_t slot = (fData >> 28) & 0x0000000F; // slot range 1 - 9 | |
524 | UInt_t adc = (fData >> 24) & 0x0000000F; // adc range 0 - 5 AND 8 - 13; | |
525 | UInt_t relModuleID = (slot-1) * 12; // 0 - 96 | |
526 | relModuleID += (adc<6) ? adc : (adc-2); // adds 0 - 5 AND 6 - 11 | |
8297cd8f | 527 | |
528 | ||
529 | ||
530 | flag=1; | |
045be90c | 531 | // relModuleID range 0 - 107 |
532 | if(relModuleID >= kModulesPerDDL){ | |
812a6a14 | 533 | fRawReader->AddMajorErrorLog(kWrongModuleIdErr,Form("Module ID = %d > %d (max)",relModuleID,kModulesPerDDL)); |
534 | AliWarning(Form("Module ID = %d > %d (max)",relModuleID,kModulesPerDDL)); | |
535 | return kFALSE; | |
536 | } | |
8297cd8f | 537 | flag=0; |
538 | ||
539 | ||
e917bef4 | 540 | Int_t ddlid=fRawReader->GetDDLID(); |
541 | if(ddlid<0){ | |
542 | AliError("fRawReader->GetDDLID returns a negative value"); | |
543 | ddlid=0; | |
544 | } | |
40f5092a | 545 | if(ddlid>=kDDLsNumber){ |
546 | AliError(Form("fRawReader->GetDDLID returns a too big value %i \n",ddlid)); | |
547 | return kFALSE; | |
548 | } | |
e917bef4 | 549 | fModuleID = fgkDDLModuleMap[ddlid][relModuleID]; |
bd1231b5 | 550 | |
551 | fCoord2 = (fData >> 12) & 0x000007FF; | |
552 | fCoord1 = (fCoord2 < 768) ? 0 : 1; // strip 0 - 767 are Pside, strip 768 - 1535 are Nside | |
553 | fCoord2 = (fCoord1 == 0) ? fCoord2 : (1535 - fCoord2); | |
2906f4c2 | 554 | |
8297cd8f | 555 | /* |
556 | cout<<"AliITSRawStreamSSD baseword="<<fData<<" slot="<<slot<<" adc="<<adc | |
557 | <<" relModuleID="<<relModuleID<<" ddl="<<fRawReader->GetDDLID() | |
558 | <<" coord1="<<fCoord1<<" coord2="<<fCoord2<<" signal"<<fSignal | |
559 | <<" fModuleID="<<fModuleID<<endl; | |
560 | */ | |
561 | ||
bd1231b5 | 562 | fadc=adc; |
563 | fad=slot; | |
564 | fddl=fRawReader->GetDDLID(); | |
565 | ||
2906f4c2 | 566 | return kTRUE; |
567 | } | |
29f71fab | 568 |