]> git.uio.no Git - u/mrichter/AliRoot.git/blobdiff - MUON/AliMUONTriggerEfficiencyCells.h
Extacting the OCDB in a separate module. The detectors have write permission in the...
[u/mrichter/AliRoot.git] / MUON / AliMUONTriggerEfficiencyCells.h
index 3f07ac8c048271ca89e9b27157c0ef9eb0b56859..d5c929e4323e397629dfb16bac9744bdefb67ed0 100755 (executable)
@@ -1,52 +1,87 @@
 /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
  * See cxx source for full Copyright notice                               */
 
-/// \ingroup rec
+// $Id$
+
+/// \ingroup calib
 /// \class AliMUONTriggerEfficiencyCells
 /// \brief Store and give access to the trigger chamber efficiency.
 ///
-/// \author: Diego Stocco; INFN Torino
+//  Author: Diego Stocco; INFN Torino
 
 #ifndef ALIMUONTRIGGEREFFICIENCYCELLS_H
 #define ALIMUONTRIGGEREFFICIENCYCELLS_H
 
 #include "TObject.h"
 #include "TArrayI.h"
-#include "TVector2.h"
-#include "TString.h"
+#include "TH1F.h"
+#include "TList.h"
 
 class AliMUONTriggerEfficiencyCells : public TObject
 {
 public:
   AliMUONTriggerEfficiencyCells();
-  AliMUONTriggerEfficiencyCells(const char* filename);
+  AliMUONTriggerEfficiencyCells(const Char_t* filename);
+  AliMUONTriggerEfficiencyCells(TList *countHistoList, TList *noCountHistoList);
+
+  AliMUONTriggerEfficiencyCells(const AliMUONTriggerEfficiencyCells& other); // copy constructor
+  AliMUONTriggerEfficiencyCells& operator=(const AliMUONTriggerEfficiencyCells& other); // assignment operator
 
   virtual ~AliMUONTriggerEfficiencyCells();
 
-  Float_t GetCellEfficiency(Int_t detElemId, Int_t cathode, Float_t x, Float_t y);
-  void GetCellEfficiency(Int_t detElemId, Float_t x, Float_t y, Float_t &eff1, Float_t &eff2);
+  void GetCellEfficiency(Int_t detElemId, Int_t localBoard, Float_t &eff1, Float_t &eff2) const;
     
-  Bool_t IsTriggered(Int_t detElemId, Int_t cathode, Float_t x, Float_t y);
-  void IsTriggered(Int_t detElemId, Float_t x, Float_t y, Bool_t &trig1, Bool_t &trig2);
+  void IsTriggered(Int_t detElemId, Int_t localBoard, Bool_t &trig1, Bool_t &trig2) const;
 
-  TVector2 ChangeReferenceFrame(Float_t x, Float_t y, Float_t x0, Float_t y0);
+  Bool_t SumRunEfficiency(const AliMUONTriggerEfficiencyCells &other);
 
-  void Reset();
-    
+
+  // Methods for display
+  void DisplayEfficiency(Bool_t perSlat=kFALSE,
+                        const Char_t* cdbStorage = "local://$ALICE_ROOT/OCDB",
+                        Int_t runNumber=0);
+
+  // Methods for efficiency check
+  /// Set the list of fired strips
+  void SetFiredStrips(TList *firedStrips){fFiredStrips = firedStrips;}
+  void CheckFiredStrips(const Char_t* cdbStorage = "local://$ALICE_ROOT/OCDB",
+                       Int_t runNumber=0);
+                                // Check for strips with lower counts than others:
+                                // syntomatic of possible read-out problems in boards
 protected:
-    TArrayI CellByCoord(Int_t detElemId, Float_t x, Float_t y);
-    void ReadFile(const char* filename="$ALICE_ROOT/MUON/data/efficiencyCells.dat");
+    void Reset();
+    void ReadFile(const Char_t* filename="$ALICE_ROOT/MUON/data/efficiencyCells.dat");
+    void CalculateEfficiency(Int_t trigger44, Int_t trigger34,
+                            Float_t &efficiency, Float_t &error,
+                            Bool_t failuresAsInput);
+
 
 private:
-    Int_t FindChamberIndex(Int_t detElemId);
-    Int_t FindSlatIndex(Int_t detElemId);
+    void CheckConstants() const;
+    Int_t FindChamberIndex(Int_t detElemId) const;
+    void ReadFileBoards(ifstream &file);
+    void ReadHistoBoards(const Char_t* filename="MUON.TriggerEfficiencyMap.root");
+    void InitHistos();
+    void FillHistosFromList();
+    Bool_t GetListsForCheck(const Char_t* cdbStorage, Int_t runNumber);
     
-    static const Int_t fgkNofCells=80; // number of cells
-    
-    Float_t fCellContent[4][18][2][fgkNofCells][fgkNofCells]; //[trig. chambers][RPCs][cathode][cellsX][cellsY]
-    Float_t fCellSize[4][18][2]; //the size of the cells
-    Int_t fCellNumber[4][18][2]; //id of the cells
+    static const Int_t fgkNcathodes=2; ///<Number of cathodes
+    static const Int_t fgkNchambers=4; ///<Number of chambers
+    static const Int_t fgkNplanes=8;   ///<Number of planes
+
     
-    ClassDef(AliMUONTriggerEfficiencyCells,1) // Trigger efficiency store
+    TH1F *fBoardEfficiency[fgkNplanes];///< the boards content
+    TH1F *fSlatEfficiency[fgkNplanes];///< the slats content
+
+    TList *fCountHistoList; ///<list of efficiency numerators
+    TList *fNoCountHistoList; ///<list of efficiency denominators
+    TList *fFiredStrips; ///<list of fired strips for efficiency check
+
+    TList *fDisplayHistoList; //!< list of efficiency histograms for display
+    TList *fBoardLabelList; //!< list of board labels for display
+    TList *fFiredFitHistoList; //!< list of fired strips for checks
+    TList *fFiredDisplayHistoList; //!< list of fired strips for display
+
+    ClassDef(AliMUONTriggerEfficiencyCells,6) // Trigger efficiency store
 };
 #endif