Code from MUON-dev joined
[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$ */
7
8#include "AliMUONResponse.h"
9
10class AliMUONResponseV0 :
11public AliMUONResponse {
12 public:
13 AliMUONResponseV0(){}
14 virtual ~AliMUONResponseV0(){}
15 //
16 // Configuration methods
17 //
18 // Set number of sigmas over which cluster didintegration is performed
19 virtual void SetSigmaIntegration(Float_t p1) {fSigmaIntegration=p1;}
20 // Get number of sigmas over which cluster didintegration is performed
21 virtual Float_t SigmaIntegration() {return fSigmaIntegration;}
22 // Set single electron pulse height (ADCcounts/e)
23 virtual void SetChargeSlope(Float_t p1) {fChargeSlope=p1;}
24 // Get Set single electron pulse height (ADCcounts/e)
25 virtual Float_t ChargeSlope() {return fChargeSlope;}
26 // Set sigmas of the charge spread function
27 virtual void SetChargeSpread(Float_t p1, Float_t p2)
28 {fChargeSpreadX=p1; fChargeSpreadY=p2;}
29 // Get sigma_X of the charge spread function
30 virtual Float_t ChargeSpreadX() {return fChargeSpreadX;}
31 // Get sigma_Y of the charge spread function
32 virtual Float_t ChargeSpreadY() {return fChargeSpreadY;}
33 // Set maximum Adc-count value
34 virtual void SetMaxAdc(Int_t p1) {fMaxAdc=p1;}
35 // Set zero suppression threshold
36 virtual void SetZeroSuppression(Int_t p1) {fZeroSuppression=p1;}
37 // Get maximum Adc-count value
38 virtual Int_t MaxAdc() {return fMaxAdc;}
39 // Get zero suppression threshold
40 virtual Int_t ZeroSuppression() {return fZeroSuppression;}
41 // Set anode cathode Pitch
42 virtual Float_t Pitch() {return fPitch;}
43 // Get anode cathode Pitch
44 virtual void SetPitch(Float_t p1) {fPitch=p1;};
45 // Set Mathieson parameters
46 // Mathieson \sqrt{Kx3}
47 virtual void SetSqrtKx3(Float_t p1) {fSqrtKx3=p1;};
48 // Mathieson Kx2
49 virtual void SetKx2(Float_t p1) {fKx2=p1;};
50 // Mathieson Kx4
51 virtual void SetKx4(Float_t p1) {fKx4=p1;};
52 // Mathieson \sqrt{Ky3}
53 virtual void SetSqrtKy3(Float_t p1) {fSqrtKy3=p1;};
54 // Mathieson Ky2
55 virtual void SetKy2(Float_t p1) {fKy2=p1;};
56 // Mathieson Ky4
57 virtual void SetKy4(Float_t p1) {fKy4=p1;};
58 //
59 // Chamber response methods
60 // Pulse height from scored quantity (eloss)
61 virtual Float_t IntPH(Float_t eloss);
62 // Charge disintegration
63 virtual Float_t IntXY(AliMUONSegmentation * segmentation);
64 // Noise, zero-suppression, adc saturation
65 virtual Int_t DigitResponse(Int_t digit);
66
67 ClassDef(AliMUONResponseV0,1) // Implementation of Mathieson response
68 protected:
69 Float_t fChargeSlope; // Slope of the charge distribution
70 Float_t fChargeSpreadX; // Width of the charge distribution in x
71 Float_t fChargeSpreadY; // Width of the charge distribution in y
72 Float_t fSigmaIntegration; // Number of sigma's used for charge distribution
73 Int_t fMaxAdc; // Maximum ADC channel
74 Int_t fZeroSuppression; // Zero suppression threshold
75 Float_t fSqrtKx3; // Mathieson \Sqrt{Kx3)
76 Float_t fKx2; // Mathieson Kx2
77 Float_t fKx4; // Mathieson Kx4
78 Float_t fSqrtKy3; // Mathieson \Sqrt{Kx3)
79 Float_t fKy2; // Mathieson Ky2
80 Float_t fKy4; // Mathieson Ky4
81 Float_t fPitch; // anode-cathode pitch
82};
83#endif
84
85
86
87
88
89
90
91
92
93
94