EcalTestDevDB

Macros

Line Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
#ifndef CondTools_Ecal_EcalTestDevDB_h
#define CondTools_Ecal_EcalTestDevDB_h

#include "FWCore/Framework/interface/one/EDAnalyzer.h"
#include "CondCore/CondDB/interface/Exception.h"

#include "FWCore/Framework/interface/IOVSyncValue.h"

#include "CondFormats/EcalObjects/interface/EcalPedestals.h"
#include "CondFormats/DataRecord/interface/EcalPedestalsRcd.h"
#include "CondFormats/EcalObjects/interface/EcalADCToGeVConstant.h"
#include "CondFormats/DataRecord/interface/EcalADCToGeVConstantRcd.h"
#include "CondFormats/EcalObjects/interface/EcalLinearCorrections.h"
#include "CondFormats/DataRecord/interface/EcalLinearCorrectionsRcd.h"
#include "CondFormats/EcalObjects/interface/EcalIntercalibConstants.h"
#include "CondFormats/DataRecord/interface/EcalIntercalibConstantsRcd.h"
#include "CondFormats/EcalObjects/interface/EcalGainRatios.h"
#include "CondFormats/DataRecord/interface/EcalGainRatiosRcd.h"
#include "CondFormats/EcalObjects/interface/EcalWeightXtalGroups.h"
#include "CondFormats/DataRecord/interface/EcalWeightXtalGroupsRcd.h"
#include "CondFormats/EcalObjects/interface/EcalTBWeights.h"
#include "CondFormats/DataRecord/interface/EcalTBWeightsRcd.h"
#include "CondFormats/EcalObjects/interface/EcalLaserAPDPNRatios.h"
#include "CondFormats/DataRecord/interface/EcalLaserAPDPNRatiosRcd.h"
#include "CondFormats/EcalObjects/interface/EcalLaserAlphas.h"
#include "CondFormats/DataRecord/interface/EcalLaserAlphasRcd.h"
#include "CondFormats/EcalObjects/interface/EcalLaserAPDPNRatiosRef.h"
#include "CondFormats/DataRecord/interface/EcalLaserAPDPNRatiosRefRcd.h"
#include "DataFormats/EcalDetId/interface/EBDetId.h"

#include <string>
#include <map>
#include <memory>

namespace edm {
  class ParameterSet;
  class Event;
  class EventSetup;
}  // namespace edm

class EcalTestDevDB : public edm::one::EDAnalyzer<> {
public:
  explicit EcalTestDevDB(const edm::ParameterSet& iConfig);
  ~EcalTestDevDB() override;

  void analyze(const edm::Event& evt, const edm::EventSetup& evtSetup) override;

  std::shared_ptr<EcalPedestals> generateEcalPedestals();
  std::shared_ptr<EcalADCToGeVConstant> generateEcalADCToGeVConstant();
  std::shared_ptr<EcalIntercalibConstants> generateEcalIntercalibConstants();
  std::shared_ptr<EcalLinearCorrections> generateEcalLinearCorrections();
  std::shared_ptr<EcalGainRatios> generateEcalGainRatios();
  std::shared_ptr<EcalWeightXtalGroups> generateEcalWeightXtalGroups();
  std::shared_ptr<EcalTBWeights> generateEcalTBWeights();
  std::shared_ptr<EcalLaserAPDPNRatios> generateEcalLaserAPDPNRatios(uint32_t i_run);
  std::shared_ptr<EcalLaserAlphas> generateEcalLaserAlphas();
  std::shared_ptr<EcalLaserAPDPNRatiosRef> generateEcalLaserAPDPNRatiosRef();

private:
  std::string m_timetype;
  std::map<std::string, unsigned long long> m_cacheIDs;
  std::map<std::string, std::string> m_records;
  unsigned long m_firstRun;
  unsigned long m_lastRun;
  unsigned int m_interval;
};

#endif