]> git.uio.no Git - u/mrichter/AliRoot.git/blob - ITS/AliITSIOTrack.h
Conversion code moved to AliG3toRoot
[u/mrichter/AliRoot.git] / ITS / AliITSIOTrack.h
1 #ifndef ALIITSIOTRACK_H
2 #define ALIITSIOTRACK_H 
3
4 ////////////////////////////////////////////////////
5 //  Reconstructed space point class for set:ITS   //
6 ////////////////////////////////////////////////////
7
8 #include <TObject.h>
9
10 class TMatrix;
11 class AliITSIOTrack : public TObject {
12
13
14  public:
15
16   AliITSIOTrack();                        // constructor
17   virtual ~AliITSIOTrack() {};            // distructor
18   Int_t   GetLabel() const {return fLab;} // get track label
19   Int_t   GetIdPoint(Int_t i) const {return fIdPoints[i];}   // get the identification number for the point
20   Int_t   GetIdModule(Int_t i) const {return fIdModules[i];} // get the module number for the point
21
22  void GetCovMatrix(Double_t &C00, Double_t &C10, Double_t &C11, Double_t &C20,
23                    Double_t &C21, Double_t &C22, Double_t &C30, Double_t &C31,
24                    Double_t &C32, Double_t &C33, Double_t &C40, Double_t &C41,
25                    Double_t &C42, Double_t &C43, Double_t &C44) const;
26   Double_t GetStatePhi() const {return fStateVPhi;}  // gets the Phi angle of the state vector
27   Double_t GetStateZ() const {return fStateVZ;}      // gets the Z cohordinate of the state vector
28   Double_t GetStateD() const {return fStateVD;}      // gets the radial impact parameter of the state vector
29   Double_t GetStateC() const {return fStateVC;}      // gets the curvature C of the state vector
30   Double_t GetStateTgl() const {return fStateVTgl;}  // gets the dip angle tangent of the state vector
31   Double_t GetRadius() const {return fRadius;}       // gets the radius corresponding to the state vector
32   Int_t     GetCharge() const {return fCharge;}      // gets the particle charge
33   Float_t GetX() const {return fX;}     // gets the x cohordinate of the found vertex
34   Float_t GetZ() const {return fZ;}     // gets the z cohordinate of the found vertex
35   Float_t GetY() const {return fY;}     // gets the y cohordinate of the found vertex
36   Float_t GetPx() const {return fPx;}   // gets the x momentum component at the found vertex 
37   Float_t GetPy() const {return fPy;}   // gets the y momentum component at the found vertex 
38   Float_t GetPz()const {return fPz;}    // gets the z momentum component at the found vertex 
39  
40   void SetCovMatrix(Double_t C00, Double_t C10, Double_t C11, Double_t C20, Double_t C21, 
41        Double_t C22, Double_t C30, Double_t C31, Double_t C32, Double_t C33, Double_t C40, 
42        Double_t C41, Double_t C42, Double_t C43, Double_t C44);
43   
44   void SetLabel(Int_t lab) {fLab=lab;}  // sets the track label
45   void SetIdPoint(Int_t i,Int_t pnt) {fIdPoints[i]=pnt;}   // set the identification number for the point
46   void SetIdModule(Int_t i,Int_t mod) {fIdModules[i]=mod;} // set the module number for the point
47    
48   void SetStatePhi(Double_t phi) {fStateVPhi=phi;}   // sets the Phi angle of the state vector 
49   void SetStateZ(Double_t z) {fStateVZ=z;}           // sets the Z cohordinate of the state vector
50   void SetStateD(Double_t d) {fStateVD=d;}           // sets the radial impact parameter of the state vector 
51   void SetStateTgl(Double_t tgl) {fStateVTgl=tgl;}   // sets the dip angle tangent of the state vector
52   void SetStateC(Double_t c) {fStateVC=c;}           // sets the curvature C of the state vector
53   void SetRadius(Double_t r) {fRadius= r;}           // sets the radius corresponding to the state vector
54   void SetCharge(Int_t charge) {fCharge=charge;}     // sets the particle charge
55
56   void SetX(Float_t x){fX=x;}        // sets the x cohordinate of the found vertex
57   void SetZ(Float_t z){fZ=z;}        // sets the z cohordinate of the found vertex
58   void SetY(Float_t y){fY=y;}        // sets the y cohordinate of the found vertex
59   void SetPx(Float_t px) {fPx=px;}   // sets the x momentum component at the found vertex 
60   void SetPy(Float_t py) {fPy=py;}   // sets the y momentum component at the found vertex
61   void SetPz(Float_t pz) {fPz=pz;}   // sets the z momentum component at the found vertex
62
63  private:
64     
65   Int_t     fLab;       // label of reconstructed track
66   Float_t   fX ;        // x cohordinate of the found vertex
67   Float_t   fY ;        // y cohordinate of the found vertex
68   Float_t   fZ ;        // z cohordinate of the found vertex
69   Float_t   fPx;        // x component of track momentum at the found vertex
70   Float_t   fPy;        // y component of track momentum at the found vertex
71   Float_t   fPz;        // z component of track momentum at the found vertex
72    
73   //
74   Int_t     fIdPoints[6];   // points assigned to the track (entry # in fRecPoints is given by module #)
75   Int_t     fIdModules[6];  // module # corresponding to each point belonging to the track
76
77   Double_t  fStateVPhi;          //  state vector component Phi
78   Double_t  fStateVZ;            //  state vector component Z
79   Double_t  fStateVD;            //  state vector component D
80   Double_t  fStateVTgl;          //  state vector component Tgl
81   Double_t  fStateVC;            //  state vector component C
82          
83   Double_t  fRadius;             //  distance of the point from the origin
84   Int_t     fCharge;             //  particle charge  
85
86 //  Covariance matrix
87   Double_t  fC00;                                   // first row elements of the covariance matrix
88   Double_t  fC10, fC11;                             // second row elements of the covariance matrix
89   Double_t  fC20, fC21, fC22;                       // third row elements of the covariance matrix 
90   Double_t  fC30, fC31, fC32, fC33;                 // fourth row elements of the covariance matrix
91   Double_t  fC40, fC41, fC42, fC43, fC44;           // fiveth row elements of the covariance matrix 
92          
93   ClassDef(AliITSIOTrack,1)  // AliITSIOTrack class
94 };
95
96 #endif