]> git.uio.no Git - u/mrichter/AliRoot.git/blobdiff - STEER/AliESDZDC.h
Fix for Savannah bug report 59287
[u/mrichter/AliRoot.git] / STEER / AliESDZDC.h
index d20e9debc9a96a82c0b2e0b55771a7e72003f165..9047bda8fe2204dfab1651c73a6deec9471b7ce4 100644 (file)
@@ -7,27 +7,35 @@
 
 //-------------------------------------------------------------------------
 //                      Implementation of   Class AliESDZDC
-//   This is a class that summarizes the ZDC data
-//   for the ESD   
+//   This is a class that summarizes the ZDC data for the ESD   
 //   Origin: Christian Klein-Boesing, CERN, Christian.Klein-Boesing@cern.ch 
+//   *** 15/10/2009 Scaler added to AliESDZDC class ***
+//   *** Scaler format:  32 floats from VME scaler  ***
 //-------------------------------------------------------------------------
 
 #include <TObject.h>
 
-
 class AliESDZDC: public TObject {
 public:
   AliESDZDC();
   AliESDZDC(const AliESDZDC& zdc);
   AliESDZDC& operator=(const AliESDZDC& zdc);
+  virtual void Copy(TObject &obj) const;
 
+  UInt_t   GetESDQuality()  const {return fESDQuality;}
   Double_t GetZDCN1Energy() const {return fZDCN1Energy;}
   Double_t GetZDCP1Energy() const {return fZDCP1Energy;}
   Double_t GetZDCN2Energy() const {return fZDCN2Energy;}
   Double_t GetZDCP2Energy() const {return fZDCP2Energy;}
-  Double_t GetZDCEMEnergy(Int_t i) const {if(i==0){return fZDCEMEnergy;}
-  else if(i==1){return fZDCEMEnergy1;}return 0;}
+  Double_t GetZDCEMEnergy(Int_t i) const 
+          {if(i==0){return fZDCEMEnergy;} else if(i==1){return fZDCEMEnergy1;}
+          return 0;}
   Short_t  GetZDCParticipants() const {return fZDCParticipants;}
+  Short_t  GetZDCPartSideA() const {return fZDCPartSideA;}
+  Short_t  GetZDCPartSideC() const {return fZDCPartSideC;}
+  Double_t GetImpactParameter() const {return fImpactParameter;}
+  Double_t GetImpactParamSideA() const {return fImpactParamSideA;}
+  Double_t GetImpactParamSideC() const {return fImpactParamSideC;}
   const Double_t * GetZN1TowerEnergy() const {return fZN1TowerEnergy;}
   const Double_t * GetZN2TowerEnergy() const {return fZN2TowerEnergy;}
   const Double_t * GetZP1TowerEnergy() const {return fZP1TowerEnergy;}
@@ -36,46 +44,62 @@ public:
   const Double_t * GetZN2TowerEnergyLR() const {return fZN2TowerEnergyLR;}
   const Double_t * GetZP1TowerEnergyLR() const {return fZP1TowerEnergyLR;}
   const Double_t * GetZP2TowerEnergyLR() const {return fZP2TowerEnergyLR;}
-  void  SetZDC(Double_t n1Energy, Double_t p1Energy, Double_t emEnergy0, Double_t emEnergy1,
-              Double_t n2Energy, Double_t p2Energy, Short_t participants) 
-   {fZDCN1Energy=n1Energy; fZDCP1Energy=p1Energy; fZDCEMEnergy=emEnergy0; fZDCEMEnergy1=emEnergy1;
-    fZDCN2Energy=n2Energy; fZDCP2Energy=p2Energy; fZDCParticipants=participants;}
-  void  SetZN1TowerEnergy(Float_t tow1[5]){
-      for(Int_t i=0; i<4; i++) fZN1TowerEnergy[i] = tow1[i];
-  }
-  void  SetZN2TowerEnergy(Float_t tow2[5]){
-      for(Int_t i=0; i<4; i++) fZN2TowerEnergy[i] = tow2[i];
-  }
-  void  SetZP1TowerEnergy(Float_t tow1[5]){
-      for(Int_t i=0; i<4; i++) fZP1TowerEnergy[i] = tow1[i];
-  }
-  void  SetZP2TowerEnergy(Float_t tow2[5]){
-      for(Int_t i=0; i<4; i++) fZP2TowerEnergy[i] = tow2[i];
-  }
-  void  SetZN1TowerEnergyLR(Float_t tow1[5]){
-      for(Int_t i=0; i<4; i++) fZN1TowerEnergyLR[i] = tow1[i];
-  }
-  void  SetZN2TowerEnergyLR(Float_t tow2[5]){
-      for(Int_t i=0; i<4; i++) fZN2TowerEnergyLR[i] = tow2[i];
-  }
-  void  SetZP1TowerEnergyLR(Float_t tow1[5]){
-      for(Int_t i=0; i<4; i++) fZP1TowerEnergyLR[i] = tow1[i];
-  }
-  void  SetZP2TowerEnergyLR(Float_t tow2[4]){
-      for(Int_t i=0; i<4; i++) fZP2TowerEnergyLR[i] = tow2[i];
-  }
+  //
+  const Double_t * GetZNCCentroidInPbPb(Float_t beamEne);
+  const Double_t * GetZNACentroidInPbPb(Float_t beamEne);
+  const Double_t * GetZNCCentroidInpp();
+  const Double_t * GetZNACentroidInpp();
+  //
+  void  SetZDC(Double_t n1Energy, Double_t p1Energy, 
+              Double_t emEnergy0, Double_t emEnergy1,
+              Double_t n2Energy, Double_t p2Energy, 
+              Short_t participants, Short_t nPartA, Short_t nPartC,
+              Double_t b, Double_t bA, Double_t bC, UInt_t recoFlag) 
+       {fZDCN1Energy=n1Energy; fZDCP1Energy=p1Energy; 
+        fZDCEMEnergy=emEnergy0; fZDCEMEnergy1=emEnergy1;
+        fZDCN2Energy=n2Energy; fZDCP2Energy=p2Energy; 
+        fZDCParticipants=participants; fZDCPartSideA=nPartA; fZDCPartSideC=nPartC;
+        fImpactParameter=b; fImpactParamSideA=bA, fImpactParamSideC=bC,
+        fESDQuality=recoFlag;}
+  //
+  void  SetZN1TowerEnergy(const Float_t tow1[5])
+          {for(Int_t i=0; i<5; i++) fZN1TowerEnergy[i] = tow1[i];}
+  void  SetZN2TowerEnergy(const Float_t tow2[5])
+          {for(Int_t i=0; i<5; i++) fZN2TowerEnergy[i] = tow2[i];}
+  void  SetZP1TowerEnergy(const Float_t tow1[5])
+          {for(Int_t i=0; i<5; i++) fZP1TowerEnergy[i] = tow1[i];}
+  void  SetZP2TowerEnergy(const Float_t tow2[5])
+          {for(Int_t i=0; i<5; i++) fZP2TowerEnergy[i] = tow2[i];}
+  void  SetZN1TowerEnergyLR(const Float_t tow1[5])
+          {for(Int_t i=0; i<5; i++) fZN1TowerEnergyLR[i] = tow1[i];}
+  void  SetZN2TowerEnergyLR(const Float_t tow2[5])
+          {for(Int_t i=0; i<5; i++) fZN2TowerEnergyLR[i] = tow2[i];}
+  void  SetZP1TowerEnergyLR(const Float_t tow1[5])
+          {for(Int_t i=0; i<5; i++) fZP1TowerEnergyLR[i] = tow1[i];}
+  void  SetZP2TowerEnergyLR(const Float_t tow2[5])
+          {for(Int_t i=0; i<5; i++) fZP2TowerEnergyLR[i] = tow2[i];}
+  void  SetZNACentroid(const Float_t centrCoord[2])
+          {for(Int_t i=0; i<2; i++) fZNACentrCoord[i] = centrCoord[i];}
+  void  SetZNCCentroid(const Float_t centrCoord[2])
+          {for(Int_t i=0; i<2; i++) fZNCCentrCoord[i] = centrCoord[i];}
+
+  UInt_t GetZDCScaler(Int_t i)  const {return fVMEScaler[i];}
+  const UInt_t* GetZDCScaler()  const {return fVMEScaler;}
+  
+  void SetZDCScaler(const UInt_t count[32]) 
+       {for(Int_t k=0; k<32; k++) fVMEScaler[k] = count[k];}
 
   void    Reset();
   void    Print(const Option_t *opt=0) const;
 
 private:
 
-  Double32_t   fZDCN1Energy;      // reconstructed energy in the neutron ZDC
-  Double32_t   fZDCP1Energy;      // reconstructed energy in the proton ZDC
-  Double32_t   fZDCN2Energy;      // reconstructed energy in the neutron ZDC
-  Double32_t   fZDCP2Energy;      // reconstructed energy in the proton ZDC
-  Double32_t   fZDCEMEnergy;      // signal in the electromagnetic ZDCs
-  Double32_t   fZDCEMEnergy1;    // second EM signal,cannot change fZDCEMEnergy to array (not backward compatible)
+  Double32_t   fZDCN1Energy;  // reconstructed energy in the neutron ZDC
+  Double32_t   fZDCP1Energy;  // reconstructed energy in the proton ZDC
+  Double32_t   fZDCN2Energy;  // reconstructed energy in the neutron ZDC
+  Double32_t   fZDCP2Energy;  // reconstructed energy in the proton ZDC
+  Double32_t   fZDCEMEnergy;  // signal in the electromagnetic ZDCs
+  Double32_t   fZDCEMEnergy1; // second EM signal,cannot change fZDCEMEnergy to array (not backward compatible)
   Double32_t   fZN1TowerEnergy[5];// reco E in 5 ZN1 sectors - high gain chain
   Double32_t   fZN2TowerEnergy[5];// reco E in 5 ZN2 sectors - high gain chain
   Double32_t   fZP1TowerEnergy[5];// reco E in 5 ZP1 sectors - high gain chain
@@ -84,8 +108,19 @@ private:
   Double32_t   fZN2TowerEnergyLR[5];// reco E in 5 ZN2 sectors - low gain chain
   Double32_t   fZP1TowerEnergyLR[5];// reco E in 5 ZP1 sectors - low gain chain
   Double32_t   fZP2TowerEnergyLR[5];// reco E in 5 ZP2 sectors - low gain chain
-  Short_t      fZDCParticipants;  // number of participants estimated by the ZDC
-  ClassDef(AliESDZDC,7)
+  Short_t      fZDCParticipants;    // number of participants estimated by the ZDC (ONLY in A-A)
+  Short_t      fZDCPartSideA;     // number of participants estimated by the ZDC (ONLY in A-A)
+  Short_t      fZDCPartSideC;     // number of participants estimated by the ZDC (ONLY in A-A)
+  Double32_t   fImpactParameter;  // impact parameter estimated by the ZDC (ONLY in A-A)
+  Double32_t   fImpactParamSideA; // impact parameter estimated by the ZDC (ONLY in A-A)
+  Double32_t   fImpactParamSideC; // impact parameter estimated by the ZDC (ONLY in A-A)
+  Double32_t   fZNACentrCoord[2]; // Coordinates of the centroid over ZNC
+  Double32_t   fZNCCentrCoord[2]; // Coordinates of the centroid over ZNA
+  UInt_t       fESDQuality;      // flags from reconstruction
+  //
+  UInt_t fVMEScaler[32]; // counts from VME scaler
+
+  ClassDef(AliESDZDC,12)
 };
 
 #endif