1 #ifndef ALIMUONTRACKERCALIBRATEDDATAMAKER_H
2 #define ALIMUONTRACKERCALIBRATEDDATAMAKER_H
4 /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
5 * See cxx source for full Copyright notice */
10 /// \class AliMUONTrackerCalibratedDataMaker
11 /// \brief Creator of calibrated AliMUONVTrackerData from AliRawReader
13 // Author Laurent Aphecetche, Subatech
15 #ifndef ALIMUONVTRACKERDATAMAKER_H
16 # include "AliMUONVTrackerDataMaker.h"
23 class AliMUONCalibrationData;
24 class AliMUONDigitCalibrator;
25 class AliMUONDigitMaker;
26 class AliMUONVTrackerData;
28 class AliMUONVDigitStore;
30 class AliMUONTrackerCalibratedDataMaker : public AliMUONVTrackerDataMaker
33 AliMUONTrackerCalibratedDataMaker(AliRawReader* reader = 0x0,
34 const char* cdbpath=0x0,
35 const char* calibMode=0x0,
36 Bool_t histogram=kFALSE,
38 Double_t xmax=4096.0);
39 virtual ~AliMUONTrackerCalibratedDataMaker();
41 /// Whether we have a valid raw reader
42 Bool_t IsValid() const { return fRawReader != 0x0; }
45 AliMUONVTrackerData* Data() const { return fAccumulatedData; }
48 virtual Bool_t IsRunnable() const { return kTRUE; }
50 /// Whether we are running or not
51 virtual Bool_t IsRunning() const { return fIsRunning; }
53 /// Set the running status
54 virtual void SetRunning(Bool_t flag) { fIsRunning = flag; }
58 void Print(Option_t* opt="") const;
62 /// Get our source URI
63 virtual TString Source() const { return fSource.Data(); }
65 /// Set our source URI
66 void SetSource(const char* source) { fSource = source; }
68 /// Get our digit store
69 AliMUONVDigitStore* DigitStore() const { return fDigitStore; }
71 /// Number of events seen
72 Int_t NumberOfEvents() const { return fNumberOfEvents; }
74 virtual Long64_t Merge(TCollection* list);
78 AliMUONTrackerCalibratedDataMaker(const AliMUONTrackerCalibratedDataMaker& rhs);
80 AliMUONTrackerCalibratedDataMaker& operator=(const AliMUONTrackerCalibratedDataMaker& rhs);
82 Bool_t ConvertDigits();
85 AliRawReader* fRawReader; //!< reader of the data (owner)
86 AliMUONVTrackerData* fAccumulatedData; ///< data (owner)
87 AliMUONVStore* fOneEventData; ///< data for one event (owner)
88 TString fSource; ///< where the data comes from
89 Bool_t fIsRunning; ///< whether we are running or are paused
90 AliMUONDigitMaker* fDigitMaker; ///< digit maker
91 AliMUONDigitCalibrator* fDigitCalibrator; //!< digit calibrator (if calibrating data)
92 AliMUONCalibrationData* fCalibrationData; ///< calibration data (if calibrating data)
93 AliMUONVDigitStore* fDigitStore; ///< digit store (if calibrating data)
94 TString fCDBPath; ///< OCDB path (if calibrating data)
95 Int_t fNumberOfEvents; ///< number of events seen
96 static Int_t fgkCounter; ///< to count the number of instances
98 ClassDef(AliMUONTrackerCalibratedDataMaker,2) // Producer of calibrated AliMUONVTrackerData from raw data