]>
Commit | Line | Data |
---|---|---|
0ee00e25 | 1 | #ifndef ALITRDTRIGGER_H |
2 | #define ALITRDTRIGGER_H | |
3 | /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. * | |
4 | * See cxx source for full Copyright notice */ | |
5 | ||
6d50f529 | 6 | /* $Id$ */ |
7 | ||
0ee00e25 | 8 | /////////////////////////////////////////////////////////////////////////////// |
9 | // // | |
10 | // TRD trigger class // | |
11 | // // | |
12 | /////////////////////////////////////////////////////////////////////////////// | |
13 | ||
e3b2b5e5 | 14 | #include <TNamed.h> |
0ee00e25 | 15 | |
e3b2b5e5 | 16 | class TTree; |
6d50f529 | 17 | class TClonesArray; |
18 | class TObjArray; | |
0ee00e25 | 19 | |
20 | class AliRunLoader; | |
21 | class AliRawReader; | |
22 | ||
23 | class AliTRDmcmTracklet; | |
6d50f529 | 24 | class AliTRDgtuTrack; |
0ee00e25 | 25 | class AliTRDmcm; |
26 | class AliTRDmodule; | |
6d50f529 | 27 | class AliTRDdigitsManager; |
28 | class AliTRDdataArrayI; | |
29 | class AliTRDgeometry; | |
0ee00e25 | 30 | |
31 | class AliTRDtrigger : public TNamed { | |
32 | ||
33 | public: | |
34 | ||
e3b2b5e5 | 35 | enum { kNMCM = 16, kMaxTrackletsPerMCM = 4, kMcmCol = 21 }; |
0ee00e25 | 36 | |
37 | AliTRDtrigger(); | |
38 | AliTRDtrigger(const Text_t* name, const Text_t* title); | |
39 | AliTRDtrigger(const AliTRDtrigger &p); | |
6d50f529 | 40 | virtual ~AliTRDtrigger(); |
41 | AliTRDtrigger &operator=(const AliTRDtrigger &p); | |
42 | ||
43 | virtual void Copy(TObject &p) const; | |
44 | ||
45 | void Init(); | |
46 | ||
47 | Bool_t Open(const Char_t *name, Int_t nEvent = 0); | |
48 | Bool_t ReadDigits(); | |
25ca55ce | 49 | Bool_t ReadDigits(AliRawReader *rawReader); |
50 | Bool_t ReadDigits(TTree *digitsTree); | |
6d50f529 | 51 | Bool_t MakeTracklets(Bool_t makeTracks = kFALSE); |
52 | void MakeTracks(Int_t det); | |
53 | Bool_t WriteTracklets(Int_t det); | |
54 | Bool_t ReadTracklets(AliRunLoader *rl); | |
55 | ||
56 | void AddTracklet(Int_t det, Int_t row, Int_t seed, Int_t n); | |
57 | void AddTrack(const AliTRDgtuTrack *t, Int_t det); | |
58 | Bool_t TestTracklet(Int_t det, Int_t row, Int_t seed, Int_t n); | |
59 | TObjArray *Tracklets(); | |
60 | void ResetTracklets(); | |
61 | ||
62 | Int_t GetNumberOfTracks() const; | |
63 | Int_t GetNPrimary() const { return fNPrimary; }; | |
6d50f529 | 64 | AliTRDgtuTrack *GetTrack(Int_t i) const; |
65 | ||
66 | void SetRunLoader(AliRunLoader *rl) { fRunLoader = rl; }; | |
67 | void SetMCMcoordinates(Int_t imcm); | |
0ee00e25 | 68 | |
69 | protected: | |
70 | ||
6d50f529 | 71 | Float_t fField; //! Magnetic field |
72 | AliTRDgeometry *fGeo; //! TRD geometry | |
3fcb9908 | 73 | |
6d50f529 | 74 | AliRunLoader *fRunLoader; //! Run Loader |
75 | AliTRDdigitsManager *fDigitsManager; //! TRD digits manager | |
76 | TTree *fTrackletTree; //! Tree with tracklets | |
77 | TObjArray *fTracklets; //! Array of tracklets | |
0ee00e25 | 78 | |
6d50f529 | 79 | Int_t fNROB; //! Number of ROBs in the current chamber |
80 | AliTRDmcm *fMCM; //! Current MCM | |
81 | AliTRDmcmTracklet *fTrk; //! Current tracklet | |
82 | AliTRDmcmTracklet *fTrkTest; //! Test tracklet | |
83 | AliTRDmodule *fModule; //! Current module | |
84 | AliTRDgtuTrack *fGTUtrk; //! Current GTU track | |
0ee00e25 | 85 | |
6d50f529 | 86 | Int_t fNtracklets; //! Tracklets counter |
0ee00e25 | 87 | |
6d50f529 | 88 | AliTRDdataArrayI *fDigits; //! Array with digits |
89 | AliTRDdataArrayI *fTrack0; //! Track dictionary 0 | |
90 | AliTRDdataArrayI *fTrack1; //! Track dictionary 1 | |
91 | AliTRDdataArrayI *fTrack2; //! Track dictionary 2 | |
0ee00e25 | 92 | |
6d50f529 | 93 | Int_t fNPrimary; //! Number of primary tracks |
0ee00e25 | 94 | |
6d50f529 | 95 | TClonesArray *fTracks; //! Array of GTU tracks |
0ee00e25 | 96 | |
f162af62 | 97 | ClassDef(AliTRDtrigger,4) // TRD trigger class |
0ee00e25 | 98 | |
99 | }; | |
100 | ||
101 | #endif |