]>
Commit | Line | Data |
---|---|---|
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 | 16 | class 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 |
64 | /// Mathieson \sqrt{Kx3} and derived Kx2 and Kx4 | |
65 | /// passing pointer to class Mathieson for backward compatibility | |
a713db22 | 66 | virtual void SetSqrtKx3AndDeriveKx2Kx4(Float_t SqrtKx3); |
7fc86979 | 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);}; |
7fc86979 | 73 | /// Mathieson \sqrt{Ky3} and derived Ky2 and Ky4 |
d5bfadcc | 74 | virtual void SetSqrtKy3AndDeriveKy2Ky4(Float_t SqrtKy3); |
7fc86979 | 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: |
829425a5 | 96 | Float_t fChargeSlope; ///< Slope of the charge distribution |
97 | Float_t fChargeSpreadX; ///< Width of the charge distribution in x | |
98 | Float_t fChargeSpreadY; ///< Width of the charge distribution in y | |
99 | Float_t fSigmaIntegration; ///< Number of sigma's used for charge distribution | |
100 | Int_t fMaxAdc; ///< Maximum ADC channel | |
101 | Int_t fSaturation; ///< Pad saturation in ADC channel | |
102 | Int_t fZeroSuppression; ///< Zero suppression threshold | |
103 | Float_t fChargeCorrel; ///< \brief amplitude of charge correlation on 2 cathods | |
104 | /// is RMS of ln(q1/q2) | |
105 | AliMUONMathieson* fMathieson; ///< pointer to mathieson fct | |
106 | Float_t fChargeThreshold; ///< Charges below this threshold are = 0 | |
b42c2a93 | 107 | |
108 | private: | |
109 | AliMUONResponseV0(const AliMUONResponseV0& rhs); | |
110 | AliMUONResponseV0& operator = (const AliMUONResponseV0& rhs); | |
111 | ||
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 |