/* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. * * See cxx source for full Copyright notice */ // $Id$ /// \ingroup base /// \class AliMUONCalibrationData /// \brief Single entry point to access MUON calibration data. /// // Author Laurent Aphecetche #ifndef ALIMUONCALIBRATIONDATA_H #define ALIMUONCALIBRATIONDATA_H #ifndef ROOT_TObject #include "TObject.h" #endif class AliCDBEntry; class AliMUONTriggerEfficiencyCells; class AliMUONTriggerLut; class AliMUONVStore; class AliMUONVStore; class AliMUONVCalibParam; class TMap; class AliMUONCalibrationData : public TObject { public: /** Constructor. * @param runNumber is used as a key to the CDB * @param deferredInitialization if kFALSE, all the calibrations are fetched * regardless of whether you'll use them or not. */ AliMUONCalibrationData(Int_t runNumber=-1, Bool_t deferredInitialization=kTRUE); virtual ~AliMUONCalibrationData(); AliMUONVStore* Capacitances() const; /// Create a capa store (which must be deleted) from OCDB for the given run static AliMUONVStore* CreateCapacitances(Int_t runNumber); /// Create a gain store (which must be deleted) from OCDB for the given run static AliMUONVStore* CreateGains(Int_t runNumber); /// Create a global trigger mask (which must be deleted) from OCDB for the given run static AliMUONVCalibParam* CreateGlobalTriggerBoardMasks(Int_t runNumber); /// Create a hv map (which must be deleted) from OCDB for the given run static TMap* CreateHV(Int_t runNumber); /// Create a neighbours store (which must be deleted) from OCDB for the given run static AliMUONVStore* CreateNeighbours(Int_t runNumber); /// Create a local trigger mask store (which must be deleted) for a given run static AliMUONVStore* CreateLocalTriggerBoardMasks(Int_t runNumber); /// Create a pedestal store (which must be deleted) from OCDB for the given run static AliMUONVStore* CreatePedestals(Int_t runNumber); /// Create a regional trigger mask store (which must be deleted) for a given run static AliMUONVStore* CreateRegionalTriggerBoardMasks(Int_t runNumber); /// Create a trigger Look Up Table (which must be deleted) for a given run static AliMUONTriggerLut* CreateTriggerLut(Int_t runNumber); /// Create a trigger efficiency map (which must be deleted) for a given run static AliMUONTriggerEfficiencyCells* CreateTriggerEfficiency(Int_t runNumber); /// Get all the gains AliMUONVStore* Gains() const; /// Get the mask for the global trigger board. AliMUONVCalibParam* GlobalTriggerBoardMasks() const; /// Get the Gain calibration object for channels within (detElemId,manuId). AliMUONVCalibParam* Gains(Int_t detElemId, Int_t manuId) const; /// Get the HV values TMap* HV() const; /// Whether this object is valid or not (might be invalid if fetching from CDB failed). Bool_t IsValid() const { return fIsValid; } /// Get the mask for a given local trigger board. AliMUONVCalibParam* LocalTriggerBoardMasks(Int_t localBoardNumber) const; /// Get the neighbours store AliMUONVStore* Neighbours() const; /// Get the pedestal store AliMUONVStore* Pedestals() const; /// Get the Pedestal calibration object for channels within (detElemId,manuId). AliMUONVCalibParam* Pedestals(Int_t detElemId, Int_t manuId) const; /// Dump to screen. virtual void Print(Option_t* opt="") const; /// Get the mask for a given regional trigger board. AliMUONVCalibParam* RegionalTriggerBoardMasks(Int_t index) const; /// The runnumber used by this object. Int_t RunNumber() const { return fRunNumber; } /// Get the trigger Look Up Table. AliMUONTriggerLut* TriggerLut() const; /// Get the trigger efficiency map AliMUONTriggerEfficiencyCells* TriggerEfficiency() const; void Reset(); protected: /// Not implemented AliMUONCalibrationData(const AliMUONCalibrationData& other); /// Not implemented AliMUONCalibrationData& operator=(const AliMUONCalibrationData& other); private: static TObject* CreateObject(Int_t runNumber, const char* path); private: mutable Bool_t fIsValid; ///< Whether we were able to correctly initialize Int_t fRunNumber; ///< The run number for which we hold calibrations mutable AliMUONVStore* fGains; //!< Gains mutable AliMUONVStore* fPedestals; //!< Pedestals mutable TMap* fHV; //!< HV mutable AliMUONVStore* fLocalTriggerBoardMasks; //!< Local trigger board maska mutable AliMUONVStore* fRegionalTriggerBoardMasks; //!< Regional trigger board maska mutable AliMUONVCalibParam* fGlobalTriggerBoardMasks; //!< Global trigger board maska mutable AliMUONTriggerLut* fTriggerLut; //!< TRigger LUTs mutable AliMUONTriggerEfficiencyCells* fTriggerEfficiency; //!< Trigger efficiency cells mutable AliMUONVStore* fCapacitances; //!< Manu capacitances mutable AliMUONVStore* fNeighbours; //!< list of neighbours for all channels ClassDef(AliMUONCalibrationData,7) // Storage for all MUON calibration data. }; #endif