]>
Commit | Line | Data |
---|---|---|
c5bdf179 | 1 | /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. * |
2 | * See cxx source for full Copyright notice */ | |
3 | ||
4 | // $Id$ | |
5 | ||
e41c38cf | 6 | /// \ingroup calib |
c5bdf179 | 7 | /// \class AliMUONCalibrationData |
c3ce65fd | 8 | /// \brief Single entry point to access MUON calibration data. |
c5bdf179 | 9 | /// |
5398f946 | 10 | // Author Laurent Aphecetche |
c5bdf179 | 11 | |
12 | #ifndef ALIMUONCALIBRATIONDATA_H | |
13 | #define ALIMUONCALIBRATIONDATA_H | |
14 | ||
15 | #ifndef ROOT_TObject | |
16 | #include "TObject.h" | |
17 | #endif | |
18 | ||
19 | class AliCDBEntry; | |
0045b488 | 20 | class AliMUONGlobalCrateConfig; |
21 | class AliMUONRegionalTriggerConfig; | |
22 | class AliMUONRejectList; | |
e7d7fa47 | 23 | class AliMUONTriggerEfficiencyCells; |
24 | class AliMUONTriggerLut; | |
0045b488 | 25 | class AliMUONVCalibParam; |
a0eca509 | 26 | class AliMUONVStore; |
27 | class AliMUONVStore; | |
48ed403b | 28 | class TMap; |
c5bdf179 | 29 | |
30 | class AliMUONCalibrationData : public TObject | |
31 | { | |
32 | public: | |
c3ce65fd | 33 | /** Constructor. |
34 | * @param runNumber is used as a key to the CDB | |
35 | * @param deferredInitialization if kFALSE, all the calibrations are fetched | |
36 | * regardless of whether you'll use them or not. | |
37 | */ | |
c5bdf179 | 38 | AliMUONCalibrationData(Int_t runNumber=-1, Bool_t deferredInitialization=kTRUE); |
39 | virtual ~AliMUONCalibrationData(); | |
c3ce65fd | 40 | |
a0eca509 | 41 | AliMUONVStore* Capacitances() const; |
5562688f | 42 | |
43 | /// Create a capa store (which must be deleted) from OCDB for the given run | |
143cd71a | 44 | static AliMUONVStore* CreateCapacitances(Int_t runNumber, Int_t* startOfValidity=0); |
5562688f | 45 | |
46 | /// Create a gain store (which must be deleted) from OCDB for the given run | |
143cd71a | 47 | static AliMUONVStore* CreateGains(Int_t runNumber, Int_t* startOfValidity=0); |
5562688f | 48 | |
49 | /// Create a global trigger mask (which must be deleted) from OCDB for the given run | |
143cd71a | 50 | static AliMUONGlobalCrateConfig* CreateGlobalTriggerCrateConfig(Int_t runNumber, Int_t* startOfValidity=0); |
c1bbaf66 | 51 | |
5562688f | 52 | /// Create a hv map (which must be deleted) from OCDB for the given run |
143cd71a | 53 | static TMap* CreateHV(Int_t runNumber, Int_t* startOfValidity=0); |
5562688f | 54 | |
49e110ec | 55 | /// Create a Trigger HV and current map (which must be deleted) from OCDB for the given run |
56 | static TMap* CreateTriggerDCS(Int_t runNumber, Int_t* startOfValidity=0); | |
57 | ||
5562688f | 58 | /// Create a neighbours store (which must be deleted) from OCDB for the given run |
143cd71a | 59 | static AliMUONVStore* CreateNeighbours(Int_t runNumber, Int_t* startOfValidity=0); |
c5bdf179 | 60 | |
5562688f | 61 | /// Create a local trigger mask store (which must be deleted) for a given run |
143cd71a | 62 | static AliMUONVStore* CreateLocalTriggerBoardMasks(Int_t runNumber, Int_t* startOfValidity=0); |
e7d7fa47 | 63 | |
7eafe398 | 64 | /// Create an occupancy map store (which must be deleted) from OCDB for the given run |
65 | static AliMUONVStore* CreateOccupancyMap(Int_t runNumber, Int_t* startOfValidity=0); | |
2b8a1212 | 66 | |
0045b488 | 67 | /// Create a rejectlist store (which must be deleted) from OCDB for the given run |
68 | static AliMUONRejectList* CreateRejectList(Int_t runNumber, Int_t* startOfValidity=0); | |
69 | ||
5562688f | 70 | /// Create a pedestal store (which must be deleted) from OCDB for the given run |
143cd71a | 71 | static AliMUONVStore* CreatePedestals(Int_t runNumber, Int_t* startOfValidity=0); |
c3ce65fd | 72 | |
5562688f | 73 | /// Create a regional trigger mask store (which must be deleted) for a given run |
143cd71a | 74 | static AliMUONRegionalTriggerConfig* CreateRegionalTriggerConfig(Int_t runNumber, Int_t* startOfValidity=0); |
48ed403b | 75 | |
5562688f | 76 | /// Create a trigger Look Up Table (which must be deleted) for a given run |
143cd71a | 77 | static AliMUONTriggerLut* CreateTriggerLut(Int_t runNumber, Int_t* startOfValidity=0); |
5562688f | 78 | /// Create a trigger efficiency map (which must be deleted) for a given run |
143cd71a | 79 | static AliMUONTriggerEfficiencyCells* CreateTriggerEfficiency(Int_t runNumber, Int_t* startOfValidity=0); |
5562688f | 80 | |
81 | /// Get all the gains | |
82 | AliMUONVStore* Gains() const; | |
83 | ||
92c23b09 | 84 | /// Get the configuration for the global trigger board. |
85 | AliMUONGlobalCrateConfig* GlobalTriggerCrateConfig() const; | |
5562688f | 86 | |
87 | /// Get the Gain calibration object for channels within (detElemId,manuId). | |
88 | AliMUONVCalibParam* Gains(Int_t detElemId, Int_t manuId) const; | |
89 | ||
48ed403b | 90 | /// Get the HV values |
91 | TMap* HV() const; | |
49e110ec | 92 | |
93 | /// Get the Trigger HV and current values | |
94 | TMap* TriggerDCS() const; | |
5562688f | 95 | |
c3ce65fd | 96 | /// Whether this object is valid or not (might be invalid if fetching from CDB failed). |
97 | Bool_t IsValid() const { return fIsValid; } | |
5562688f | 98 | |
99 | /// Get the mask for a given local trigger board. | |
100 | AliMUONVCalibParam* LocalTriggerBoardMasks(Int_t localBoardNumber) const; | |
101 | ||
102 | /// Get the neighbours store | |
103 | AliMUONVStore* Neighbours() const; | |
c5bdf179 | 104 | |
5562688f | 105 | /// Get the pedestal store |
a0eca509 | 106 | AliMUONVStore* Pedestals() const; |
2b8a1212 | 107 | |
7eafe398 | 108 | /// Get the occupancy map store |
109 | AliMUONVStore* OccupancyMap() const; | |
2b8a1212 | 110 | |
0045b488 | 111 | /// Get the reject list store |
112 | AliMUONRejectList* RejectList() const; | |
113 | ||
c3ce65fd | 114 | /// Get the Pedestal calibration object for channels within (detElemId,manuId). |
e7d7fa47 | 115 | AliMUONVCalibParam* Pedestals(Int_t detElemId, Int_t manuId) const; |
c5bdf179 | 116 | |
c3ce65fd | 117 | /// Dump to screen. |
c5bdf179 | 118 | virtual void Print(Option_t* opt="") const; |
e7d7fa47 | 119 | |
92c23b09 | 120 | /// Get the config for regional trigger. |
121 | AliMUONRegionalTriggerConfig* RegionalTriggerConfig() const; | |
122 | ||
e7d7fa47 | 123 | |
c3ce65fd | 124 | /// The runnumber used by this object. |
125 | Int_t RunNumber() const { return fRunNumber; } | |
c5bdf179 | 126 | |
e7d7fa47 | 127 | /// Get the trigger Look Up Table. |
128 | AliMUONTriggerLut* TriggerLut() const; | |
129 | ||
130 | /// Get the trigger efficiency map | |
131 | AliMUONTriggerEfficiencyCells* TriggerEfficiency() const; | |
132 | ||
c1bbaf66 | 133 | void Reset(); |
0145e89a | 134 | |
143cd71a | 135 | static TObject* CreateObject(Int_t runNumber, const char* path, Int_t* startOfValidity=0x0); |
c1bbaf66 | 136 | |
630711ed | 137 | static void Check(Int_t runNumber); |
138 | ||
884a73f1 | 139 | protected: |
71a2d3aa | 140 | /// Not implemented |
e7d7fa47 | 141 | AliMUONCalibrationData(const AliMUONCalibrationData& other); |
71a2d3aa | 142 | /// Not implemented |
e7d7fa47 | 143 | AliMUONCalibrationData& operator=(const AliMUONCalibrationData& other); |
144 | ||
5562688f | 145 | private: |
71a2d3aa | 146 | mutable Bool_t fIsValid; ///< Whether we were able to correctly initialize |
147 | Int_t fRunNumber; ///< The run number for which we hold calibrations | |
a0eca509 | 148 | mutable AliMUONVStore* fGains; //!< Gains |
149 | mutable AliMUONVStore* fPedestals; //!< Pedestals | |
71a2d3aa | 150 | mutable TMap* fHV; //!< HV |
49e110ec | 151 | mutable TMap* fTriggerDCS; //!< Trigger HV and Currents |
92c23b09 | 152 | mutable AliMUONVStore* fLocalTriggerBoardMasks; //!< Local trigger board maska |
153 | mutable AliMUONRegionalTriggerConfig* fRegionalTriggerConfig; //!< Regional trigger config | |
154 | mutable AliMUONGlobalCrateConfig* fGlobalTriggerCrateConfig; //!< Global trigger crate config | |
155 | ||
71a2d3aa | 156 | mutable AliMUONTriggerLut* fTriggerLut; //!< TRigger LUTs |
157 | mutable AliMUONTriggerEfficiencyCells* fTriggerEfficiency; //!< Trigger efficiency cells | |
a0eca509 | 158 | mutable AliMUONVStore* fCapacitances; //!< Manu capacitances |
159 | mutable AliMUONVStore* fNeighbours; //!< list of neighbours for all channels | |
c5bdf179 | 160 | |
7eafe398 | 161 | mutable AliMUONVStore* fOccupancyMap; //!< occupancy map |
2b8a1212 | 162 | |
0045b488 | 163 | mutable AliMUONRejectList* fRejectList; //!< reject list |
164 | ||
165 | ClassDef(AliMUONCalibrationData,11) // Storage for all MUON calibration data. | |
c5bdf179 | 166 | }; |
167 | ||
168 | #endif |