]> git.uio.no Git - u/mrichter/AliRoot.git/commitdiff
Method to calculate the centroid of spectator neutrons over the ZN front face. It...
authorhristov <hristov@f7af4fe6-9843-0410-8265-dc069ae4e863>
Wed, 16 Apr 2008 09:10:51 +0000 (09:10 +0000)
committerhristov <hristov@f7af4fe6-9843-0410-8265-dc069ae4e863>
Wed, 16 Apr 2008 09:10:51 +0000 (09:10 +0000)
STEER/AliESDZDC.cxx
STEER/AliESDZDC.h

index 04cdd094385fe9ce76871f1d13b91ba9cb9a84b7..12c5554d5adbd10fbff28f9be369ca1575926e2f 100644 (file)
@@ -27,6 +27,8 @@
 
 ClassImp(AliESDZDC)
 
+float fCParCentr(const int n) {return 1.8936-0.7126/(n + 0.7179);}
+
 //______________________________________________________________________________
 AliESDZDC::AliESDZDC() :
   TObject(),
@@ -124,4 +126,44 @@ void AliESDZDC::Print(const Option_t *) const
   fZDCN1Energy,fZDCP1Energy,fZDCN2Energy,fZDCP2Energy,fZDCParticipants);
 }
 
+//______________________________________________________________________________
+const Float_t * AliESDZDC::GetZNCCentroid(int NspecnC) const
+{
+  // Provide coordinates of centroid over ZN (side C) front face
+  Float_t CentrCoord[2];
+  Float_t x[4] = {-1.75, 1.75, -1.75, 1.75};
+  Float_t y[4] = {-1.75, -1.72, 1.75, 1.75};
+  Float_t NumX=0., NumY=0., Den=0.;
+  Float_t alpha=0.395, w;
+  for(Int_t i=1; i<5; i++){
+    w = TMath::Power(fZN1TowerEnergy[i], alpha);
+    NumX += x[i]*w;
+    NumY += y[i]*w;
+    Den += w;
+  }
+  if(Den!=0){
+    CentrCoord[0] = fCParCentr(NspecnC)*NumX/Den;
+    CentrCoord[1] = fCParCentr(NspecnC)*NumY/Den;
+  }
+  return CentrCoord;
+}
 
+//______________________________________________________________________________
+const Float_t * AliESDZDC::GetZNACentroid(int NspecnA) const
+{
+  // Provide coordinates of centroid over ZN (side A) front face
+  Float_t CentrCoord[2];
+  Float_t x[4] = {-1.75, 1.75, -1.75, 1.75};
+  Float_t y[4] = {-1.75, -1.72, 1.75, 1.75};
+  Float_t NumX=0., NumY=0., Den=0.;
+  Float_t alpha=0.395, w;
+  for(Int_t i=1; i<5; i++){
+    w = TMath::Power(fZN2TowerEnergy[i], alpha);
+    NumX += x[i]*w;
+    NumY += y[i]*w;
+    Den += w;
+  }
+  CentrCoord[0] = fCParCentr(NspecnA)*NumX/Den;
+  CentrCoord[1] = fCParCentr(NspecnA)*NumY/Den;
+  return CentrCoord;
+}
index b69e6b8761aa2c65f86e86605650e3d81851f72e..bedd2ada9334b00d4e5ee12c5c53031776dbcd1d 100644 (file)
@@ -7,12 +7,12 @@
 
 //-------------------------------------------------------------------------
 //                      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 
 //-------------------------------------------------------------------------
 
 #include <TObject.h>
+#include <TMath.h>
 
 
 class AliESDZDC: public TObject {
@@ -25,8 +25,8 @@ public:
   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;}
   const Double_t * GetZN1TowerEnergy() const {return fZN1TowerEnergy;}
   const Double_t * GetZN2TowerEnergy() const {return fZN2TowerEnergy;}
@@ -36,46 +36,42 @@ public:
   const Double_t * GetZN2TowerEnergyLR() const {return fZN2TowerEnergyLR;}
   const Double_t * GetZP1TowerEnergyLR() const {return fZP1TowerEnergyLR;}
   const Double_t * GetZP2TowerEnergyLR() const {return fZP2TowerEnergyLR;}
+  //
+  const Float_t * GetZNCCentroid(int NspecnC) const;
+  const Float_t * GetZNACentroid(int NspecnA) const;
+  //
   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<5; i++) fZN1TowerEnergy[i] = tow1[i];
-  }
-  void  SetZN2TowerEnergy(Float_t tow2[5]){
-      for(Int_t i=0; i<5; i++) fZN2TowerEnergy[i] = tow2[i];
-  }
-  void  SetZP1TowerEnergy(Float_t tow1[5]){
-      for(Int_t i=0; i<5; i++) fZP1TowerEnergy[i] = tow1[i];
-  }
-  void  SetZP2TowerEnergy(Float_t tow2[5]){
-      for(Int_t i=0; i<5; i++) fZP2TowerEnergy[i] = tow2[i];
-  }
-  void  SetZN1TowerEnergyLR(Float_t tow1[5]){
-      for(Int_t i=0; i<5; i++) fZN1TowerEnergyLR[i] = tow1[i];
-  }
-  void  SetZN2TowerEnergyLR(Float_t tow2[5]){
-      for(Int_t i=0; i<5; i++) fZN2TowerEnergyLR[i] = tow2[i];
-  }
-  void  SetZP1TowerEnergyLR(Float_t tow1[5]){
-      for(Int_t i=0; i<5; i++) fZP1TowerEnergyLR[i] = tow1[i];
-  }
-  void  SetZP2TowerEnergyLR(Float_t tow2[5]){
-      for(Int_t i=0; i<5; i++) fZP2TowerEnergyLR[i] = tow2[i];
-  }
+  void  SetZN1TowerEnergy(Float_t tow1[5])
+          {for(Int_t i=0; i<5; i++) fZN1TowerEnergy[i] = tow1[i];}
+  void  SetZN2TowerEnergy(Float_t tow2[5])
+          {for(Int_t i=0; i<5; i++) fZN2TowerEnergy[i] = tow2[i];}
+  void  SetZP1TowerEnergy(Float_t tow1[5])
+          {for(Int_t i=0; i<5; i++) fZP1TowerEnergy[i] = tow1[i];}
+  void  SetZP2TowerEnergy(Float_t tow2[5])
+          {for(Int_t i=0; i<5; i++) fZP2TowerEnergy[i] = tow2[i];}
+  void  SetZN1TowerEnergyLR(Float_t tow1[5])
+          {for(Int_t i=0; i<5; i++) fZN1TowerEnergyLR[i] = tow1[i];}
+  void  SetZN2TowerEnergyLR(Float_t tow2[5])
+          {for(Int_t i=0; i<5; i++) fZN2TowerEnergyLR[i] = tow2[i];}
+  void  SetZP1TowerEnergyLR(Float_t tow1[5])
+          {for(Int_t i=0; i<5; i++) fZP1TowerEnergyLR[i] = tow1[i];}
+  void  SetZP2TowerEnergyLR(Float_t tow2[5])
+          {for(Int_t i=0; i<5; i++) fZP2TowerEnergyLR[i] = tow2[i];}
 
   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