ROOT logo
// -*- mode: C++ -*- 
#ifndef ALIESDZDC_H
#define ALIESDZDC_H

/* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
 * See cxx source for full Copyright notice                               */

//-------------------------------------------------------------------------
//                      Implementation of   Class AliESDZDC
//   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 <AliVZDC.h>

class AliESDZDC: public AliVZDC {
public: 
 
  AliESDZDC();
  AliESDZDC(const AliESDZDC& zdc);
  AliESDZDC& operator=(const AliESDZDC& zdc);


  // Getters 
  
  virtual Short_t  GetZDCParticipants() const {return fZDCParticipants;}
  virtual Short_t  GetZDCPartSideA() const {return fZDCPartSideA;}
  virtual Short_t  GetZDCPartSideC() const {return fZDCPartSideC;}
  virtual Double_t GetImpactParameter() const {return fImpactParameter;}
  virtual Double_t GetImpactParamSideA() const {return fImpactParamSideA;}
  virtual Double_t GetImpactParamSideC() const {return fImpactParamSideC;}

  virtual Double_t GetZNCEnergy() const {return (Double_t) fZDCN1Energy;}
  virtual Double_t GetZPCEnergy() const {return (Double_t) fZDCP1Energy;}
  virtual Double_t GetZNAEnergy() const {return (Double_t) fZDCN2Energy;}
  virtual Double_t GetZPAEnergy() const {return (Double_t) fZDCP2Energy;}
  virtual Double_t GetZEM1Energy() const {return (Double_t) fZDCEMEnergy;}
  virtual Double_t GetZEM2Energy() const {return (Double_t) fZDCEMEnergy1;}
  
  virtual const Double_t *GetZNCTowerEnergy() const {return fZN1TowerEnergy;}
  virtual const Double_t *GetZNATowerEnergy() const {return fZN2TowerEnergy;}
  virtual const Double_t *GetZPCTowerEnergy() const {return fZP1TowerEnergy;}
  virtual const Double_t *GetZPATowerEnergy() const {return fZP2TowerEnergy;}
  virtual const Double_t *GetZNCTowerEnergyLR() const {return fZN1TowerEnergyLR;}
  virtual const Double_t *GetZNATowerEnergyLR() const {return fZN2TowerEnergyLR;}
  const Double_t *GetZPCTowerEnergyLR() const {return fZP1TowerEnergyLR;}
  const Double_t *GetZPATowerEnergyLR() const {return fZP2TowerEnergyLR;}

  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;}

  const Double_t * GetZN1TowerEnergy() const {return fZN1TowerEnergy;}
  const Double_t * GetZN2TowerEnergy() const {return fZN2TowerEnergy;}
  const Double_t * GetZP1TowerEnergy() const {return fZP1TowerEnergy;}
  const Double_t * GetZP2TowerEnergy() const {return fZP2TowerEnergy;}
  const Double_t * GetZN1TowerEnergyLR() const {return fZN1TowerEnergyLR;}
  const Double_t * GetZN2TowerEnergyLR() const {return fZN2TowerEnergyLR;}
  const Double_t * GetZP1TowerEnergyLR() const {return fZP1TowerEnergyLR;}
  const Double_t * GetZP2TowerEnergyLR() const {return fZP2TowerEnergyLR;}
  //
  virtual Bool_t GetZNCentroidInPbPb(Float_t beamEne, Double_t centrZNC[2], Double_t centrZNA[2]);
  virtual Bool_t GetZNCentroidInpp(Double_t centrZNC[2], Double_t centrZNA[2]);
  //

  UInt_t GetZDCScaler(Int_t i)  const {return fVMEScaler[i];}
  const UInt_t* GetZDCScaler()  const {return fVMEScaler;}

  Int_t GetZDCTDCData(Int_t i, Int_t j) const {return fZDCTDCData[i][j];}
  Float_t GetZDCTDCCorrected(Int_t i, Int_t j) const 
  {
    if(AliESDZDC::kCorrectedTDCFilled && (fZDCTDCData[i][j]!=0)) return fZDCTDCCorrected[i][j];
	   else return 999.;
  }
  
  Float_t GetZNTDCSum(Int_t ihit) const 
  {
    if(ihit<4 && AliESDZDC::kCorrectedTDCFilled && (fZDCTDCData[10][ihit]!=0) && (fZDCTDCData[12][ihit]!=0)) return (Float_t) (fZDCTDCCorrected[10][ihit]+fZDCTDCCorrected[12][ihit]);
    else return 999.;
  }
  Float_t GetZNTDCDiff(Int_t ihit) const 
  {
    if(ihit<4 && AliESDZDC::kCorrectedTDCFilled &&  (fZDCTDCData[10][ihit]!=0) && (fZDCTDCData[12][ihit]!=0)) return (Float_t) (fZDCTDCCorrected[12][ihit]-fZDCTDCCorrected[10][ihit]);
    else return 999.;
  }
  
  virtual Float_t GetZDCTimeSum() const 
          {if(AliESDZDC::kCorrectedTDCFilled && (fZDCTDCData[10][0]!=0) && (fZDCTDCData[12][0]!=0)) return (Float_t) (fZDCTDCCorrected[10][0]+fZDCTDCCorrected[12][0]);
           else return 0.;}
  virtual Float_t GetZDCTimeDiff() const 
          {if(AliESDZDC::kCorrectedTDCFilled &&  (fZDCTDCData[10][0]!=0) && (fZDCTDCData[12][0]!=0)) return (Float_t) (fZDCTDCCorrected[12][0]-fZDCTDCCorrected[10][0]);
           else return 0.;}
  
  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];}
  
  void SetZDCScaler(const UInt_t count[32]) 
       {for(Int_t k=0; k<32; k++) fVMEScaler[k] = count[k];}
  
  void SetZDCTDCData(const Int_t values[32][4]) 
       {for(Int_t k=0; k<32; k++)
       	   for(Int_t j=0; j<4; j++) fZDCTDCData[k][j] = values[k][j];}
  
  void SetZDCTDCCorrected(const Float_t values[32][4]) 
       {for(Int_t k=0; k<32; k++)
       	   for(Int_t j=0; j<4; j++) fZDCTDCCorrected[k][j] = values[k][j];}
  
  Bool_t IsZNChit() {return fZNCTDChit;}
  Bool_t IsZNAhit() {return fZNATDChit;}
  Bool_t IsZPChit() {return fZPCTDChit;}
  Bool_t IsZPAhit() {return fZPATDChit;}
  Bool_t IsZEM1hit() {return fZEM1TDChit;}
  Bool_t IsZEM2hit() {return fZEM2TDChit;}
  //
  void SetZNCTDChit(Bool_t isf)  {fZNCTDChit = isf;} 
  void SetZPCTDChit(Bool_t isf)  {fZNATDChit = isf;} 
  void SetZNATDChit(Bool_t isf)  {fZPCTDChit = isf;} 
  void SetZPATDChit(Bool_t isf)  {fZPATDChit = isf;} 
  void SetZEM1TDChit(Bool_t isf) {fZEM1TDChit = isf;} 
  void SetZEM2TDChit(Bool_t isf) {fZEM2TDChit = isf;} 

  void    Reset();
  void    Print(const Option_t *opt=0) const;
private:
  virtual void Copy(TObject &obj) 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   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
  Double32_t   fZP2TowerEnergy[5];// reco E in 5 ZP2 sectors - high gain chain
  Double32_t   fZN1TowerEnergyLR[5];// reco E in 5 ZN1 sectors - low gain chain
  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 (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
  Int_t        fZDCTDCData[32][4];     // ZDC TDC data
  Float_t      fZDCTDCCorrected[32][4];// ZDC TDC data in ns corrected 4 phase shift
  Bool_t       fZNCTDChit;    // true if ZNC TDC has at least 1 hit
  Bool_t       fZNATDChit;    // true if ZNA TDC has at least 1 hit
  Bool_t       fZPCTDChit;    // true if ZPC TDC has at least 1 hit
  Bool_t       fZPATDChit;    // true if ZPA TDC has at least 1 hit
  Bool_t       fZEM1TDChit;   // true if ZEM1 TDC has at least 1 hit
  Bool_t       fZEM2TDChit;   // true if ZEM2 TDC has at least 1 hit
  
  ClassDef(AliESDZDC,18)
};

#endif

 AliESDZDC.h:1
 AliESDZDC.h:2
 AliESDZDC.h:3
 AliESDZDC.h:4
 AliESDZDC.h:5
 AliESDZDC.h:6
 AliESDZDC.h:7
 AliESDZDC.h:8
 AliESDZDC.h:9
 AliESDZDC.h:10
 AliESDZDC.h:11
 AliESDZDC.h:12
 AliESDZDC.h:13
 AliESDZDC.h:14
 AliESDZDC.h:15
 AliESDZDC.h:16
 AliESDZDC.h:17
 AliESDZDC.h:18
 AliESDZDC.h:19
 AliESDZDC.h:20
 AliESDZDC.h:21
 AliESDZDC.h:22
 AliESDZDC.h:23
 AliESDZDC.h:24
 AliESDZDC.h:25
 AliESDZDC.h:26
 AliESDZDC.h:27
 AliESDZDC.h:28
 AliESDZDC.h:29
 AliESDZDC.h:30
 AliESDZDC.h:31
 AliESDZDC.h:32
 AliESDZDC.h:33
 AliESDZDC.h:34
 AliESDZDC.h:35
 AliESDZDC.h:36
 AliESDZDC.h:37
 AliESDZDC.h:38
 AliESDZDC.h:39
 AliESDZDC.h:40
 AliESDZDC.h:41
 AliESDZDC.h:42
 AliESDZDC.h:43
 AliESDZDC.h:44
 AliESDZDC.h:45
 AliESDZDC.h:46
 AliESDZDC.h:47
 AliESDZDC.h:48
 AliESDZDC.h:49
 AliESDZDC.h:50
 AliESDZDC.h:51
 AliESDZDC.h:52
 AliESDZDC.h:53
 AliESDZDC.h:54
 AliESDZDC.h:55
 AliESDZDC.h:56
 AliESDZDC.h:57
 AliESDZDC.h:58
 AliESDZDC.h:59
 AliESDZDC.h:60
 AliESDZDC.h:61
 AliESDZDC.h:62
 AliESDZDC.h:63
 AliESDZDC.h:64
 AliESDZDC.h:65
 AliESDZDC.h:66
 AliESDZDC.h:67
 AliESDZDC.h:68
 AliESDZDC.h:69
 AliESDZDC.h:70
 AliESDZDC.h:71
 AliESDZDC.h:72
 AliESDZDC.h:73
 AliESDZDC.h:74
 AliESDZDC.h:75
 AliESDZDC.h:76
 AliESDZDC.h:77
 AliESDZDC.h:78
 AliESDZDC.h:79
 AliESDZDC.h:80
 AliESDZDC.h:81
 AliESDZDC.h:82
 AliESDZDC.h:83
 AliESDZDC.h:84
 AliESDZDC.h:85
 AliESDZDC.h:86
 AliESDZDC.h:87
 AliESDZDC.h:88
 AliESDZDC.h:89
 AliESDZDC.h:90
 AliESDZDC.h:91
 AliESDZDC.h:92
 AliESDZDC.h:93
 AliESDZDC.h:94
 AliESDZDC.h:95
 AliESDZDC.h:96
 AliESDZDC.h:97
 AliESDZDC.h:98
 AliESDZDC.h:99
 AliESDZDC.h:100
 AliESDZDC.h:101
 AliESDZDC.h:102
 AliESDZDC.h:103
 AliESDZDC.h:104
 AliESDZDC.h:105
 AliESDZDC.h:106
 AliESDZDC.h:107
 AliESDZDC.h:108
 AliESDZDC.h:109
 AliESDZDC.h:110
 AliESDZDC.h:111
 AliESDZDC.h:112
 AliESDZDC.h:113
 AliESDZDC.h:114
 AliESDZDC.h:115
 AliESDZDC.h:116
 AliESDZDC.h:117
 AliESDZDC.h:118
 AliESDZDC.h:119
 AliESDZDC.h:120
 AliESDZDC.h:121
 AliESDZDC.h:122
 AliESDZDC.h:123
 AliESDZDC.h:124
 AliESDZDC.h:125
 AliESDZDC.h:126
 AliESDZDC.h:127
 AliESDZDC.h:128
 AliESDZDC.h:129
 AliESDZDC.h:130
 AliESDZDC.h:131
 AliESDZDC.h:132
 AliESDZDC.h:133
 AliESDZDC.h:134
 AliESDZDC.h:135
 AliESDZDC.h:136
 AliESDZDC.h:137
 AliESDZDC.h:138
 AliESDZDC.h:139
 AliESDZDC.h:140
 AliESDZDC.h:141
 AliESDZDC.h:142
 AliESDZDC.h:143
 AliESDZDC.h:144
 AliESDZDC.h:145
 AliESDZDC.h:146
 AliESDZDC.h:147
 AliESDZDC.h:148
 AliESDZDC.h:149
 AliESDZDC.h:150
 AliESDZDC.h:151
 AliESDZDC.h:152
 AliESDZDC.h:153
 AliESDZDC.h:154
 AliESDZDC.h:155
 AliESDZDC.h:156
 AliESDZDC.h:157
 AliESDZDC.h:158
 AliESDZDC.h:159
 AliESDZDC.h:160
 AliESDZDC.h:161
 AliESDZDC.h:162
 AliESDZDC.h:163
 AliESDZDC.h:164
 AliESDZDC.h:165
 AliESDZDC.h:166
 AliESDZDC.h:167
 AliESDZDC.h:168
 AliESDZDC.h:169
 AliESDZDC.h:170
 AliESDZDC.h:171
 AliESDZDC.h:172
 AliESDZDC.h:173
 AliESDZDC.h:174
 AliESDZDC.h:175
 AliESDZDC.h:176
 AliESDZDC.h:177
 AliESDZDC.h:178
 AliESDZDC.h:179
 AliESDZDC.h:180
 AliESDZDC.h:181
 AliESDZDC.h:182
 AliESDZDC.h:183
 AliESDZDC.h:184
 AliESDZDC.h:185
 AliESDZDC.h:186
 AliESDZDC.h:187
 AliESDZDC.h:188
 AliESDZDC.h:189
 AliESDZDC.h:190
 AliESDZDC.h:191
 AliESDZDC.h:192
 AliESDZDC.h:193
 AliESDZDC.h:194
 AliESDZDC.h:195
 AliESDZDC.h:196
 AliESDZDC.h:197
 AliESDZDC.h:198
 AliESDZDC.h:199
 AliESDZDC.h:200
 AliESDZDC.h:201
 AliESDZDC.h:202