]> git.uio.no Git - u/mrichter/AliRoot.git/blobdiff - MUON/AliMUONResponseV0.h
updated vertex selection
[u/mrichter/AliRoot.git] / MUON / AliMUONResponseV0.h
index 88db99977f764d1f08713ca2dff5887e2a331a4e..6575f7f97971b6276bdd3b9f4c41362ee214132c 100644 (file)
@@ -17,82 +17,89 @@ class AliMUONResponseV0 : public AliMUONResponse
 {
  public:
   AliMUONResponseV0();
-    virtual ~AliMUONResponseV0();
-    //
+  AliMUONResponseV0(const AliMUONResponseV0& rhs);
+  AliMUONResponseV0& operator = (const AliMUONResponseV0& rhs);
+  virtual ~AliMUONResponseV0();
+  
+  //
     // Configuration methods
     //
-    // Set number of sigmas over which cluster didintegration is performed
+    /// Set number of sigmas over which cluster didintegration is performed
     virtual void    SetSigmaIntegration(Float_t p1) {fSigmaIntegration=p1;}
-    // Get number of sigmas over which cluster didintegration is performed   
+    /// Get number of sigmas over which cluster didintegration is performed   
     virtual Float_t SigmaIntegration() const {return fSigmaIntegration;}    
-    // Set single electron pulse height (ADCcounts/e)
+    /// Set single electron pulse height (ADCcounts/e)
     virtual void    SetChargeSlope(Float_t p1) {fChargeSlope=p1;}
-    // Get Set single electron pulse height (ADCcounts/e)
+    /// Get Set single electron pulse height (ADCcounts/e)
     virtual Float_t ChargeSlope() const     {return fChargeSlope;}
-    // Set sigmas of the charge spread function
+    /// Set sigmas of the charge spread function
     virtual void    SetChargeSpread(Float_t p1, Float_t p2)
        {fChargeSpreadX=p1; fChargeSpreadY=p2;}
-    // Get sigma_X of the charge spread function
+    /// Get sigma_X of the charge spread function
     virtual Float_t ChargeSpreadX() const    {return fChargeSpreadX;}
-    // Get sigma_Y of the charge spread function
+    /// Get sigma_Y of the charge spread function
     virtual Float_t ChargeSpreadY() const    {return fChargeSpreadY;}        
-    // Set maximum Adc-count value
+    /// Set maximum Adc-count value
     virtual void    SetMaxAdc(Int_t p1) {fMaxAdc=p1;}
-    // Set saturation value
+    /// Set saturation value
     virtual void    SetSaturation(Int_t p1) {fSaturation=p1;}
-    // Set zero suppression threshold
+    /// Set zero suppression threshold
     virtual void    SetZeroSuppression(Int_t p1) {fZeroSuppression=p1;}
-    // Get maximum Adc-count value   
+    /// Get maximum Adc-count value   
     virtual Int_t   MaxAdc() const          {return fMaxAdc;}
-    // Get saturation value   
+    /// Get saturation value   
     virtual Int_t   Saturation() const      {return fSaturation;}
 
-    // Get zero suppression threshold
+    /// Get zero suppression threshold
     virtual Int_t   ZeroSuppression() const {return fZeroSuppression;}
-    // Set the charge correlation
+    /// Set the charge correlation
     virtual void SetChargeCorrel(Float_t correl){fChargeCorrel = correl;}
-    // Get the charge correlation
+    /// Get the charge correlation
     virtual Float_t ChargeCorrel() const {return fChargeCorrel;}
 
 
-    // Set anode cathode Pitch
+    /// Set anode cathode Pitch
     virtual Float_t Pitch() const           {return fMathieson->Pitch();}
-    // Get anode cathode Pitch
+    /// Get anode cathode Pitch
     virtual void    SetPitch(Float_t p1)    {fMathieson->SetPitch(p1);};
 
-    // Set Mathieson parameters
-    // Mathieson \sqrt{Kx3} and derived Kx2 and Kx4 
-    // passing pointer to class Mathieson for backward compatibility
+    /// Set Mathieson parameters
+    /// Mathieson sqrt{Kx3} and derived Kx2 and Kx4 
+    /// passing pointer to class Mathieson for backward compatibility
     virtual void    SetSqrtKx3AndDeriveKx2Kx4(Float_t SqrtKx3);
-    // Mathieson \sqrt{Kx3}
+    /// Mathieson sqrt{Kx3}
     virtual void    SetSqrtKx3(Float_t p1) {fMathieson->SetSqrtKx3(p1);};
-    // Mathieson Kx2
+    /// Mathieson Kx2
     virtual void    SetKx2(Float_t p1)     {fMathieson->SetKx2(p1);};
-    // Mathieson Kx4
+    /// Mathieson Kx4
     virtual void    SetKx4(Float_t p1)     {fMathieson->SetKx4(p1);};
-    // Mathieson \sqrt{Ky3} and derived Ky2 and Ky4
+    /// Mathieson sqrt{Ky3} and derived Ky2 and Ky4
     virtual void SetSqrtKy3AndDeriveKy2Ky4(Float_t SqrtKy3);
-    // Mathieson \sqrt{Ky3}
+    /// Mathieson sqrt{Ky3}
     virtual void    SetSqrtKy3(Float_t p1) {fMathieson->SetSqrtKy3(p1);};
-    // Mathieson Ky2
+    /// Mathieson Ky2
     virtual void    SetKy2(Float_t p1)     {fMathieson->SetKy2(p1);};
-    // Mathieson Ky4
+    /// Mathieson Ky4
       virtual void SetKy4(Float_t p1)     {fMathieson->SetKy4(p1);};
     //  
     // Chamber response methods
     // Pulse height from scored quantity (eloss)
     virtual Float_t  IntPH(Float_t eloss) const;
-    // Charge disintegration
-    virtual Float_t  IntXY(Int_t idDE, 
-                          AliMUONGeometrySegmentation* segmentation) const;
 
+    /// Parametrised tail effect in resolution histogram
+    virtual void    SetTailEffect(Bool_t isTail) {fIsTailEffect=isTail;}
+    
     virtual Float_t GetAnod(Float_t x) const;
     
     virtual void DisIntegrate(const AliMUONHit& hit, TList& digits);
     
     virtual void Print(Option_t* opt="") const;
-     
- protected:
+  
+private:
+    void CopyTo(AliMUONResponseV0& other) const;
+    
+private:
+   
     Float_t fChargeSlope;              ///< Slope of the charge distribution
     Float_t fChargeSpreadX;            ///< Width of the charge distribution in x
     Float_t fChargeSpreadY;            ///< Width of the charge distribution in y
@@ -104,12 +111,9 @@ class AliMUONResponseV0 : public AliMUONResponse
                                        ///  is RMS of ln(q1/q2)
     AliMUONMathieson* fMathieson;      ///< pointer to mathieson fct
     Float_t fChargeThreshold;          ///< Charges below this threshold are = 0  
+    Bool_t   fIsTailEffect;            ///< switch to turn on/off the tail effect
+      
 
-  private:
-    AliMUONResponseV0(const AliMUONResponseV0& rhs);
-    AliMUONResponseV0& operator = (const AliMUONResponseV0& rhs);
-
-   
     ClassDef(AliMUONResponseV0,2) // Implementation of detector response
 };