]> git.uio.no Git - u/mrichter/AliRoot.git/blobdiff - TRD/AliTRDtrackingSector.h
Merge branch 'master' of https://git.cern.ch/reps/AliRoot
[u/mrichter/AliRoot.git] / TRD / AliTRDtrackingSector.h
index 9f37e8bf3d982748972ffe92aae3f01559f2ccf7..a9887b98295bce07caa5a3bf138434dea309c154 100644 (file)
@@ -2,7 +2,7 @@
 #define ALITRDTRACKINGSECTOR_H
 
 /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
- * See cxx source for full Copyright notice                               */
+* See cxx source for full Copyright notice                               */
 
 /* $Id: AliTRDtrackingSector.h 22646 2007-11-29 18:13:40Z cblume $ */
 
 //                                                                        //
 ////////////////////////////////////////////////////////////////////////////
 
-#ifndef ROOT_Rtypes
-#include "Rtypes.h"
+#ifndef ALITRDGEOMETRY_H
+#include "AliTRDgeometry.h"
 #endif
 
+class AliTRDReconstructor;
 class AliTRDtrackingChamber;
-class AliTRDgeometry;
-
 class AliTRDtrackingSector 
 {
 
 public:
-       enum{
-               kNChambersSector   = 30
-               , kNplane          = 6
-               , kTrackingSectors = 18
-       };
-       
-       AliTRDtrackingSector();
-       AliTRDtrackingSector(AliTRDgeometry* geo, Int_t gs, Int_t tbs);
-       AliTRDtrackingSector(const AliTRDtrackingSector &/*t*/);
-       virtual ~AliTRDtrackingSector();
-       
-       AliTRDtrackingSector &operator=(const AliTRDtrackingSector &/*t*/) { return *this; }
-       
-  void     Clear(const Option_t *opt = 0x0);
-       Int_t    GetNChambers() const             { return fN; }
-       Double_t GetX(Int_t pl) const                  { return pl >=0 && pl < kNplane ? fX0[pl] : 0.; }
-       AliTRDtrackingChamber* GetChamber(Int_t i) const  { return i>=0 && i < fN ? fChamber[i] : 0x0;  }
-       AliTRDtrackingChamber* GetChamber(Int_t stack, Int_t plane, Bool_t build = kFALSE);
-       AliTRDtrackingChamber** GetStack(Int_t stack);
-       Int_t    GetSector() const {return fSector;}    
-       void     Init();
-       
-       void     SetGeometry(AliTRDgeometry *geo) {fGeom = geo;}
-        
-       // temporary ... some of this functions are obsolete
-       void Print(Option_t *opt = 0x0);
-//     void     MapTimeBinLayers();
-//     Int_t    Find(Double_t x) const; 
-//     void     InsertLayer(AliTRDchamberTimeBin *pl);
-//     Int_t    CookTimeBinIndex(Int_t plane, Int_t localTB) const;     
-       
+  AliTRDtrackingSector();
+  AliTRDtrackingSector(AliTRDgeometry* geo, Int_t gs);
+  virtual ~AliTRDtrackingSector(){;}
+    
+  void     Clear(const Option_t *opt = NULL);
+  Int_t    GetNChambers() const             { return fN; }
+  Double_t GetX(Int_t pl) const                  { return pl >=0 && pl < AliTRDgeometry::kNlayer ? fX0[pl] : 0.; }
+  AliTRDtrackingChamber* GetChamber(Int_t i) const  { return i>=0 && i < fN ? fChamber[i] : NULL;  }
+  AliTRDtrackingChamber* GetChamber(Int_t stack, Int_t plane, Bool_t build = kFALSE);
+  AliTRDtrackingChamber** GetStack(Int_t stack);
+  Int_t    GetSector() const {return fSector;} 
+
+  void     Init(const AliTRDReconstructor *rec);
+  void     Print(Option_t *opt = NULL) const;
+  
+  void     SetGeometry(AliTRDgeometry *const geo) {fGeom = geo;}
+  
+private:
+  AliTRDtrackingSector(const AliTRDtrackingSector &/*t*/);
+  AliTRDtrackingSector &operator=(const AliTRDtrackingSector &/*t*/);
+
+
 private:
-       UChar_t        fTimeBinsPerPlane; // no. of time bins
-       Char_t         fSector;           // Sector# in AliTRDgeometry
-       UChar_t        fN;                // Total number of chambers allocated
-       Char_t         fIndex[kNChambersSector]; // indexes of allocated chambers
-       Float_t        fX0[kNplane];      // average position of pad plane for each plane
-       AliTRDgeometry *fGeom;            // Geometry
-       AliTRDtrackingChamber *fChamber[kNChambersSector];// chambers   
-       AliTRDtrackingChamber *fStack[kNplane]; //! temporary holding one stack
-       ClassDef(AliTRDtrackingSector, 1) // TRD tracker container for one sector
+  Char_t         fSector;           // Sector# in AliTRDgeometry
+  UChar_t        fN;                // Total number of chambers allocated
+  Char_t         fIndex[AliTRDgeometry::kNdets]; // indexes of allocated chambers
+  Float_t        fX0[AliTRDgeometry::kNlayer];      // average position of pad plane for each plane
+  AliTRDgeometry *fGeom;            // Geometry
+  AliTRDtrackingChamber *fChamber[AliTRDgeometry::kNdets];// chambers   
+  AliTRDtrackingChamber *fStack[AliTRDgeometry::kNlayer]; //! temporary holding one stack
+
+  ClassDef(AliTRDtrackingSector, 1) // TRD tracker container for one sector
 };