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;
24 class AliMUONRegionalTriggerConfig;
25 class AliMUONGlobalCrateConfig;
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 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);
63 void WriteTrigger(Int_t startRun=0,Int_t endRun=AliCDBRunRange::Infinity());
64 void WriteTracker(Bool_t defaultValues=kTRUE, Int_t startRun=0,Int_t endRun=AliCDBRunRange::Infinity());
66 void WriteNeighbours(Int_t startRun=0, Int_t endRun=AliCDBRunRange::Infinity());
67 void WriteHV(Bool_t defaultValues, Int_t startRun, Int_t endRun);
68 void WritePedestals(Bool_t defaultValues, Int_t startRun, Int_t endRun=AliCDBRunRange::Infinity());
69 void WriteGains(Bool_t defaultValues, Int_t startRun, Int_t endRun=AliCDBRunRange::Infinity());
70 void WriteCapacitances(Bool_t defaultValues, Int_t startRun=0, Int_t endRun=AliCDBRunRange::Infinity());
71 void WriteCapacitances(const char* file, Int_t startRun=0, Int_t endRun=AliCDBRunRange::Infinity());
73 void WriteLocalTriggerMasks(Int_t startRun=0, Int_t endRun=AliCDBRunRange::Infinity());
74 void WriteRegionalTriggerConfig(Int_t startRun=0, Int_t endRun=AliCDBRunRange::Infinity());
75 void WriteGlobalTriggerConfig(Int_t startRun=0, Int_t endRun=AliCDBRunRange::Infinity());
77 void WriteTriggerLut(Int_t startRun=0, Int_t endRun=AliCDBRunRange::Infinity());
78 void WriteTriggerEfficiency(Int_t startRun=0, Int_t endRun=AliCDBRunRange::Infinity());
82 AliMUONCDB(const AliMUONCDB& rhs);
84 AliMUONCDB& operator=(const AliMUONCDB& rhs);
87 TString fCDBPath; //!< where to write stuff
88 Int_t fMaxNofChannelsToGenerate; //!< to limit the number of generated channels (debug)
90 ClassDef(AliMUONCDB,0) // Helper class to experience OCDB