3 #ifndef AliL3_DataCompressorHelper
4 #define AliL3_DataCompressorHelper
6 #include "AliL3RootTypes.h"
8 class AliL3DataCompressorHelper {
11 static void SetBitNumbers(Int_t pad,Int_t time,Int_t charge,Int_t shape);
12 static void SetTransverseResolutions(Float_t res1,Float_t res2,Float_t res3,Float_t width=0.005);
13 static void SetLongitudinalResolutions(Float_t res1,Float_t res2,Float_t res3,Float_t width=0.005);
14 static void SetRemainingBitNumbers(Int_t pad,Int_t time,Int_t shape);
15 static Int_t GetNPadBits() {return fgNumPadBits;}
16 static Int_t GetNTimeBits() {return fgNumTimeBits;}
17 static Int_t GetNChargeBits() {return fgNumChargeBits;}
18 static Int_t GetNShapeBits() {return fgNumShapeBits;}
19 static Float_t GetXYWidthStep() {return fgXYWidthStep;}
20 static Float_t GetZWidthStep() {return fgZWidthStep;}
21 static Int_t GetClusterCharge() {return fgClusterCharge;}
22 static Float_t GetXYResidualStep(Int_t row);
23 static Float_t GetZResidualStep(Int_t row);
24 static Int_t GetNPadBitsRemaining() {return fgNumPadBitsRemaining;}
25 static Int_t GetNTimeBitsRemaining() {return fgNumTimeBitsRemaining;}
26 static Int_t GetNShapeBitsRemaining() {return fgNumShapeBitsRemaining;}
27 static Float_t GetPadPrecisionFactor();
28 static Float_t GetTimePrecisionFactor();
31 static Int_t Nint(Double_t x);
32 static Int_t Abs(Int_t d) { return (d > 0) ? d : -d; }
33 static Double_t Abs(Double_t d) { return (d > 0) ? d : -d; }
36 static Int_t fgNumPadBits; // Number of pad bits
37 static Int_t fgNumTimeBits; // Number of time bits
38 static Int_t fgNumChargeBits; // Number of charge bits
39 static Int_t fgNumShapeBits; // Number of shape bits
40 static Int_t fgNumPadBitsRemaining; // Number of remaining pad bits
41 static Int_t fgNumTimeBitsRemaining; // Number of remaining time bits
42 static Int_t fgNumShapeBitsRemaining; // Number of remaining shape bits
44 static Float_t fgXYResidualStep1; // XY resbual at step 1
45 static Float_t fgXYResidualStep2; // XY residual at step 2
46 static Float_t fgXYResidualStep3; // XY resudual at step 3
47 static Float_t fgZResidualStep1; // Z residual at step 1
48 static Float_t fgZResidualStep2; // Z resudual at step 2
49 static Float_t fgZResidualStep3; // Z resudual at step 3
50 static Float_t fgXYWidthStep; // Width of XY step
51 static Float_t fgZWidthStep; // Width of Z step
52 static Int_t fgClusterCharge; // Cluster charge
55 ClassDef(AliL3DataCompressorHelper,1)