AliRoot Core  a565103 (a565103)
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
AliMFT.h
Go to the documentation of this file.
1 #ifndef AliMFT_H
2 #define AliMFT_H
3 
4 /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
5  * See cxx source for full Copyright notice */
6 
7 //====================================================================================================================================================
8 //
9 // Geometry of the Muon Forward Tracker based on TGeo
10 //
11 // Contact author: antonio.uras@cern.ch
12 //
13 //====================================================================================================================================================
14 
15 #include "TFile.h"
16 #include "TGeoManager.h"
17 #include "TGeoVolume.h"
18 #include "TGeoMatrix.h"
19 #include "TVirtualMC.h"
20 #include "TTree.h"
21 #include "TClonesArray.h"
22 #include "TGeoGlobalMagField.h"
23 #include "AliRun.h"
24 #include "AliLoader.h"
25 #include "AliDetector.h"
26 #include "AliMC.h"
27 #include "AliMagF.h"
28 #include "AliMFTHit.h"
29 #include "AliMFTDigit.h"
30 #include "AliMFTCluster.h"
31 #include "AliTrackReference.h"
32 #include "AliMFTSegmentation.h"
33 #include "AliMFTDigitizer.h"
34 #include "AliMFTPlane.h"
35 #include "TString.h"
36 #include "TObjArray.h"
37 #include "AliMFTConstants.h"
38 
39 //====================================================================================================================================================
40 
41 class AliMFT : public AliDetector {
42 
43 public:
44 
45  AliMFT();
46  AliMFT(const Char_t *name, const Char_t *title);
47  AliMFT(const Char_t *name, const Char_t *title, Char_t *nameGeomFile);
48 
49  virtual ~AliMFT();
50 
51  Int_t IsVersion() const { return fVersion; }
52 
53  // ------- framework part -----------------------------------------------------------------------------------
54  void CreateMaterials(); // from AliModule invoked from AliMC
55  void CreateGeometry(); // from AliModule invoked from AliMC
56  void AddAlignableVolumes();
57  void StepManager(); // from AliModule invoked from AliMC::Stepping()
58  void Hits2SDigits();
59  void Hits2SDigitsLocal(TClonesArray *hits, const TObjArray *pSDig, Int_t track);
60  void MakeBranch(Option_t *option="");
61  void SetTreeAddress();
62 
63  // ------- create containers -----------------------------------------------------------------------------------
64  void CreateHits();
65  void CreateSDigits();
66  void CreateDigits();
67  void CreateRecPoints();
68 
69  TObjArray* GetSDigitsList() const { return fSDigitsPerPlane; } // get sdigits list for all planes
70  TClonesArray* GetSDigitsList(Int_t plane) const { return fSDigitsPerPlane ? (TClonesArray*) fSDigitsPerPlane->At(plane):0; }
71 
72  TObjArray* GetDigitsList() const{return fDigitsPerPlane;} // get digits list for all layers
73  TClonesArray* GetDigitsList(Int_t plane) const{return fDigitsPerPlane ? (TClonesArray*) fDigitsPerPlane->At(plane):0; }
74 
75  TObjArray* GetRecPointsList() const{return fRecPointsPerPlane;} // get cluster list for all layers
76  TClonesArray* GetRecPointsList(Int_t plane) const{return fRecPointsPerPlane ? (TClonesArray*) fRecPointsPerPlane->At(plane):0; }
77 
78  void ResetSDigits() { if(fSDigitsPerPlane) for(int iPlane=0; iPlane<AliMFTConstants::kNDisks; iPlane++) ((TClonesArray*) fSDigitsPerPlane ->At(iPlane))->Clear(); } // reset sdigits list
79  void ResetDigits() { if(fDigitsPerPlane) for(int iPlane=0; iPlane<AliMFTConstants::kNDisks; iPlane++) ((TClonesArray*) fDigitsPerPlane ->At(iPlane))->Clear(); } // reset digits list
80  void ResetRecPoints() { if(fRecPointsPerPlane) for(int iPlane=0; iPlane<AliMFTConstants::kNDisks; iPlane++) ((TClonesArray*) fRecPointsPerPlane->At(iPlane))->Clear(); } // reset recPoints list
81 
82  AliDigitizer* CreateDigitizer(AliDigitizationInput *digInp) const { return new AliMFTDigitizer(digInp); }
83 
85 
87 
88  // Geometry/segmentation creation part
89  void AddAlignableVolumes() const { /* not needed */ return; }
90  void SetGeometry();
91 
92  Int_t GetNPlanes() const { return fNPlanes; }
93 
94  void SetChargeDispersion(Double_t chargeDispersion) { fChargeDispersion = chargeDispersion; }
95  Double_t GetChargeDispersion() { return fChargeDispersion; }
96  void SetNStepForChargeDispersion(Int_t nStepForChargeDispersion) { fNStepForChargeDispersion = nStepForChargeDispersion; }
99 
100  void SetDensitySupportOverSi(Double_t density) { if (density>1e-6) fDensitySupportOverSi=density; else fDensitySupportOverSi=1e-6; }
101 
102  //--------- for underlying and pile-up events --------------------
103 
104  void SetFileNameForUnderlyingEvent(TString fileName) { if (fileName.EndsWith("MFT.RecPoints.root")) fFileNameForUnderyingEvent += fileName; }
105  void SetFileNameForPileUpEvents(TString fileName) { if (fileName.EndsWith("MFT.RecPoints.root")) fFileNameForPileUpEvents += fileName; }
106 
107  void SetUnderlyingEventID(Short_t eventID) { fUnderlyingEventID = eventID; }
108  void SetPileUpEventID(Short_t i, Short_t eventID) { if (i>=0 && i<AliMFTConstants::fNMaxPileUpEvents) fPileUpEventsIDs[i] = eventID; }
109 
113  Short_t GetPileUpEventID(Short_t i) { if (i>=0 && i<AliMFTConstants::fNMaxPileUpEvents) return fPileUpEventsIDs[i]; else return -1; }
114 
115 protected:
116 
117  static const Int_t fNMaxPlanes = AliMFTConstants::fNMaxPlanes; // max number of MFT planes
118 
119  Int_t fVersion;
120 
121  Int_t fNPlanes; // # of MFT planes
122 
123  TObjArray *fSDigitsPerPlane; // ![fNPlanes] list of sdigits [per plane]
124  TObjArray *fDigitsPerPlane; // ![fNPlanes] list of digits [per plane]
125  TObjArray *fRecPointsPerPlane; // ![fNPlanes] list of recPoints [per plane]
126  TClonesArray *fSideDigits; // ! list of digits fired by the charge dispersion coming from the main hit
127 
129 
130  TString fNameGeomFile;
131 
135 
137 
140 
141 private:
142 
143  AliMFT (const AliMFT& mft); // dummy copy constructor
144  AliMFT &operator=(const AliMFT& mft); // dummy assignment operator
145 
146  ClassDef(AliMFT,2)
147 
148 };
149 
150 //====================================================================================================================================================
151 
152 #endif
153 
static const Int_t fNMaxPlanes
Definition: AliMFT.h:117
Int_t fVersion
Definition: AliMFT.h:119
Double_t fDensitySupportOverSi
Definition: AliMFT.h:136
Double_t fSingleStepForChargeDispersion
Definition: AliMFT.h:133
void CreateMaterials()
Definition: AliMFT.cxx:158
TObjArray * GetRecPointsList() const
Definition: AliMFT.h:75
TObjArray * GetSDigitsList() const
Definition: AliMFT.h:69
TString fFileNameForPileUpEvents
Definition: AliMFT.h:138
Int_t GetNPlanes() const
Definition: AliMFT.h:92
void SetUnderlyingEventID(Short_t eventID)
Definition: AliMFT.h:107
Int_t GetNStepForChargeDispersion()
Definition: AliMFT.h:97
#define TObjArray
Short_t fUnderlyingEventID
Definition: AliMFT.h:139
AliMFT & operator=(const AliMFT &mft)
Definition: AliMFT.h:41
void SetTreeAddress()
Definition: AliMFT.cxx:650
const Char_t * GetFileNameForUnderlyingEvent()
Definition: AliMFT.h:110
void AddAlignableVolumes()
Definition: AliMFT.cxx:361
void SetNStepForChargeDispersion(Int_t nStepForChargeDispersion)
Definition: AliMFT.h:96
TObjArray * GetDigitsList() const
Definition: AliMFT.h:72
Short_t GetUnderlyingEventID()
Definition: AliMFT.h:112
void StepManager()
Definition: AliMFT.cxx:378
void ResetSDigits()
Definition: AliMFT.h:78
static const Int_t fNMaxPlanes
AliMFTSegmentation * GetSegmentation() const
Definition: AliMFT.h:84
void Hits2SDigitsLocal(TClonesArray *hits, const TObjArray *pSDig, Int_t track)
Definition: AliMFT.cxx:507
AliTPCfastTrack * track
TClonesArray * GetSDigitsList(Int_t plane) const
Definition: AliMFT.h:70
Double_t fChargeDispersion
Definition: AliMFT.h:132
void SetPileUpEventID(Short_t i, Short_t eventID)
Definition: AliMFT.h:108
TString fNameGeomFile
Definition: AliMFT.h:130
void SetFileNameForUnderlyingEvent(TString fileName)
Definition: AliMFT.h:104
Short_t fPileUpEventsIDs[AliMFTConstants::fNMaxPileUpEvents]
Definition: AliMFT.h:139
void CreateDigits()
Definition: AliMFT.cxx:735
EMedia
Definition: AliMFT.h:86
TClonesArray * GetDigitsList(Int_t plane) const
Definition: AliMFT.h:73
AliMFTSegmentation * fSegmentation
Definition: AliMFT.h:128
Int_t fNStepForChargeDispersion
Definition: AliMFT.h:134
void CreateHits()
Definition: AliMFT.cxx:706
void CreateSDigits()
Definition: AliMFT.cxx:719
void AddAlignableVolumes() const
Definition: AliMFT.h:89
TClonesArray * fSideDigits
Definition: AliMFT.h:126
TObjArray * fDigitsPerPlane
Definition: AliMFT.h:124
AliDigitizer * CreateDigitizer(AliDigitizationInput *digInp) const
Definition: AliMFT.h:82
Int_t fNPlanes
Definition: AliMFT.h:121
TClonesArray * GetRecPointsList(Int_t plane) const
Definition: AliMFT.h:76
void ResetDigits()
Definition: AliMFT.h:79
void CreateRecPoints()
Definition: AliMFT.cxx:749
void SetFileNameForPileUpEvents(TString fileName)
Definition: AliMFT.h:105
TString fFileNameForUnderyingEvent
Definition: AliMFT.h:138
Class for the virtual segmentation of the ALICE Muon Forward Tracker.
Short_t fNPileUpEvents
Definition: AliMFT.h:139
static const Int_t fNMaxPileUpEvents
TObjArray * fSDigitsPerPlane
Definition: AliMFT.h:123
void Hits2SDigits()
Definition: AliMFT.cxx:462
void SetChargeDispersion(Double_t chargeDispersion)
Definition: AliMFT.h:94
void SetGeometry()
Definition: AliMFT.cxx:692
const Char_t * GetFileNameForPileUpEvents()
Definition: AliMFT.h:111
Double_t GetChargeDispersion()
Definition: AliMFT.h:95
static const Int_t kNDisks
Number of Disk.
virtual ~AliMFT()
Definition: AliMFT.cxx:148
void ResetRecPoints()
Definition: AliMFT.h:80
void MakeBranch(Option_t *option="")
Definition: AliMFT.cxx:612
void SetDensitySupportOverSi(Double_t density)
Definition: AliMFT.h:100
Int_t IsVersion() const
Definition: AliMFT.h:51
Short_t GetPileUpEventID(Short_t i)
Definition: AliMFT.h:113
void CreateGeometry()
Definition: AliMFT.cxx:345
Double_t GetSingleStepForChargeDispersion()
Definition: AliMFT.h:98
TObjArray * fRecPointsPerPlane
Definition: AliMFT.h:125