SiStripGainRandomCalculator

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
#ifndef CalibTracker_SiStripChannelGain_SiStripGainRandomCalculator_h
#define CalibTracker_SiStripChannelGain_SiStripGainRandomCalculator_h
// -*- C++ -*-
//
// Package:    SiStripApvGainCalculator
// Class:      SiStripApvGainCalculator
//
/**\class SiStripApvGainCalculator SiStripApvGainCalculator.cc CalibTracker/SiStripChannelGain/src/SiStripApvGainCalculator.cc

 Description: <one line class summary>

 Implementation:
     <Notes on implementation>
*/
//
// Original Author:  Dorian Kcira, Pierre Rodeghiero
//         Created:  Mon Nov 20 10:04:31 CET 2006
//
//

#include "CommonTools/ConditionDBWriter/interface/ConditionDBWriter.h"
#include "CondFormats/SiStripObjects/interface/SiStripApvGain.h"

#include "Geometry/TrackerGeometryBuilder/interface/TrackerGeometry.h"
#include "Geometry/Records/interface/TrackerDigiGeometryRecord.h"
#include "FWCore/Framework/interface/ESWatcher.h"

#include <vector>
#include <memory>

class SiStripGainRandomCalculator : public ConditionDBWriter<SiStripApvGain> {
public:
  explicit SiStripGainRandomCalculator(const edm::ParameterSet &);
  ~SiStripGainRandomCalculator() override;

private:
  void algoAnalyze(const edm::Event &, const edm::EventSetup &) override;

  std::unique_ptr<SiStripApvGain> getNewObject() override;

private:
  double meanGain_;
  double sigmaGain_;
  double minimumPosValue_;

  std::vector<std::pair<uint32_t, unsigned short> > detid_apvs_;
  bool printdebug_;

  edm::ESGetToken<TrackerGeometry, TrackerDigiGeometryRecord> tkGeomToken_;
  edm::ESWatcher<TrackerDigiGeometryRecord> tkDigiGeomRcdWatcher_;
};
#endif