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"
20 class AliMUONVCalibParam;
21 class AliMUONTriggerLut;
22 class AliMUONTriggerEfficiencyCells;
23 class AliMUONRegionalTriggerConfig;
24 class AliMUONGlobalCrateConfig;
26 class AliMUONCDB : public TObject
29 /// Ctor. change the path for testing the Shuttle preprocessor, to
30 /// "local://$ALICE_ROOT/OCDB/SHUTTLE/TestShuttle/TestCDB"
31 AliMUONCDB(const char* cdbpath = "local://$ALICE_ROOT/OCDB");
32 virtual ~AliMUONCDB();
34 void SetMaxNofChannelsToGenerate(Int_t n);
36 Int_t MakeNeighbourStore(AliMUONVStore& neighbourStore);
38 Int_t MakeHVStore(TMap& aliasMap, Bool_t defaultValues);
39 Int_t MakeTriggerDCSStore(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 MakeCapacitanceStore(AliMUONVStore& capaStore, const char* file);
43 Int_t MakeGainStore(AliMUONVStore& gainStore, Bool_t defaultValues);
45 Int_t MakeLocalTriggerMaskStore(AliMUONVStore& ltm) const;
46 Int_t MakeRegionalTriggerConfigStore(AliMUONRegionalTriggerConfig& rtm) const;
47 Int_t MakeGlobalTriggerConfigStore(AliMUONGlobalCrateConfig& gtm) const;
49 AliMUONTriggerLut* MakeTriggerLUT(const char* file="$(ALICE_ROOT)/MUON/data/lutAptLpt1Hpt1p7.root") const;
50 AliMUONTriggerEfficiencyCells* MakeTriggerEfficiency(const char* file="$ALICE_ROOT/MUON/data/efficiencyCells.dat") const;
52 /// Compute the difference between two (compatible) stores
53 AliMUONVStore* Diff(AliMUONVStore& store1, AliMUONVStore& store2,
54 const char* opt="abs");
56 void Plot(const AliMUONVStore& store, const char* name, Int_t nbins=512);
58 void WriteToCDB(const char* calibpath, TObject* object,
59 Int_t startRun, Int_t endRun, Bool_t defaultValues);
60 void WriteToCDB(const char* calibpath, TObject* object,
61 Int_t startRun, Int_t endRun, const char* filename);
62 void WriteToCDB(TObject* object, const char* calibpath, Int_t startRun=0, Int_t endRun=AliCDBRunRange::Infinity(),
63 const char* comment="", const char* responsible="AliMUONCDB tester class");
65 void WriteTrigger(Bool_t defaultValues=kTRUE, Int_t startRun=0,Int_t endRun=AliCDBRunRange::Infinity());
66 void WriteTracker(Bool_t defaultValues=kTRUE, Int_t startRun=0,Int_t endRun=AliCDBRunRange::Infinity());
68 void WriteNeighbours(Int_t startRun=0, Int_t endRun=AliCDBRunRange::Infinity());
69 void WriteHV(Bool_t defaultValues, Int_t startRun, Int_t endRun=AliCDBRunRange::Infinity());
70 void WriteTriggerDCS(Bool_t defaultValues, Int_t startRun, Int_t endRun=AliCDBRunRange::Infinity());
71 void WritePedestals(Bool_t defaultValues, Int_t startRun, Int_t endRun=AliCDBRunRange::Infinity());
72 void WriteGains(Bool_t defaultValues, Int_t startRun, Int_t endRun=AliCDBRunRange::Infinity());
73 void WriteCapacitances(Bool_t defaultValues, Int_t startRun=0, Int_t endRun=AliCDBRunRange::Infinity());
74 void WriteCapacitances(const char* file, Int_t startRun=0, Int_t endRun=AliCDBRunRange::Infinity());
76 void WriteLocalTriggerMasks(Int_t startRun=0, Int_t endRun=AliCDBRunRange::Infinity());
77 void WriteRegionalTriggerConfig(Int_t startRun=0, Int_t endRun=AliCDBRunRange::Infinity());
78 void WriteGlobalTriggerConfig(Int_t startRun=0, Int_t endRun=AliCDBRunRange::Infinity());
80 void WriteTriggerLut(Int_t startRun=0, Int_t endRun=AliCDBRunRange::Infinity());
81 void WriteTriggerEfficiency(Int_t startRun=0, Int_t endRun=AliCDBRunRange::Infinity());
85 AliMUONCDB(const AliMUONCDB& rhs);
87 AliMUONCDB& operator=(const AliMUONCDB& rhs);
90 TString fCDBPath; //!< where to write stuff
91 Int_t fMaxNofChannelsToGenerate; //!< to limit the number of generated channels (debug)
93 ClassDef(AliMUONCDB,0) // Helper class to experience OCDB