Changes for report #71958: ZDC: changes needs code update in STEER
[u/mrichter/AliRoot.git] / STEER / AliESDZDC.h
1 // -*- mode: C++ -*- 
2 #ifndef ALIESDZDC_H
3 #define ALIESDZDC_H
4
5 /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
6  * See cxx source for full Copyright notice                               */
7
8 //-------------------------------------------------------------------------
9 //                      Implementation of   Class AliESDZDC
10 //   This is a class that summarizes the ZDC data for the ESD   
11 //   Origin: Christian Klein-Boesing, CERN, Christian.Klein-Boesing@cern.ch 
12 //   *** 15/10/2009 Scaler added to AliESDZDC class ***
13 //   *** Scaler format:  32 floats from VME scaler  ***
14 //-------------------------------------------------------------------------
15
16 #include <TObject.h>
17
18 class AliESDZDC: public TObject {
19 public:
20   AliESDZDC();
21   AliESDZDC(const AliESDZDC& zdc);
22   AliESDZDC& operator=(const AliESDZDC& zdc);
23   virtual void Copy(TObject &obj) const;
24
25   UInt_t   GetESDQuality()  const {return fESDQuality;}
26   Double_t GetZDCN1Energy() const {return fZDCN1Energy;}
27   Double_t GetZDCP1Energy() const {return fZDCP1Energy;}
28   Double_t GetZDCN2Energy() const {return fZDCN2Energy;}
29   Double_t GetZDCP2Energy() const {return fZDCP2Energy;}
30   Double_t GetZDCEMEnergy(Int_t i) const 
31            {if(i==0){return fZDCEMEnergy;} else if(i==1){return fZDCEMEnergy1;}
32            return 0;}
33   Short_t  GetZDCParticipants() const {return fZDCParticipants;}
34   Short_t  GetZDCPartSideA() const {return fZDCPartSideA;}
35   Short_t  GetZDCPartSideC() const {return fZDCPartSideC;}
36   Double_t GetImpactParameter() const {return fImpactParameter;}
37   Double_t GetImpactParamSideA() const {return fImpactParamSideA;}
38   Double_t GetImpactParamSideC() const {return fImpactParamSideC;}
39   const Double_t * GetZN1TowerEnergy() const {return fZN1TowerEnergy;}
40   const Double_t * GetZN2TowerEnergy() const {return fZN2TowerEnergy;}
41   const Double_t * GetZP1TowerEnergy() const {return fZP1TowerEnergy;}
42   const Double_t * GetZP2TowerEnergy() const {return fZP2TowerEnergy;}
43   const Double_t * GetZN1TowerEnergyLR() const {return fZN1TowerEnergyLR;}
44   const Double_t * GetZN2TowerEnergyLR() const {return fZN2TowerEnergyLR;}
45   const Double_t * GetZP1TowerEnergyLR() const {return fZP1TowerEnergyLR;}
46   const Double_t * GetZP2TowerEnergyLR() const {return fZP2TowerEnergyLR;}
47   //
48   Bool_t GetZNCentroidInPbPb(Float_t beamEne, Double_t centrZNC[2], Double_t centrZNA[2]);
49   Bool_t GetZNCentroidInpp(Double_t centrZNC[2], Double_t centrZNA[2]);
50   //
51   void  SetZDC(Double_t n1Energy, Double_t p1Energy, 
52                Double_t emEnergy0, Double_t emEnergy1,
53                Double_t n2Energy, Double_t p2Energy, 
54                Short_t participants, Short_t nPartA, Short_t nPartC,
55                Double_t b, Double_t bA, Double_t bC, UInt_t recoFlag) 
56         {fZDCN1Energy=n1Energy; fZDCP1Energy=p1Energy; 
57          fZDCEMEnergy=emEnergy0; fZDCEMEnergy1=emEnergy1;
58          fZDCN2Energy=n2Energy; fZDCP2Energy=p2Energy; 
59          fZDCParticipants=participants; fZDCPartSideA=nPartA; fZDCPartSideC=nPartC;
60          fImpactParameter=b; fImpactParamSideA=bA, fImpactParamSideC=bC,
61          fESDQuality=recoFlag;}
62   //
63   void  SetZN1TowerEnergy(const Float_t tow1[5])
64           {for(Int_t i=0; i<5; i++) fZN1TowerEnergy[i] = tow1[i];}
65   void  SetZN2TowerEnergy(const Float_t tow2[5])
66           {for(Int_t i=0; i<5; i++) fZN2TowerEnergy[i] = tow2[i];}
67   void  SetZP1TowerEnergy(const Float_t tow1[5])
68           {for(Int_t i=0; i<5; i++) fZP1TowerEnergy[i] = tow1[i];}
69   void  SetZP2TowerEnergy(const Float_t tow2[5])
70           {for(Int_t i=0; i<5; i++) fZP2TowerEnergy[i] = tow2[i];}
71   void  SetZN1TowerEnergyLR(const Float_t tow1[5])
72           {for(Int_t i=0; i<5; i++) fZN1TowerEnergyLR[i] = tow1[i];}
73   void  SetZN2TowerEnergyLR(const Float_t tow2[5])
74           {for(Int_t i=0; i<5; i++) fZN2TowerEnergyLR[i] = tow2[i];}
75   void  SetZP1TowerEnergyLR(const Float_t tow1[5])
76           {for(Int_t i=0; i<5; i++) fZP1TowerEnergyLR[i] = tow1[i];}
77   void  SetZP2TowerEnergyLR(const Float_t tow2[5])
78           {for(Int_t i=0; i<5; i++) fZP2TowerEnergyLR[i] = tow2[i];}
79   void  SetZNACentroid(const Float_t centrCoord[2])
80            {for(Int_t i=0; i<2; i++) fZNACentrCoord[i] = centrCoord[i];}
81   void  SetZNCCentroid(const Float_t centrCoord[2])
82            {for(Int_t i=0; i<2; i++) fZNCCentrCoord[i] = centrCoord[i];}
83
84   UInt_t GetZDCScaler(Int_t i)  const {return fVMEScaler[i];}
85   const UInt_t* GetZDCScaler()  const {return fVMEScaler;}
86
87   Int_t GetZDCTDCData(Int_t i) const {return fZDCTDCData[i];}
88   const Int_t* GetZDCTDCData()  const {return fZDCTDCData;}
89   
90   void SetZDCScaler(const UInt_t count[32]) 
91        {for(Int_t k=0; k<32; k++) fVMEScaler[k] = count[k];}
92   
93   void SetZDCTDC(const Int_t values[32]) 
94        {for(Int_t k=0; k<32; k++) fZDCTDCData[k] = values[k];}
95
96   void    Reset();
97   void    Print(const Option_t *opt=0) const;
98
99 private:
100
101   Double32_t   fZDCN1Energy;  // reconstructed energy in the neutron ZDC
102   Double32_t   fZDCP1Energy;  // reconstructed energy in the proton ZDC
103   Double32_t   fZDCN2Energy;  // reconstructed energy in the neutron ZDC
104   Double32_t   fZDCP2Energy;  // reconstructed energy in the proton ZDC
105   Double32_t   fZDCEMEnergy;  // signal in the electromagnetic ZDCs
106   Double32_t   fZDCEMEnergy1; // second EM signal,cannot change fZDCEMEnergy to array (not backward compatible)
107   Double32_t   fZN1TowerEnergy[5];// reco E in 5 ZN1 sectors - high gain chain
108   Double32_t   fZN2TowerEnergy[5];// reco E in 5 ZN2 sectors - high gain chain
109   Double32_t   fZP1TowerEnergy[5];// reco E in 5 ZP1 sectors - high gain chain
110   Double32_t   fZP2TowerEnergy[5];// reco E in 5 ZP2 sectors - high gain chain
111   Double32_t   fZN1TowerEnergyLR[5];// reco E in 5 ZN1 sectors - low gain chain
112   Double32_t   fZN2TowerEnergyLR[5];// reco E in 5 ZN2 sectors - low gain chain
113   Double32_t   fZP1TowerEnergyLR[5];// reco E in 5 ZP1 sectors - low gain chain
114   Double32_t   fZP2TowerEnergyLR[5];// reco E in 5 ZP2 sectors - low gain chain
115   Short_t      fZDCParticipants;    // number of participants estimated by the ZDC (ONLY in A-A)
116   Short_t      fZDCPartSideA;     // number of participants estimated by the ZDC (ONLY in A-A)
117   Short_t      fZDCPartSideC;     // number of participants estimated by the ZDC (ONLY in A-A)
118   Double32_t   fImpactParameter;  // impact parameter estimated by the ZDC (ONLY in A-A)
119   Double32_t   fImpactParamSideA; // impact parameter estimated by the ZDC (ONLY in A-A)
120   Double32_t   fImpactParamSideC; // impact parameter estimated by the ZDC (ONLY in A-A)
121   Double32_t   fZNACentrCoord[2]; // Coordinates of the centroid over ZNC
122   Double32_t   fZNCCentrCoord[2]; // Coordinates of the centroid over ZNA
123   UInt_t       fESDQuality;       // flags from reconstruction
124   UInt_t fVMEScaler[32];          // counts from VME scaler
125   Int_t  fZDCTDCData[32];         // ZDC TDC data
126
127   ClassDef(AliESDZDC,13)
128 };
129
130 #endif
131