3 /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights
6 * Latest changes by Christian Holm Christensen <cholm@nbi.dk>
8 * See cxx source for full Copyright notice
11 //____________________________________________________________________
13 // Manager class for the FMD - Base class.
14 // AliFMDv1, AliFMDv0, and AliFMDAlla
15 // provides concrete implementations.
16 // This class is sooooo crowded
19 # include <AliDetector.h>
31 //____________________________________________________________________
32 class AliFMD : public AliDetector
36 AliFMD(const char *name, const char *title);
37 AliFMD(const AliFMD& other);
39 AliFMD& operator=(const AliFMD& other);
40 // Use old implementation
41 void UseOld(Bool_t use=kTRUE) { fUseOld = use; }
42 void UseAssembly(Bool_t use=kTRUE) { fUseAssembly = use; }
43 void UseDetailed(Bool_t use=kTRUE) { fDetailed = use; }
45 // GEometry ANd Tracking (GEANT :-)
46 virtual void CreateGeometry();
47 virtual void CreateMaterials();
49 virtual void StepManager() = 0;
50 virtual void FinishEvent();
52 // Graphics and event display
53 virtual void BuildGeometry();
54 virtual void DrawDetector();
55 virtual Int_t DistanceToPrimitive(Int_t px, Int_t py);
56 virtual void LoadPoints(Int_t track);
58 // Hit and digit management
59 virtual void MakeBranch(Option_t *opt=" ");
60 virtual void SetHitsAddressBranch(TBranch *b);
61 virtual void SetTreeAddress();
62 virtual TClonesArray* SDigits() { return fSDigits; }
63 virtual void ResetSDigits();
64 virtual void AddHit(Int_t track, Int_t *vol, Float_t *hits);
65 virtual AliFMDHit* AddHitByFields(Int_t track,
80 Bool_t stopped=kFALSE);
81 virtual void AddDigit(Int_t *digits, Int_t* notused=0);
82 virtual void AddDigitByFields(UShort_t detector=0,
89 virtual void AddSDigit(Int_t *digits);
90 virtual void AddSDigitByFields(UShort_t detector=0,
100 virtual AliDigitizer* CreateDigitizer(AliRunDigitizer* manager) const;
101 virtual void Hits2Digits();
102 virtual void Hits2SDigits();
105 virtual void Digits2Raw();
108 void Browse(TBrowser* b);
110 TClonesArray* HitsArray();
111 TClonesArray* DigitsArray();
112 TClonesArray* SDigitsArray();
114 TClonesArray* fSDigits; // Summable digits
115 Int_t fNsdigits; // Number of digits
116 Bool_t fDetailed; // Use detailed geometry
117 Bool_t fUseOld; // Use old approx geometry
118 Bool_t fUseAssembly; // Use divided volumes
121 kSiId, // ID index of Si medium
122 kAirId, // ID index of Air medium
123 kPlasticId, // ID index of Plastic medium
124 kPcbId, // ID index of PCB medium
125 kSiChipId, // ID index of Si Chip medium
126 kAlId, // ID index of Al medium
127 kCarbonId, // ID index of Carbon medium
128 kCopperId, // ID index of Copper Medium
129 kKaptonId // ID index of Kapton Medium
132 TObjArray* fBad; //! debugging - bad hits
134 ClassDef(AliFMD,11) // Base class FMD entry point
138 //____________________________________________________________________