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
21 class AliMUONVCalibParam;
22 class AliMUONTriggerLut;
23 class AliMUONTriggerEfficiencyCells;
25 #define ALIMUONCDBINFINITY 99999999
27 class AliMUONCDB : public TObject
30 /// Ctor. change the path for testing the Shuttle preprocessor, to
31 /// "local://$ALICE_ROOT/SHUTTLE/TestShuttle/TestCDB"
32 AliMUONCDB(const char* cdbpath = "local://$ALICE_ROOT");
33 virtual ~AliMUONCDB();
35 void SetMaxNofChannelsToGenerate(Int_t n);
37 Int_t MakeNeighbourStore(AliMUONVStore& neighbourStore);
39 Int_t MakeHVStore(TMap& aliasMap, Bool_t defaultValues);
40 Int_t MakePedestalStore(AliMUONVStore& pedestalStore, Bool_t defaultValues);
41 Int_t MakeCapacitanceStore(AliMUONVStore& capaStore, Bool_t defaultValues);
42 Int_t MakeGainStore(AliMUONVStore& gainStore, Bool_t defaultValues);
44 Int_t MakeLocalTriggerMaskStore(AliMUONVStore& ltm) const;
45 Int_t MakeRegionalTriggerMaskStore(AliMUONVStore& rtm) const;
46 Int_t MakeGlobalTriggerMaskStore(AliMUONVCalibParam& gtm) const;
47 AliMUONTriggerLut* MakeTriggerLUT(const char* file="$(ALICE_ROOT)/MUON/data/lutAptLpt1Hpt1p7.root") const;
48 AliMUONTriggerEfficiencyCells* MakeTriggerEfficiency(const char* file="$ALICE_ROOT/MUON/data/efficiencyCells.dat") const;
50 /// Compute the difference between two (compatible) stores
51 AliMUONVStore* Diff(AliMUONVStore& store1, AliMUONVStore& store2,
52 const char* opt="abs");
54 void Plot(const AliMUONVStore& store, const char* name, Int_t nbins=512);
56 void WriteToCDB(const char* calibpath, TObject* object,
57 Int_t startRun, Int_t endRun, Bool_t defaultValues);
59 void WriteTrigger(Int_t startRun=0,Int_t endRun=ALIMUONCDBINFINITY);
60 void WriteTracker(Bool_t defaultValues=kTRUE, Int_t startRun=0,Int_t endRun=ALIMUONCDBINFINITY);
62 void WriteNeighbours(Int_t startRun=0, Int_t endRun=ALIMUONCDBINFINITY);
63 void WriteHV(Bool_t defaultValues, Int_t startRun, Int_t endRun);
64 void WritePedestals(Bool_t defaultValues, Int_t startRun, Int_t endRun=ALIMUONCDBINFINITY);
65 void WriteGains(Bool_t defaultValues, Int_t startRun, Int_t endRun=ALIMUONCDBINFINITY);
66 void WriteCapacitances(Bool_t defaultValues, Int_t startRun=0, Int_t endRun=ALIMUONCDBINFINITY);
68 void WriteLocalTriggerMasks(Int_t startRun=0, Int_t endRun=ALIMUONCDBINFINITY);
69 void WriteRegionalTriggerMasks(Int_t startRun=0, Int_t endRun=ALIMUONCDBINFINITY);
70 void WriteGlobalTriggerMasks(Int_t startRun=0, Int_t endRun=ALIMUONCDBINFINITY);
71 void WriteTriggerLut(Int_t startRun=0, Int_t endRun=ALIMUONCDBINFINITY);
72 void WriteTriggerEfficiency(Int_t startRun=0, Int_t endRun=ALIMUONCDBINFINITY);
76 AliMUONCDB(const AliMUONCDB& rhs);
78 AliMUONCDB& operator=(const AliMUONCDB& rhs);
83 TString fCDBPath; //!< where to write stuff
84 TList* fManuList; //!< full list of manus
85 Int_t fMaxNofChannelsToGenerate; //!< to limit the number of generated channels (debug)
87 ClassDef(AliMUONCDB,0) // Helper class to experience OCDB