Crucial bug-fix. The raw-data events should be never skipped inside the QA data makers
[u/mrichter/AliRoot.git] / ACORDE / AliACORDEConstants.cxx
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 // AliACORDEConstants class
21 //
22 // This class serves to group constants needed by ACORDE detector in 1
23 // easily accessible place. All constants are public const static data 
24 // members. The class is never instatiated.
25 // Authors: Arturo Fernandez, Enrique Gamez, Mario Rodríguez Cahuantzi, Eleazar Cuautle(ICN-UNAM) 
26 //         FCFM-UAP, Mexico.
27 //
28 ////////////////////////////////////////////////////////////////////////
29
30 #include "AliACORDEConstants.h"
31
32 AliACORDEConstants* AliACORDEConstants::fgInstance = 0;
33
34 const Float_t AliACORDEConstants::fgkModuleLength          = 300.0;
35 const Float_t AliACORDEConstants::fgkModuleWidth           = 26.0;
36 const Float_t AliACORDEConstants::fgkModuleHeight          =  10.0;
37 const Float_t AliACORDEConstants::fgkPlasticLength = 190.0;
38 const Float_t AliACORDEConstants::fgkPlasticWidth  =  20.0;
39 const Float_t AliACORDEConstants::fgkPlasticHeight =   1.0;
40 const Float_t AliACORDEConstants::fgkProfileWidth =    3.8;
41 const Float_t AliACORDEConstants::fgkProfileThickness = 0.3;
42 const Float_t AliACORDEConstants::fgkDepth               =4420; 
43
44 const Float_t AliACORDEConstants::fgkHitEnergyThreshold = 1.52; // MeV
45 const Float_t AliACORDEConstants::fgkMaxHitTimeDifference = 40.0; // ns
46 const Int_t AliACORDEConstants::fgkMultiMuonThreshold = 2;
47 const Float_t AliACORDEConstants::fgkMultiMuonWindow = 25;
48 const Float_t AliACORDEConstants::fgkModulePositionX[60] = {
49   641, 641, 641, 641, 641, 641, 641, 641, 641, 641,
50   426, 426, 426, 426, 426, 426, 426, 426, 426, 426,
51   153, 153, 153, 153, 153, 153, 153, 153, 153, 153,
52   -153, -153, -153, -153, -153, -153, -153, -153, -153,
53   -153, -426, -426, -426, -426, -426, -426, -426, -426,
54   -426, -426, -644, -644, -644, -644, -644, -619, -623,
55   -641, -641, -641};
56 const Float_t AliACORDEConstants::fgkModulePositionY[60] = {
57   582, 582, 582, 582, 582, 582, 582, 582, 582, 582,
58   797, 797, 797, 797, 797, 797, 797, 797, 797, 797,
59   850, 850, 850, 850, 850, 850, 850, 850, 850, 850,
60   850, 850, 850, 850, 850, 850, 850, 850, 850, 850,
61   797, 797, 797, 797, 797, 797, 797, 797, 797, 797,
62   582, 582, 582, 582, 582, 609, 605, 582, 582, 582};
63 const Float_t AliACORDEConstants::fgkModulePositionZ[60] = {
64   450, 350, 250, 150, 50, -50, -120, -280, -350, -450,
65   450, 350, 250, 150, 50, -50, -150, -250, -350, -450,
66   450, 350, 250, 150, 50, -50, -150, -250, -350, -450,
67   450, 350, 250, 150, 50, -50, -150, -250, -350, -450,
68   450, 350, 250, 150, 50, -50, -150, -250, -350, -450,
69   450, 350, 250, 104, 50, -85, -176, -250, -350, -450};
70
71 const Float_t AliACORDEConstants::fgkExtraModulePositionZ[4] = {93.0, 18., -18, -93};
72 const Float_t AliACORDEConstants::fgkExtraModulePositionX = 0.0;
73 const Float_t AliACORDEConstants::fgkExtraModulePositionY = 850.0;
74 const Int_t AliACORDEConstants::fgkModuleElectronicChannel[60] = {
75 /* DCS 0_0 ITS-1*/ 10,
76 /* DCS 0_1 */ 4,
77 /* DCS 0_2 */ 8,
78 /* DCS 0_3 */ 7,
79 /* DCS 0_4 */ 6,
80 /* DCS 0_5 */ 5,
81 /* DCS 0_6 */ 9,
82 /* DCS 0_7 */ 3,
83 /* DCS 0_8 */ 2,
84 /* DCS 0_9 ITS-2*/ 42,
85 /* DCS 1_0 */ 20,
86 /* DCS 1_1 */ 19,
87 /* DCS 1_2 */ 18,
88 /* DCS 1_3 */ 17,
89 /* DCS 1_4 */ 16,
90 /* DCS 1_5 */ 15,
91 /* DCS 1_6 */ 14,
92 /* DCS 1_7 */ 13,
93 /* DCS 1_8 */ 12,
94 /* DCS 1_9 */ 11,
95 /* DCS 2_0 */ 60,
96 /* DCS 2_1 */ 59,
97 /* DCS 2_2 */ 58,
98 /* DCS 2_3 */ 57,
99 /* DCS 2_4 */ 56,
100 /* DCS 2_5 */ 55,
101 /* DCS 2_6 */ 54,
102 /* DCS 2_7 */ 53,
103 /* DCS 2_8 */ 52,
104 /* DCS 2_9 */ 51,
105 /* DCS 3_0 */ 40,
106 /* DCS 3_1 */ 39,
107 /* DCS 3_2 */ 38,
108 /* DCS 3_3 */ 37,
109 /* DCS 3_4 */ 36,
110 /* DCS 3_5 */ 35,
111 /* DCS 3_6 */ 34,
112 /* DCS 3_7 */ 33,
113 /* DCS 3_8 */ 32,
114 /* DCS 3_9 */ 31,
115 /* DCS 4_0 */ 30,
116 /* DCS 4_1 */ 29,
117 /* DCS 4_2 */ 28,
118 /* DCS 4_3 */ 27,
119 /* DCS 4_4 */ 26,
120 /* DCS 4_5 */ 25,
121 /* DCS 4_6 */ 24,
122 /* DCS 4_7 */ 23,
123 /* DCS 4_8 */ 22,
124 /* DCS 4_9 */ 21,
125 /* DCS 5_0 ITS-3*/ 1,
126 /* DCS 5_1 */ 49,
127 /* DCS 5_2 */ 48,
128 /* DCS 5_3 */ 47,
129 /* DCS 5_4 */ 46,
130 /* DCS 5_5 */ 45,
131 /* DCS 5_6 */ 44,
132 /* DCS 5_7 */ 43,
133 /* DCS 5_8 */ 50,
134 /* DCS 5_9 ITS-4*/ 41
135 };
136
137 ClassImp(AliACORDEConstants)
138
139 //_____________________________________________________________________________
140 AliACORDEConstants::AliACORDEConstants()
141   : TObject()
142 {
143   // Default constructor
144 }
145
146
147 //_____________________________________________________________________________
148 AliACORDEConstants* AliACORDEConstants::Instance()
149 {
150   if ( !fgInstance ) {
151     fgInstance = new AliACORDEConstants;
152   }
153   return fgInstance;
154 }
155
156 //_____________________________________________________________________________
157 AliACORDEConstants::~AliACORDEConstants()
158 {
159   fgInstance = 0;
160 }
161
162 //_____________________________________________________________________________
163 Float_t AliACORDEConstants::ModulePositionX(Int_t i) const
164 {
165   // Module lenght
166   return fgkModulePositionX[i];
167 }
168
169 //_____________________________________________________________________________
170 Float_t AliACORDEConstants::ModulePositionY(Int_t i) const
171 {
172   // Module lenght
173   return fgkModulePositionY[i];
174 }
175 //_____________________________________________________________________________
176 Float_t AliACORDEConstants::ModulePositionZ(Int_t i) const
177 {
178   // Module lenght
179   return fgkModulePositionZ[i];
180 }
181
182 Float_t AliACORDEConstants::ExtraModulePositionX() const
183 {
184   // Module lenght
185   return fgkExtraModulePositionX;
186 }
187
188 //_____________________________________________________________________________
189 Float_t AliACORDEConstants::ExtraModulePositionY() const
190 {
191   // Module lenght
192   return fgkExtraModulePositionY;
193 }
194 //_____________________________________________________________________________
195 Float_t AliACORDEConstants::ExtraModulePositionZ(Int_t i) const
196 {
197   // Module lenght
198   return fgkExtraModulePositionZ[i];
199 }
200 //_____________________________________________________________________________
201 Int_t AliACORDEConstants::ModuleElectronicChannel(Int_t i) const
202 {
203         // return de ID (electronic channel in ACORDE) of each module
204         // acording to the match between DCS and Electronic nomenclature
205         return fgkModuleElectronicChannel[i];
206 }
207 //_____________________________________________________________________________
208 Float_t AliACORDEConstants::ModuleLength() const
209 {
210   // Module lenght
211   return fgkModuleLength;
212 }
213
214 //_____________________________________________________________________________
215 Float_t AliACORDEConstants::ModuleWidth() const
216 {
217   // Module width
218   return fgkModuleWidth;
219 }
220
221 //_____________________________________________________________________________
222 Float_t AliACORDEConstants::ModuleHeight() const
223 {
224   // Module height
225   return fgkModuleHeight;
226 }
227
228 //_____________________________________________________________________________
229 Float_t AliACORDEConstants::PlasticLength() const
230 {
231   // Length of the scintillator active zone for a single counter
232   return fgkPlasticLength;
233 }
234
235 //_____________________________________________________________________________
236 Float_t AliACORDEConstants::PlasticWidth() const
237 {
238   // Width of the scintillator active zone for a single counter
239   return fgkPlasticWidth;
240 }
241
242 //_____________________________________________________________________________
243 Float_t AliACORDEConstants::PlasticHeight() const
244 {
245   // Height of the scintillator active zone for a single counter
246   return fgkPlasticHeight;
247 }
248
249 Float_t AliACORDEConstants::ProfileWidth() const
250 {
251   // Width of the profile of the Al box
252   return fgkProfileWidth;
253 }
254
255 Float_t AliACORDEConstants::ProfileThickness() const
256 {
257   // Thickness of the profile of the Al box
258   return fgkProfileThickness;
259 }
260
261
262 //_____________________________________________________________________________
263 Float_t AliACORDEConstants::Depth() const
264 {
265   // Alice IP depth
266   return fgkDepth;
267 }