]>
Commit | Line | Data |
---|---|---|
46d29e70 | 1 | #ifndef ALITRDCLUSTER_H |
2 | #define ALITRDCLUSTER_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 | ||
5443e65e | 8 | |
9 | #include "AliCluster.h" | |
46d29e70 | 10 | |
11 | class AliTRDrecPoint; | |
12 | ||
5443e65e | 13 | class AliTRDcluster : public AliCluster { |
46d29e70 | 14 | |
15 | public: | |
16 | ||
4f1c04d3 | 17 | AliTRDcluster() : AliCluster() { fQ=0; fTimeBin=0; fDetector=0; fNPads=0; } |
a2b90f83 | 18 | AliTRDcluster(const AliTRDcluster &c); |
19 | AliTRDcluster(const AliTRDrecPoint &p); | |
a2b90f83 | 20 | |
5443e65e | 21 | virtual void AddTrackIndex(Int_t *i); |
a2b90f83 | 22 | |
a2b90f83 | 23 | |
5443e65e | 24 | Int_t IsUsed() const { return (fQ < 0) ? 1 : 0; } |
b8f166bb | 25 | void Use(Int_t = 0) { fQ = -fQ; } |
5443e65e | 26 | |
27 | Bool_t From2pad() const { return TestBit(k2pad); } | |
28 | Bool_t From3pad() const { return TestBit(k3pad); } | |
29 | Bool_t From4pad() const { return TestBit(k4pad); } | |
30 | Bool_t From5pad() const { return TestBit(k5pad); } | |
31 | Bool_t FromLarge() const { return TestBit(kLarge);} | |
32 | Bool_t Isolated() const { return (TestBit(k2pad) || TestBit(k3pad)); } | |
abaf1f1d | 33 | |
5443e65e | 34 | void SetDetector(Int_t d) { fDetector = d; } |
35 | void SetLocalTimeBin(Int_t t) { fTimeBin = t; } | |
36 | void SetQ(Float_t q) { fQ = q; } | |
37 | ||
38 | Int_t GetDetector() const { return fDetector; } | |
39 | Int_t GetLocalTimeBin() const { return fTimeBin; } | |
40 | Float_t GetQ() const { return fQ; } | |
41 | ||
4f1c04d3 | 42 | void Set2pad() { SetBit(k2pad); fNPads=2; } |
43 | void Set3pad() { SetBit(k3pad); fNPads=3; } | |
44 | void Set4pad() { SetBit(k4pad); fNPads=4; } | |
45 | void Set5pad() { SetBit(k5pad); fNPads=5; } | |
46 | void SetLarge() { SetBit(kLarge);fNPads=6; } | |
47 | Int_t GetNPads() const {return fNPads;} | |
54d12e2f | 48 | void SetCenter(Float_t center){fCenter =center;} |
49 | Float_t GetCenter() const {return fCenter;} | |
46d29e70 | 50 | protected: |
51 | ||
a2b90f83 | 52 | enum { |
db30bf0f | 53 | k2pad = 0x00000001, // 2 pad cluster |
54 | k3pad = 0x00000002, // 3 pad cluster | |
55 | k4pad = 0x00000004, // 4 pad cluster | |
56 | k5pad = 0x00000008, // 5 pad cluster | |
57 | kLarge = 0x00000016 // Large cluster | |
a2b90f83 | 58 | }; |
5443e65e | 59 | |
a2b90f83 | 60 | Int_t fDetector; // TRD detector number |
61 | Int_t fTimeBin; // Time bin number within the detector | |
a2b90f83 | 62 | Float_t fQ; // amplitude |
4f1c04d3 | 63 | Int_t fNPads; // number of pads in cluster |
54d12e2f | 64 | Float_t fCenter; // center of the cluster relative to the pad |
65 | ||
66 | ClassDef(AliTRDcluster,2) // Cluster for the TRD | |
46d29e70 | 67 | |
68 | }; | |
69 | ||
70 | #endif |