EcalPulseSymmCovariancesHandler

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
#ifndef ECAL_PULSESYMMCOVARIANCES_HANDLER_H
#define ECAL_PULSESYMMCOVARIANCES_HANDLER_H

#include <vector>
#include <typeinfo>
#include <string>
#include <map>
#include <iostream>
#include <ctime>

#include "CondCore/PopCon/interface/PopConSourceHandler.h"
#include "FWCore/ParameterSet/interface/ParameterSetfwd.h"

#include "FWCore/ServiceRegistry/interface/Service.h"
#include "CondCore/DBOutputService/interface/PoolDBOutputService.h"
#include "FWCore/Framework/interface/ESHandle.h"
#include "FWCore/Framework/interface/Event.h"
#include "FWCore/Framework/interface/MakerMacros.h"
#include "FWCore/MessageLogger/interface/MessageLogger.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include "DataFormats/Common/interface/Handle.h"
#include "FWCore/Framework/interface/EventSetup.h"
#include "FWCore/Framework/interface/EventSetupRecordKey.h"

#include "CondFormats/EcalObjects/interface/EcalPulseSymmCovariances.h"
#include "CondFormats/DataRecord/interface/EcalPulseSymmCovariancesRcd.h"

#include "DataFormats/EcalDetId/interface/EEDetId.h"
#include "DataFormats/EcalDetId/interface/EBDetId.h"
#include "DataFormats/Provenance/interface/Timestamp.h"

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

namespace popcon {

  class EcalPulseSymmCovariancesHandler : public popcon::PopConSourceHandler<EcalPulseSymmCovariances> {
  public:
    EcalPulseSymmCovariancesHandler(edm::ParameterSet const&);
    ~EcalPulseSymmCovariancesHandler() override;
    bool checkPulseSymmCovariance(EcalPulseSymmCovariances::Item* item);
    void fillSimPulseSymmCovariance(EcalPulseSymmCovariances::Item* item, bool isbarrel);
    void getNewObjects() override;
    std::string id() const override { return m_name; }

  private:
    const EcalPulseSymmCovariances* mypulseshapes;

    unsigned int m_firstRun;
    unsigned int m_lastRun;

    std::string m_gentag;
    std::string m_filename;
    std::string m_name;
    std::vector<double> m_EBPulseShapeCovariance, m_EEPulseShapeCovariance;
  };
}  // namespace popcon
#endif