]> git.uio.no Git - u/mrichter/AliRoot.git/blobdiff - MUON/AliMUONDigitMaker.h
Setting the reco-params for the QADataMakerRec objects. At least we managed to remove...
[u/mrichter/AliRoot.git] / MUON / AliMUONDigitMaker.h
index 03e369af85d91817e0fb7b375dac6b735b982af7..ee40d0feba61505a56557d98befa118b8dad78d7 100644 (file)
 //  Author: Ch, Finck
 
 #include <TObject.h>
-#include "TStopwatch.h"
 
 class TArrayS;
 
 class AliRawReader;
 class AliMUONLocalStruct;
 
-class AliMUONRawStreamTracker;
-class AliMUONRawStreamTrigger;
+class AliMUONVRawStreamTracker;
+class AliMUONVRawStreamTrigger;
 
 class AliMUONVDigitStore;
 class AliMUONVTriggerStore;
 
+class AliMUONLogger;
+
 class AliMUONDigitMaker : public TObject 
 {
  public:
-  AliMUONDigitMaker(); // Constructor
+  AliMUONDigitMaker(
+         Bool_t enableErrorLogger = kTRUE,
+         Bool_t useFastTrackerDecoder = kTRUE, Bool_t useFastTriggerDecoder = kTRUE
+     ); // Constructor
   virtual ~AliMUONDigitMaker(void); // Destructor
     
+  /// Code to indicate readout errors
+  enum ErrorCode
+  {
+    kOK=0,             ///< everything is OK 
+    kTrackerBAD=1<<1,  ///< tracker part had readout errors 
+    kTriggerBAD=1<<2   ///< trigger part had readout errors 
+  };
+  
   // write raw data
   Int_t  Raw2Digits(AliRawReader* rawReader, 
                     AliMUONVDigitStore* digitContainer=0,
@@ -38,6 +50,7 @@ class AliMUONDigitMaker : public TObject
 
   Int_t  ReadTrackerDDL(AliRawReader* rawReader);
   Int_t  ReadTriggerDDL(AliRawReader* rawReader);
+  Int_t  ReadTriggerDDLFast(AliRawReader* rawReader);
   
   Int_t TriggerDigits(Int_t nBoard, TArrayS* xyPattern, 
                       AliMUONVDigitStore& digitStore) const;
@@ -48,6 +61,13 @@ class AliMUONDigitMaker : public TObject
         /// Set flag whether or not we should generate digits for the trigger
   void  SetMakeTriggerDigits(Bool_t flag = kFALSE) { fMakeTriggerDigits = flag; }
 
+  Bool_t UsingFastTrackerDecoder() const;
+  Bool_t UsingFastTriggerDecoder() const;
+  void  SetFastTrackerDecoder(Bool_t useFastDecoder);
+  void  SetFastTriggerDecoder(Bool_t useFastDecoder);
+
+  void Print(Option_t* opt="") const;
+
 private:
     
   /// Not implemented
@@ -56,21 +76,21 @@ private:
   AliMUONDigitMaker& operator=(const AliMUONDigitMaker& rhs); // assignment operator
 
 private:
+  void CreateRawStreamTracker(Bool_t useFastDecoder);
+  void CreateRawStreamTrigger(Bool_t useFastDecoder);
 
-  Bool_t           fScalerEvent;       //!< flag to generates scaler event
+  Bool_t fScalerEvent;       //!< flag to generates scaler event
   Bool_t fMakeTriggerDigits; //!< whether or not we should generate digits for the trigger
   
-  AliMUONRawStreamTracker* fRawStreamTracker;  //!< pointer of raw stream for tracker
-  AliMUONRawStreamTrigger* fRawStreamTrigger;  //!< pointer of raw stream for trigger
-
-  TStopwatch fTrackerTimer;                    //!< time watcher for tracker part
-  TStopwatch fTriggerTimer;                    //!< time watcher for trigger part
-  TStopwatch fMappingTimer;                    //!< time watcher for mapping-tracker part
+  AliMUONVRawStreamTracker* fRawStreamTracker; //!< pointer of raw stream for tracker
+  AliMUONVRawStreamTrigger* fRawStreamTrigger;  //!< pointer of raw stream for trigger
 
   AliMUONVDigitStore* fDigitStore; //!< not owner
   AliMUONVTriggerStore* fTriggerStore; //!< not owner
+
+  AliMUONLogger* fLogger; //!< to log messages
   
-  ClassDef(AliMUONDigitMaker,5) // MUON digit maker from rawdata
+  ClassDef(AliMUONDigitMaker,6) // MUON digit maker from rawdata
 };
        
 #endif