FineDelayHistosUsingDb

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

#ifndef DQM_SiStripCommissioningClients_FineDelayHistosUsingDb_H
#define DQM_SiStripCommissioningClients_FineDelayHistosUsingDb_H

#include "Geometry/Records/interface/TrackerDigiGeometryRecord.h"
#include "DQM/SiStripCommissioningClients/interface/SamplingHistograms.h"
#include "DQM/SiStripCommissioningDbClients/interface/CommissioningHistosUsingDb.h"
#include "OnlineDB/SiStripConfigDb/interface/SiStripConfigDb.h"
#include <string>
#include <map>

class TrackerGeometry;

class FineDelayHistosUsingDb : public CommissioningHistosUsingDb, public SamplingHistograms {
public:
  FineDelayHistosUsingDb(const edm::ParameterSet& pset,
                         DQMStore*,
                         SiStripConfigDb* const,
                         edm::ESGetToken<TrackerTopology, TrackerTopologyRcd> tTopoToken,
                         edm::ESGetToken<TrackerGeometry, TrackerDigiGeometryRecord> tkGeomToken);

  ~FineDelayHistosUsingDb() override;

  void configure(const edm::ParameterSet&, const edm::EventSetup&) override;

  void uploadConfigurations() override;

private:
  bool update(SiStripConfigDb::DeviceDescriptionsRange);

  void update(SiStripConfigDb::FedDescriptionsRange);

  void create(SiStripConfigDb::AnalysisDescriptionsV&, Analysis) override;

  void computeDelays();

  std::map<unsigned int, float> delays_;

  edm::ESGetToken<TrackerGeometry, TrackerDigiGeometryRecord> tkGeomToken_;
  const TrackerGeometry* tracker_;

  bool cosmic_;
};

#endif  // DQM_SiStripCommissioningClients_FineDelayHistosUsingDb_H