]> git.uio.no Git - u/mrichter/AliRoot.git/blame - MUON/AliMUONResponseV0.h
Reflecting changes in AliPreprocessor
[u/mrichter/AliRoot.git] / MUON / AliMUONResponseV0.h
CommitLineData
a9e2aefa 1#ifndef ALIMUONRESPONSEV0_H
2#define ALIMUONRESPONSEV0_H
3/* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
4 * See cxx source for full Copyright notice */
5
6/* $Id$ */
30178c30 7// Revision of includes 07/05/2004
a9e2aefa 8
692de412 9/// \ingroup sim
10/// \class AliMUONResponseV0
11/// \brief Implementation of Mathieson response
12
a9e2aefa 13#include "AliMUONResponse.h"
a713db22 14#include "AliMUONMathieson.h"
a9e2aefa 15
a713db22 16class AliMUONResponseV0 : public AliMUONResponse
30178c30 17{
a9e2aefa 18 public:
885d501b 19 AliMUONResponseV0();
a713db22 20 virtual ~AliMUONResponseV0();
a9e2aefa 21 //
22 // Configuration methods
23 //
7fc86979 24 /// Set number of sigmas over which cluster didintegration is performed
a9e2aefa 25 virtual void SetSigmaIntegration(Float_t p1) {fSigmaIntegration=p1;}
7fc86979 26 /// Get number of sigmas over which cluster didintegration is performed
30178c30 27 virtual Float_t SigmaIntegration() const {return fSigmaIntegration;}
7fc86979 28 /// Set single electron pulse height (ADCcounts/e)
a9e2aefa 29 virtual void SetChargeSlope(Float_t p1) {fChargeSlope=p1;}
7fc86979 30 /// Get Set single electron pulse height (ADCcounts/e)
30178c30 31 virtual Float_t ChargeSlope() const {return fChargeSlope;}
7fc86979 32 /// Set sigmas of the charge spread function
a9e2aefa 33 virtual void SetChargeSpread(Float_t p1, Float_t p2)
34 {fChargeSpreadX=p1; fChargeSpreadY=p2;}
7fc86979 35 /// Get sigma_X of the charge spread function
30178c30 36 virtual Float_t ChargeSpreadX() const {return fChargeSpreadX;}
7fc86979 37 /// Get sigma_Y of the charge spread function
30178c30 38 virtual Float_t ChargeSpreadY() const {return fChargeSpreadY;}
7fc86979 39 /// Set maximum Adc-count value
a9e2aefa 40 virtual void SetMaxAdc(Int_t p1) {fMaxAdc=p1;}
7fc86979 41 /// Set saturation value
a614d271 42 virtual void SetSaturation(Int_t p1) {fSaturation=p1;}
7fc86979 43 /// Set zero suppression threshold
a9e2aefa 44 virtual void SetZeroSuppression(Int_t p1) {fZeroSuppression=p1;}
7fc86979 45 /// Get maximum Adc-count value
30178c30 46 virtual Int_t MaxAdc() const {return fMaxAdc;}
7fc86979 47 /// Get saturation value
30178c30 48 virtual Int_t Saturation() const {return fSaturation;}
a614d271 49
7fc86979 50 /// Get zero suppression threshold
30178c30 51 virtual Int_t ZeroSuppression() const {return fZeroSuppression;}
7fc86979 52 /// Set the charge correlation
16d57990 53 virtual void SetChargeCorrel(Float_t correl){fChargeCorrel = correl;}
7fc86979 54 /// Get the charge correlation
30178c30 55 virtual Float_t ChargeCorrel() const {return fChargeCorrel;}
a713db22 56
57
7fc86979 58 /// Set anode cathode Pitch
a713db22 59 virtual Float_t Pitch() const {return fMathieson->Pitch();}
7fc86979 60 /// Get anode cathode Pitch
a713db22 61 virtual void SetPitch(Float_t p1) {fMathieson->SetPitch(p1);};
62
7fc86979 63 /// Set Mathieson parameters
c4ee792d 64 /// Mathieson sqrt{Kx3} and derived Kx2 and Kx4
7fc86979 65 /// passing pointer to class Mathieson for backward compatibility
a713db22 66 virtual void SetSqrtKx3AndDeriveKx2Kx4(Float_t SqrtKx3);
c4ee792d 67 /// Mathieson sqrt{Kx3}
a713db22 68 virtual void SetSqrtKx3(Float_t p1) {fMathieson->SetSqrtKx3(p1);};
7fc86979 69 /// Mathieson Kx2
a713db22 70 virtual void SetKx2(Float_t p1) {fMathieson->SetKx2(p1);};
7fc86979 71 /// Mathieson Kx4
a713db22 72 virtual void SetKx4(Float_t p1) {fMathieson->SetKx4(p1);};
c4ee792d 73 /// Mathieson sqrt{Ky3} and derived Ky2 and Ky4
d5bfadcc 74 virtual void SetSqrtKy3AndDeriveKy2Ky4(Float_t SqrtKy3);
c4ee792d 75 /// Mathieson sqrt{Ky3}
a713db22 76 virtual void SetSqrtKy3(Float_t p1) {fMathieson->SetSqrtKy3(p1);};
7fc86979 77 /// Mathieson Ky2
a713db22 78 virtual void SetKy2(Float_t p1) {fMathieson->SetKy2(p1);};
7fc86979 79 /// Mathieson Ky4
a713db22 80 virtual void SetKy4(Float_t p1) {fMathieson->SetKy4(p1);};
a9e2aefa 81 //
82 // Chamber response methods
83 // Pulse height from scored quantity (eloss)
85fec35d 84 virtual Float_t IntPH(Float_t eloss) const;
a9e2aefa 85 // Charge disintegration
85fec35d 86 virtual Float_t IntXY(Int_t idDE,
87 AliMUONGeometrySegmentation* segmentation) const;
a9e2aefa 88
885d501b 89 virtual Float_t GetAnod(Float_t x) const;
90
91 virtual void DisIntegrate(const AliMUONHit& hit, TList& digits);
92
93 virtual void Print(Option_t* opt="") const;
94
a9e2aefa 95 protected:
71a2d3aa 96 /// Not implemented
97 AliMUONResponseV0(const AliMUONResponseV0& rhs);
98 /// Not implemented
99 AliMUONResponseV0& operator = (const AliMUONResponseV0& rhs);
100
829425a5 101 Float_t fChargeSlope; ///< Slope of the charge distribution
102 Float_t fChargeSpreadX; ///< Width of the charge distribution in x
103 Float_t fChargeSpreadY; ///< Width of the charge distribution in y
104 Float_t fSigmaIntegration; ///< Number of sigma's used for charge distribution
105 Int_t fMaxAdc; ///< Maximum ADC channel
106 Int_t fSaturation; ///< Pad saturation in ADC channel
107 Int_t fZeroSuppression; ///< Zero suppression threshold
108 Float_t fChargeCorrel; ///< \brief amplitude of charge correlation on 2 cathods
109 /// is RMS of ln(q1/q2)
110 AliMUONMathieson* fMathieson; ///< pointer to mathieson fct
111 Float_t fChargeThreshold; ///< Charges below this threshold are = 0
b42c2a93 112
885d501b 113 ClassDef(AliMUONResponseV0,2) // Implementation of detector response
a9e2aefa 114};
885d501b 115
a9e2aefa 116#endif
117
118
119
120
121
122
123
124
125
126
127