]> git.uio.no Git - u/mrichter/AliRoot.git/blobdiff - EMCAL/AliEMCALDigit.h
Change digits energy from Int_t to Float; Implement time cut window in clusterization
[u/mrichter/AliRoot.git] / EMCAL / AliEMCALDigit.h
index d50ba86158358b8f2a616eef3118db3bb275d6fa..bc5b1ad4b3dc13e9c85cc96744d45232deaf4ec4 100644 (file)
@@ -31,7 +31,7 @@ class AliEMCALDigit : public AliDigitNew {
  public:
   
   AliEMCALDigit() ;
-  AliEMCALDigit(Int_t primary, Int_t iparent, Int_t id, Int_t DigEnergy, Float_t Time, Int_t index = -1, Float_t dE = 0) ;
+  AliEMCALDigit(Int_t primary, Int_t iparent, Int_t id, Float_t digEnergy, Float_t time, Bool_t trigger,Int_t index = -1, Float_t dE = 0) ;
   AliEMCALDigit(const AliEMCALDigit & digit) ;
   virtual ~AliEMCALDigit() ;
 
@@ -40,26 +40,58 @@ class AliEMCALDigit : public AliDigitNew {
   AliEMCALDigit operator*(Float_t factor) ; 
   const AliEMCALDigit& operator = (const AliEMCALDigit &) {return *this;}
 
-  Int_t   Compare(const TObject * obj) const ;  
-  Float_t GetEta() const ; 
-  Int_t   GetNprimary() const { return fNprimary ; }
-  Int_t   GetPrimary(Int_t index) const ; 
+  Int_t   Compare(const TObject * obj) const ;
+  Float_t GetAmplitude()   const { if(!fAmp)return fAmpFloat ; else return fAmp ;}//Keep backward compatibility.
+  Float_t GetEta()         const ; 
+  Int_t   GetNprimary()    const { return fNprimary ;}
+  Int_t   GetPrimary(Int_t index)   const ; 
   Float_t GetDEPrimary(Int_t index) const ; 
-  Int_t   GetNiparent() const {return fNiparent;}
-  Int_t   GetIparent(Int_t index) const ;
-  Float_t GetDEParent(Int_t index) const ; 
-  Float_t GetPhi() const;
-  Float_t GetTime(void) const {return fTime ;}
-  Float_t GetTimeR(void) const {return fTimeR ;}
-  Bool_t  IsSortable() const { return kTRUE ; }
-  void    SetAmp(Int_t amp) { fAmp= amp ; } 
-  void    SetId(Int_t id) {fId = id ;}
-  void    SetTime(Float_t time) {fTime = time ;}
-  void    SetTimeR(Float_t time) {fTimeR = time ;}
+  Int_t   GetNiparent()    const { return fNiparent ;}
+  Int_t   GetIparent(Int_t index)   const ;
+  Float_t GetDEParent(Int_t index)  const ; 
+  Float_t GetPhi()         const ;
+  Float_t GetTime(void)    const { return fTime  ;}
+  Float_t GetTimeR(void)   const { return fTimeR ;}
+  Float_t GetChi2(void)    const { return fChi2  ;}
+  Int_t   GetNDF(void)     const { return fNDF   ;}
+  Bool_t  IsSortable()     const { return kTRUE  ;}
+  Bool_t  IsTriggerDigit() const { return fTriggerDigit ;}
+       
+  void    SetAmp(Int_t amp)         { fAmp      = amp  ;} //old
+  void    SetAmplitude(Float_t amp) { fAmpFloat = amp  ;}
+  void    SetId(Int_t id)           { fId       = id   ;}
+  void    SetTime(Float_t time)     { fTime     = time ;}
+  void    SetTimeR(Float_t time)    { fTimeR    = time ;}
+  void    SetChi2(Float_t chi)      { fChi2     = chi  ;}
+  void    SetNDF(Int_t ndf)         { fNDF      = ndf  ;}
+  void    SetTriggerDigit(Bool_t b) { fTriggerDigit = b ;}
   void    ShiftPrimary(Int_t shift); // shift to separate different TreeK in merging
- private: 
+       
+  //Raw time sample
+  //ALTRO
+  Int_t   GetNALTROSamplesLG() const {if(!fTriggerDigit)return fNSamples; else return 0;}
+  Bool_t  GetALTROSampleLG(const Int_t iSample, Int_t& timeBin, Int_t& amp) const;
+  Int_t   GetNALTROSamplesHG() const {if(!fTriggerDigit) return fNSamplesHG; else return 0;}
+  Bool_t  GetALTROSampleHG(const Int_t iSample, Int_t& timeBin, Int_t& amp) const;
+  //FALTRO, trigger. Same data members as Low Gain     
+  Int_t   GetNFALTROSamples() const 
+       {if(fTriggerDigit) return fNSamples; else return 0;}
+  Bool_t  GetFALTROSample(const Int_t iSample, Int_t& timeBin, Int_t& amp) const ;
+       
+  void SetALTROSamplesHG (const Int_t nSamplesHG, Int_t *samplesHG);
+  void SetALTROSamplesLG (const Int_t nSamplesLG, Int_t *samplesLG);
+  void SetFALTROSamples  (const Int_t nSamples,   Int_t *samples) { if(fTriggerDigit) SetALTROSamplesLG(nSamples, samples);} 
 
+  void Print(const Option_t* /*opt*/) const;
+       
+ private: 
+       
+  Float_t fAmpFloat;    // Cell amplitude, float
+  Int_t   fNSamples;    // Number of time samples, Low Gain for ALTRO, used also for FALTRO 
+  Int_t*  fSamples;        //[fNSamples], list of time bin constents, Low Gain for ALTRO, used also for FALTRO 
+  Int_t   fNSamplesHG;  // Number of time samples, High Gain for ALTRO
+  Int_t*  fSamplesHG;  //[fNSamples], list of time bin constents, High Gain for ALTRO, used also for FALTRO 
+       
   Int_t fNprimary ;     // Number of primaries
   Int_t fNMaxPrimary ;  // Max Number of primaries
   Int_t *fPrimary ;     //[fNMaxPrimary]  Array of primaries       
@@ -72,8 +104,13 @@ class AliEMCALDigit : public AliDigitNew {
   Int_t fMaxIter  ;     // Number to Increment Maxiparent, and MaxPrimary if default is not sufficient
   Float_t fTime ;       // Calculated time  
   Float_t fTimeR ;      // Earliest time: to be used by Digits2Raw
-  ClassDef(AliEMCALDigit,3)   // Digit in EMCAL 
+  //Fit quality parameters
+  Float_t fChi2;        // Fit Chi aquare      
+  Int_t   fNDF;          // Fit Number of Degrees of Freedom
+       
+  Bool_t fTriggerDigit; // This is a trigger digit or not 
+       
+  ClassDef(AliEMCALDigit,4)   // Digit in EMCAL 
 
 } ;