3 /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
4 * See cxx source for full Copyright notice */
10 /// \brief Helper class to experience the OCDB
12 // Author Laurent Aphecetche
16 #include "AliCDBRunRange.h"
21 class AliMUONVCalibParam;
22 class AliMUONTriggerLut;
23 class AliMUONTriggerEfficiencyCells;
25 class AliMUONCDB : public TObject
28 /// Ctor. change the path for testing the Shuttle preprocessor, to
29 /// "local://$ALICE_ROOT/SHUTTLE/TestShuttle/TestCDB"
30 AliMUONCDB(const char* cdbpath = "local://$ALICE_ROOT");
31 virtual ~AliMUONCDB();
33 void SetMaxNofChannelsToGenerate(Int_t n);
35 Int_t MakeNeighbourStore(AliMUONVStore& neighbourStore);
37 Int_t MakeHVStore(TMap& aliasMap, Bool_t defaultValues);
38 Int_t MakePedestalStore(AliMUONVStore& pedestalStore, Bool_t defaultValues);
39 Int_t MakeCapacitanceStore(AliMUONVStore& capaStore, Bool_t defaultValues);
40 Int_t MakeCapacitanceStore(AliMUONVStore& capaStore, const char* file);
41 Int_t MakeGainStore(AliMUONVStore& gainStore, Bool_t defaultValues);
43 Int_t MakeLocalTriggerMaskStore(AliMUONVStore& ltm) const;
44 Int_t MakeRegionalTriggerMaskStore(AliMUONVStore& rtm) const;
45 Int_t MakeGlobalTriggerMaskStore(AliMUONVCalibParam& gtm) const;
46 AliMUONTriggerLut* MakeTriggerLUT(const char* file="$(ALICE_ROOT)/MUON/data/lutAptLpt1Hpt1p7.root") const;
47 AliMUONTriggerEfficiencyCells* MakeTriggerEfficiency(const char* file="$ALICE_ROOT/MUON/data/efficiencyCells.dat") const;
49 /// Compute the difference between two (compatible) stores
50 AliMUONVStore* Diff(AliMUONVStore& store1, AliMUONVStore& store2,
51 const char* opt="abs");
53 void Plot(const AliMUONVStore& store, const char* name, Int_t nbins=512);
55 void WriteToCDB(const char* calibpath, TObject* object,
56 Int_t startRun, Int_t endRun, Bool_t defaultValues);
57 void WriteToCDB(const char* calibpath, TObject* object,
58 Int_t startRun, Int_t endRun, const char* filename);
60 void WriteTrigger(Int_t startRun=0,Int_t endRun=AliCDBRunRange::Infinity());
61 void WriteTracker(Bool_t defaultValues=kTRUE, Int_t startRun=0,Int_t endRun=AliCDBRunRange::Infinity());
63 void WriteNeighbours(Int_t startRun=0, Int_t endRun=AliCDBRunRange::Infinity());
64 void WriteHV(Bool_t defaultValues, Int_t startRun, Int_t endRun);
65 void WritePedestals(Bool_t defaultValues, Int_t startRun, Int_t endRun=AliCDBRunRange::Infinity());
66 void WriteGains(Bool_t defaultValues, Int_t startRun, Int_t endRun=AliCDBRunRange::Infinity());
67 void WriteCapacitances(Bool_t defaultValues, Int_t startRun=0, Int_t endRun=AliCDBRunRange::Infinity());
68 void WriteCapacitances(const char* file, Int_t startRun=0, Int_t endRun=AliCDBRunRange::Infinity());
70 void WriteLocalTriggerMasks(Int_t startRun=0, Int_t endRun=AliCDBRunRange::Infinity());
71 void WriteRegionalTriggerMasks(Int_t startRun=0, Int_t endRun=AliCDBRunRange::Infinity());
72 void WriteGlobalTriggerMasks(Int_t startRun=0, Int_t endRun=AliCDBRunRange::Infinity());
73 void WriteTriggerLut(Int_t startRun=0, Int_t endRun=AliCDBRunRange::Infinity());
74 void WriteTriggerEfficiency(Int_t startRun=0, Int_t endRun=AliCDBRunRange::Infinity());
78 AliMUONCDB(const AliMUONCDB& rhs);
80 AliMUONCDB& operator=(const AliMUONCDB& rhs);
83 TString fCDBPath; //!< where to write stuff
84 Int_t fMaxNofChannelsToGenerate; //!< to limit the number of generated channels (debug)
86 ClassDef(AliMUONCDB,0) // Helper class to experience OCDB