]> git.uio.no Git - u/mrichter/AliRoot.git/blobdiff - RALICE/AliCalorimeter.h
Updating T00 configuration for the test and P2.
[u/mrichter/AliRoot.git] / RALICE / AliCalorimeter.h
index 2dcefe2f7a10bcff71b16c40404125e7a2838f92..b69aceeae80fb9b54c40e9fce3996f0ca541972d 100644 (file)
@@ -27,8 +27,8 @@ class AliCalorimeter : public AliDevice
   virtual ~AliCalorimeter();                             // Destructor
   AliCalorimeter(const AliCalorimeter& c);               // Copy constructor
   virtual TObject* Clone(const char* name="") const;     // Make a deep copy and provide pointer of the copy
-  Int_t GetNrows() const;                                // Return number of rows of the matrix
-  Int_t GetNcolumns() const;                             // Return number of columns of the matrix
+  Int_t GetNrows();                                      // Return number of rows of the matrix
+  Int_t GetNcolumns();                                   // Return number of columns of the matrix
   using AliDevice::SetSignal;
   void SetSignal(Int_t row,Int_t col,Float_t s);         // Set signal for a certain module
   using AliDevice::AddSignal;
@@ -36,45 +36,46 @@ class AliCalorimeter : public AliDevice
   void AddSignal(AliCalmodule* m);                       // Add module signal to current calorimeter
   void Reset(Int_t row,Int_t col);                       // Reset signal for a certain module
   virtual void Reset(Int_t mode=0);                      // Reset the complete calorimeter
-  virtual Float_t GetSignal(Int_t row,Int_t col=0) const { return GetSignal(row,col,0); }
-  Float_t GetSignal(Int_t row,Int_t col,Int_t mode) const; // Provide signal of a certain module
+  using AliDevice::GetSignal;
+  virtual Float_t GetSignal(Int_t row,Int_t col=0) { return GetSignal(row,col,0); }
+  Float_t GetSignal(Int_t row,Int_t col,Int_t mode);     // Provide signal of a certain module
   Int_t GetNsignals() const;                             // Return number of modules with a signal
   void Group(Int_t n=1,Int_t mode=1);                    // Group modules into clusters (n rings)
   Int_t GetNclusters() const;                            // Return number of clusters
-  Float_t GetClusteredSignal(Int_t row,Int_t col) const; // Provide module signal after clustering
+  Float_t GetClusteredSignal(Int_t row,Int_t col);       // Provide module signal after clustering
   AliCalcluster* GetCluster(Int_t j) const;              // Access to cluster number j
   AliCalmodule* GetModule(Int_t j) const;                // Access to 'fired' module number j
-  AliCalmodule* GetModule(Int_t row,Int_t col) const;    // Access to module at (row,col)
+  AliCalmodule* GetModule(Int_t row,Int_t col);          // Access to module at (row,col)
   using AliDevice::SetEdgeOn;
   void SetEdgeOn(Int_t row,Int_t col);                   // Indicate module as 'edge module'
   using AliDevice::SetEdgeOff;
   void SetEdgeOff(Int_t row,Int_t col);                  // Indicate module as 'non-edge module'
   using AliDevice::GetEdgeValue;
-  Int_t GetEdgeValue(Int_t row,Int_t col) const;         // Provide the edge flag of a module
+  Int_t GetEdgeValue(Int_t row,Int_t col);               // Provide the edge flag of a module
   using AliDevice::SetDead;
   void SetDead(Int_t row,Int_t col);                     // Indicate module as 'dead module'
   using AliDevice::SetAlive;
   void SetAlive(Int_t row,Int_t col);                    // Indicate module as 'active module'
   using AliDevice::GetDeadValue;
-  Int_t GetDeadValue(Int_t row,Int_t col) const;         // Provide the dead flag of a module
+  Int_t GetDeadValue(Int_t row,Int_t col);               // Provide the dead flag of a module
   using AliDevice::SetGain;
   void SetGain(Int_t row,Int_t col,Float_t g);           // Set the gain value for a module
   using AliDevice::SetOffset;
   void SetOffset(Int_t row,Int_t col,Float_t o);         // Set the offset value for a module
   using AliDevice::GetGain;
-  Float_t GetGain(Int_t row,Int_t col) const;            // Provide the gain value of a module
+  Float_t GetGain(Int_t row,Int_t col);                  // Provide the gain value of a module
   using AliDevice::GetGainFlag;
-  Int_t GetGainFlag(Int_t row,Int_t col) const;          // Provide the gain flag value of a module
+  Int_t GetGainFlag(Int_t row,Int_t col);                // Provide the gain flag value of a module
   using AliDevice::GetOffset;
-  Float_t GetOffset(Int_t row,Int_t col) const;          // Provide the offset value of a module
+  Float_t GetOffset(Int_t row,Int_t col);                // Provide the offset value of a module
   using AliDevice::GetOffsetFlag;
-  Int_t GetOffsetFlag(Int_t row,Int_t col) const;        // Provide the offset flag value of a module
+  Int_t GetOffsetFlag(Int_t row,Int_t col);              // Provide the offset flag value of a module
   using AliDevice::SetPosition;
   void SetPosition(Int_t row,Int_t col,Float_t* r,TString f); // Set module position
   void SetPosition(Int_t row,Int_t col,Ali3Vector& r);   // Set module position
   using AliDevice::GetPosition;
-  void GetPosition(Int_t row,Int_t col,Float_t* r,TString f) const; // Return module position
-  AliPosition* GetPosition(Int_t row,Int_t col) const;   // Access to module position
+  void GetPosition(Int_t row,Int_t col,Float_t* r,TString f); // Return module position
+  AliPosition* GetPosition(Int_t row,Int_t col);         // Access to module position
   TH2F* DrawModules(Float_t thresh=0.,Int_t mode=0);     // Lego plot of module (corr.) signals above threshold
   TH2F* DrawClusters(Float_t thresh=0.);                 // Lego plot of cluster signals above threshold
   void AddVetoSignal(AliSignal& s);                      // Associate (extrapolated) signal
@@ -87,19 +88,20 @@ class AliCalorimeter : public AliDevice
  protected:
   Int_t fNrows;                              // The number of rows
   Int_t fNcolumns;                           // The number of columns
-  AliObjMatrix* fMatrix;                     // The matrix of module pointers
+  AliObjMatrix* fMatrix;                     //! Matrix lookup table of module pointers
   Int_t fSwap;                               // The swapmode for the module and position matrices
-  void SortM(AliCalmodule** a,Int_t& n);     // Order the modules with decreasing signal (matrix search)
-  void SortA(AliCalmodule** a,Int_t& n);     // Order the modules with decreasing signal (fired array search)
+  void SortM();                              // Order the modules with decreasing signal (matrix search)
+  void SortA();                              // Order the modules with decreasing signal (fired array search)
   TObjArray* fClusters;                      // The array of clusters
   void AddRing(Int_t row,Int_t col,Int_t n); // add signals of n rings around cluster center
   void Ungroup();                            // Restore module matrix as before clustering
   TH2F* fHmodules;                           //! The module 2-D histogram for event display
   TH2F* fHclusters;                          //! The cluster 2-D histogram for event display
   TObjArray* fVetos;                         // The array of associated (extrapolated) veto signals
-  TObjArray* fAttributes;                    //! Matrix with module attributes (e.g. gain, offset etc...)
-  AliObjMatrix* fPositions;                  //! The matrix of module position pointers
+  TObjArray* fAttributes;                    //! Matrix dbase with module attributes (e.g. gain, offset etc...)
+  AliObjMatrix* fPositions;                  //! Matrix dbase of module position pointers
+  void LoadMatrix();                         // Loading of matrix lookup table from the linear hit array
  
- ClassDef(AliCalorimeter,9) // Description of a modular calorimeter system.
+ ClassDef(AliCalorimeter,11) // Description of a modular calorimeter system.
 };
 #endif