]> git.uio.no Git - u/mrichter/AliRoot.git/blame - PHOS/AliPHOSv1.h
Typo
[u/mrichter/AliRoot.git] / PHOS / AliPHOSv1.h
CommitLineData
7587f5a5 1#ifndef ALIPHOSV1_H
2#define ALIPHOSV1_H
5f20d3fb 3/* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
7587f5a5 4 * See cxx source for full Copyright notice */
5f20d3fb 5
702ab87e 6/* $Id$ */
7
8/* History of cvs commits:
9 *
10 * $Log$
43fbaae1 11 * Revision 1.39 2005/05/28 14:19:05 schutz
12 * Compilation warnings fixed by T.P.
13 *
702ab87e 14 */
15
b2a60966 16//_________________________________________________________________________
5f20d3fb 17// Implementation version v1 of PHOS Manager class
a3dfe79c 18// Layout EMC + CPV has name IHEP
19//*--
5f20d3fb 20//*-- Author: Yves Schutz (SUBATECH)
7587f5a5 21
22// --- ROOT system ---
13add4de 23class TClonesArray ;
24class TLorentzVector ;
2ab0c725 25class TFile;
26
7587f5a5 27// --- AliRoot header files ---
28#include "AliPHOSv0.h"
7587f5a5 29
30class AliPHOSv1 : public AliPHOSv0 {
31
32public:
33
bea63bea 34 AliPHOSv1(void) ;
7587f5a5 35 AliPHOSv1(const char *name, const char *title="") ;
43fbaae1 36 AliPHOSv1(AliPHOSv1 & phos);
bea63bea 37 virtual ~AliPHOSv1(void) ;
38
702ab87e 39 virtual void Copy(TObject &phos) const;
40
41 using AliPHOSv0::AddHit;
2af5445a 42 virtual void AddHit( Int_t shunt, Int_t primary, Int_t id, Float_t *hits) ;
7b326aac 43 virtual void FinishEvent() ;
44 virtual void FinishPrimary() ;
45 virtual Int_t IsVersion(void) const {
037cc66d 46 // Gives the version number
47 return 1 ;
48 }
49
0a6d52e3 50 virtual void StepManager(void) ;
bd46a237 51 virtual const TString Version(void)const { return TString("v1") ; }
5f20d3fb 52
8c140292 53 AliPHOSv1 & operator = (const AliPHOSv1 & /*rvalue*/) {
a3dfe79c 54 // assignement operator requested by coding convention but not needed
f1611b7c 55 Fatal("operator =", "not implemented") ;
5f20d3fb 56 return *this ;
57 }
bea63bea 58
90cceaf6 59 void CPVDigitize (TLorentzVector p, Float_t *xy, TClonesArray *digits) ;
fa412d9b 60 Float_t CPVPadResponseFunction(Float_t qhit, Float_t zg, Float_t xg) ;
61 Double_t CPVCumulPadResponse(Double_t x, Double_t y) ;
62
9688c1dd 63 //Variables conserning light yeild and APD efficiency
64 Float_t GetLightYieldMean() const { return fLightYieldMean ;}
65 Float_t GetLightYieldAttenuation() const { return fLightYieldAttenuation ;}
66 Float_t GetRecalibrationFactor() const { return fRecalibrationFactor ;}
67 Float_t GetAPDGain() const { return fAPDGain ;}
68 Float_t GetIntrinsicPINEfficiency() const { return fIntrinsicPINEfficiency ;}
69 Float_t GetElectronsPerGeV() const { return fElectronsPerGeV ;}
70
71 void SetLightYieldMean(Float_t LightYieldMean)
72 {fLightYieldMean = LightYieldMean;}
73 void SetLightYieldAttenuation(Float_t LightYieldAttenuation)
74 {fLightYieldAttenuation = LightYieldAttenuation;}
75 void SetIntrinsicPINEfficiency(Float_t IntrinsicPINEfficiency)
76 {fIntrinsicPINEfficiency = IntrinsicPINEfficiency;}
77 void SetRecalibrationFactor(Float_t RecalibrationFactor)
78 {fRecalibrationFactor = RecalibrationFactor;}
79 void SetElectronsPerGeV(Float_t ElectronsPerGeV)
80 {fElectronsPerGeV = ElectronsPerGeV;}
81 void SetAPDGain(Float_t APDGain) {fAPDGain = APDGain;}
82
bea63bea 83protected:
84
9688c1dd 85 Float_t fLightYieldMean ; // Mean lightyield in the PbOW4 xtal per GeV (Poisson distribution)
86 Float_t fIntrinsicPINEfficiency ; // Photo efficiency of the PIN diode
87 Float_t fLightYieldAttenuation ; // Attenuation of the light through the crystal
88 Float_t fRecalibrationFactor ; // Recalibration factor
89 Float_t fElectronsPerGeV ; // Number of electrons per GeV created in the PIN by a ionizing particle
90 Float_t fAPDGain ; // APD Gain
27f33ee5 91 Float_t fLightFactor ; //! a calculated factor
92 Float_t fAPDFactor ; //! a calculated factor
fa412d9b 93
184569b0 94 ClassDef(AliPHOSv1,2) // Implementation of PHOS manager class for layout EMC+PPSD
7587f5a5 95
96};
97
98#endif // AliPHOSV1_H