* See cxx source for full Copyright notice */
/* $Id$ */
+// Revision of includes 07/05/2004
+
+/// \ingroup sim
+/// \class AliMUONResponseV0
+/// \brief Implementation of Mathieson response
#include "AliMUONResponse.h"
+#include "AliMUONMathieson.h"
-class AliMUONResponseV0 :
-public AliMUONResponse {
+class AliMUONResponseV0 : public AliMUONResponse
+{
public:
- AliMUONResponseV0(){fChargeCorrel = 0;} // by default
- virtual ~AliMUONResponseV0(){}
+ AliMUONResponseV0();
+ virtual ~AliMUONResponseV0();
//
// Configuration methods
//
// 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
- virtual Float_t SigmaIntegration() {return fSigmaIntegration;}
+ virtual Float_t SigmaIntegration() const {return fSigmaIntegration;}
// Set single electron pulse height (ADCcounts/e)
virtual void SetChargeSlope(Float_t p1) {fChargeSlope=p1;}
// Get Set single electron pulse height (ADCcounts/e)
- virtual Float_t ChargeSlope() {return fChargeSlope;}
+ virtual Float_t ChargeSlope() const {return fChargeSlope;}
// 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
- virtual Float_t ChargeSpreadX() {return fChargeSpreadX;}
+ virtual Float_t ChargeSpreadX() const {return fChargeSpreadX;}
// Get sigma_Y of the charge spread function
- virtual Float_t ChargeSpreadY() {return fChargeSpreadY;}
+ virtual Float_t ChargeSpreadY() const {return fChargeSpreadY;}
// Set maximum Adc-count value
virtual void SetMaxAdc(Int_t p1) {fMaxAdc=p1;}
+ // Set saturation value
+ virtual void SetSaturation(Int_t p1) {fSaturation=p1;}
// Set zero suppression threshold
virtual void SetZeroSuppression(Int_t p1) {fZeroSuppression=p1;}
// Get maximum Adc-count value
- virtual Int_t MaxAdc() {return fMaxAdc;}
+ virtual Int_t MaxAdc() const {return fMaxAdc;}
+ // Get saturation value
+ virtual Int_t Saturation() const {return fSaturation;}
+
// Get zero suppression threshold
- virtual Int_t ZeroSuppression() {return fZeroSuppression;}
- // Set anode cathode Pitch
- virtual Float_t Pitch() {return fPitch;}
- // Get anode cathode Pitch
- virtual void SetPitch(Float_t p1) {fPitch=p1;};
+ virtual Int_t ZeroSuppression() const {return fZeroSuppression;}
// Set the charge correlation
virtual void SetChargeCorrel(Float_t correl){fChargeCorrel = correl;}
// Get the charge correlation
- virtual Float_t ChargeCorrel(){return fChargeCorrel;}
+ virtual Float_t ChargeCorrel() const {return fChargeCorrel;}
+
+
+ // Set anode cathode Pitch
+ virtual Float_t Pitch() const {return fMathieson->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
- virtual void SetSqrtKx3AndDeriveKx2Kx4(Float_t SqrtKx3);
+ // 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}
- virtual void SetSqrtKx3(Float_t p1) {fSqrtKx3=p1;};
+ virtual void SetSqrtKx3(Float_t p1) {fMathieson->SetSqrtKx3(p1);};
// Mathieson Kx2
- virtual void SetKx2(Float_t p1) {fKx2=p1;};
+ virtual void SetKx2(Float_t p1) {fMathieson->SetKx2(p1);};
// Mathieson Kx4
- virtual void SetKx4(Float_t p1) {fKx4=p1;};
+ virtual void SetKx4(Float_t p1) {fMathieson->SetKx4(p1);};
// Mathieson \sqrt{Ky3} and derived Ky2 and Ky4
virtual void SetSqrtKy3AndDeriveKy2Ky4(Float_t SqrtKy3);
// Mathieson \sqrt{Ky3}
- virtual void SetSqrtKy3(Float_t p1) {fSqrtKy3=p1;};
+ virtual void SetSqrtKy3(Float_t p1) {fMathieson->SetSqrtKy3(p1);};
// Mathieson Ky2
- virtual void SetKy2(Float_t p1) {fKy2=p1;};
+ virtual void SetKy2(Float_t p1) {fMathieson->SetKy2(p1);};
// Mathieson Ky4
- virtual void SetKy4(Float_t p1) {fKy4=p1;};
+ 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);
// Charge disintegration
- virtual Float_t IntXY(AliSegmentation * segmentation);
+ virtual Float_t IntXY(Int_t idDE, AliMUONGeometrySegmentation* segmentation);
// Noise, zero-suppression, adc saturation
virtual Int_t DigitResponse(Int_t digit, AliMUONTransientDigit* where);
ClassDef(AliMUONResponseV0,1) // Implementation of Mathieson response
protected:
+ AliMUONResponseV0(const AliMUONResponseV0& rhs);
+ AliMUONResponseV0& operator = (const AliMUONResponseV0& rhs);
+
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
Float_t fSigmaIntegration; // Number of sigma's used for charge distribution
Int_t fMaxAdc; // Maximum ADC channel
+ Int_t fSaturation; // Pad saturation in ADC channel
Int_t fZeroSuppression; // Zero suppression threshold
Float_t fChargeCorrel; // amplitude of charge correlation on 2 cathods
// is RMS of ln(q1/q2)
- Float_t fSqrtKx3; // Mathieson Sqrt(Kx3)
- Float_t fKx2; // Mathieson Kx2
- Float_t fKx4; // Mathieson Kx4 = Kx1/Kx2/Sqrt(Kx3)
- Float_t fSqrtKy3; // Mathieson Sqrt(Ky3)
- Float_t fKy2; // Mathieson Ky2
- Float_t fKy4; // Mathieson Ky4 = Ky1/Ky2/Sqrt(Ky3)
- Float_t fPitch; // anode-cathode pitch
+ AliMUONMathieson* fMathieson; // pointer to mathieson fct
+
};
#endif