CMS 3D CMS Logo

SiStripApvGainFakeESSource.cc
Go to the documentation of this file.
1 // -*- C++ -*-
2 //
3 // Package: CalibTracker/SiStripESProducers
4 // Class: SiStripApvGainFakeESSource
5 //
14 // system include files
15 #include <memory>
16 
17 // user include files
20 
24 
26 
28 public:
30  ~SiStripApvGainFakeESSource() override;
31 
33  const edm::IOVSyncValue& iov,
34  edm::ValidityInterval& iValidity) override;
35 
36  typedef std::unique_ptr<SiStripApvGain> ReturnType;
38 
39 private:
41  double m_meanGain;
42  double m_sigmaGain;
44  uint32_t m_printDebug;
46 };
47 
49 #include "CLHEP/Random/RandGauss.h"
50 
52  setWhatProduced(this);
53  findingRecord<SiStripApvGainRcd>();
54 
55  m_genMode = iConfig.getParameter<std::string>("genMode");
56  m_meanGain = iConfig.getParameter<double>("MeanGain");
57  m_sigmaGain = iConfig.getParameter<double>("SigmaGain");
58  m_minimumPosValue = iConfig.getParameter<double>("MinPositiveGain");
59  m_printDebug = iConfig.getUntrackedParameter<uint32_t>("printDebug", 5);
61 }
62 
64 
66  const edm::IOVSyncValue& iov,
67  edm::ValidityInterval& iValidity) {
68  iValidity = edm::ValidityInterval{iov.beginOfTime(), iov.endOfTime()};
69 }
70 
71 // ------------ method called to produce the data ------------
73  using namespace edm::es;
74 
75  auto apvGain = std::make_unique<SiStripApvGain>();
76 
77  uint32_t count{0};
78  for (const auto& elm : m_detInfo.getAllData()) {
79  std::vector<float> theSiStripVector;
80  for (unsigned short j = 0; j < elm.second.nApvs; ++j) {
81  float gainValue;
82  if (m_genMode == "default") {
83  gainValue = m_meanGain;
84  } else if (m_genMode == "gaussian") {
85  gainValue = CLHEP::RandGauss::shoot(m_meanGain, m_sigmaGain);
86  if (gainValue <= m_minimumPosValue) {
87  gainValue = m_minimumPosValue;
88  }
89  } else {
90  LogDebug("SiStripApvGain") << "ERROR: wrong genMode specifier : " << m_genMode
91  << ", please select one of \"default\" or \"gaussian\"";
92  exit(1);
93  }
94 
95  if (count < m_printDebug) {
96  edm::LogInfo("SiStripApvGainGenerator") << "detid: " << elm.first << " Apv: " << j << " gain: " << gainValue;
97  }
98  theSiStripVector.push_back(gainValue);
99  }
100  ++count;
101 
102  if (!apvGain->put(elm.first, SiStripApvGain::Range{theSiStripVector.begin(), theSiStripVector.end()})) {
103  edm::LogError("SiStripApvGainGenerator") << " detid already exists";
104  }
105  }
106 
107  return apvGain;
108 }
109 
110 //define this as a plug-in
SiStripApvGainFakeESSource::~SiStripApvGainFakeESSource
~SiStripApvGainFakeESSource() override
Definition: SiStripApvGainFakeESSource.cc:63
SiStripApvGainFakeESSource::m_detInfo
SiStripDetInfo m_detInfo
Definition: SiStripApvGainFakeESSource.cc:45
MessageLogger.h
edm::ESProducer::setWhatProduced
auto setWhatProduced(T *iThis, const es::Label &iLabel={})
Definition: ESProducer.h:163
edm::ValidityInterval
Definition: ValidityInterval.h:28
SiStripApvGainFakeESSource::m_meanGain
double m_meanGain
Definition: SiStripApvGainFakeESSource.cc:41
ESProducer.h
edm::ParameterSet::getUntrackedParameter
T getUntrackedParameter(std::string const &, T const &) const
edm::LogInfo
Log< level::Info, false > LogInfo
Definition: MessageLogger.h:125
edm::EventSetupRecordIntervalFinder
Definition: EventSetupRecordIntervalFinder.h:33
SiStripApvGainFakeESSource::ReturnType
std::unique_ptr< SiStripApvGain > ReturnType
Definition: SiStripApvGainFakeESSource.cc:36
edm::eventsetup::EventSetupRecordKey
Definition: EventSetupRecordKey.h:30
SiStripDetInfoFileReader::read
SiStripDetInfo read(std::string filePath)
Definition: SiStripDetInfoFileReader.cc:11
edm::FileInPath
Definition: FileInPath.h:61
SiStripApvGainFakeESSource::setIntervalFor
void setIntervalFor(const edm::eventsetup::EventSetupRecordKey &, const edm::IOVSyncValue &iov, edm::ValidityInterval &iValidity) override
Definition: SiStripApvGainFakeESSource.cc:65
SiStripApvGainFakeESSource
Definition: SiStripApvGainFakeESSource.cc:27
SiStripApvGainFakeESSource::m_printDebug
uint32_t m_printDebug
Definition: SiStripApvGainFakeESSource.cc:44
submitPVResolutionJobs.count
count
Definition: submitPVResolutionJobs.py:352
SiStripDetInfo::getAllData
const std::map< uint32_t, DetInfo > & getAllData() const noexcept
Definition: SiStripDetInfo.h:59
SiStripDetInfoFileReader.h
SiStripApvGain.h
edm::IOVSyncValue
Definition: IOVSyncValue.h:31
DEFINE_FWK_EVENTSETUP_SOURCE
#define DEFINE_FWK_EVENTSETUP_SOURCE(type)
Definition: SourceFactory.h:91
EventSetupRecordIntervalFinder.h
SourceFactory.h
SiStripApvGainFakeESSource::m_sigmaGain
double m_sigmaGain
Definition: SiStripApvGainFakeESSource.cc:42
LogDebug
#define LogDebug(id)
Definition: MessageLogger.h:233
edm::ParameterSet
Definition: ParameterSet.h:47
SiStripCondDataRecords.h
SiStripApvGainFakeESSource::produce
ReturnType produce(const SiStripApvGainRcd &)
Definition: SiStripApvGainFakeESSource.cc:72
edm::IOVSyncValue::endOfTime
static const IOVSyncValue & endOfTime()
Definition: IOVSyncValue.cc:82
edm::LogError
Log< level::Error, false > LogError
Definition: MessageLogger.h:123
AlCaHLTBitMon_QueryRunRegistry.string
string string
Definition: AlCaHLTBitMon_QueryRunRegistry.py:256
SiStripApvGainRcd
Definition: SiStripCondDataRecords.h:8
SiStripApvGain::Range
std::pair< ContainerIterator, ContainerIterator > Range
Definition: SiStripApvGain.h:28
SiStripApvGainFakeESSource::m_minimumPosValue
double m_minimumPosValue
Definition: SiStripApvGainFakeESSource.cc:43
edm::es
Definition: es_Label.h:33
edm::IOVSyncValue::beginOfTime
static const IOVSyncValue & beginOfTime()
Definition: IOVSyncValue.cc:88
edm::ParameterSet::getParameter
T getParameter(std::string const &) const
Definition: ParameterSet.h:303
edm::ESProducer
Definition: ESProducer.h:104
SiStripDetInfo
Definition: SiStripDetInfo.h:29
beamvalidation.exit
def exit(msg="")
Definition: beamvalidation.py:52
ParameterSet.h
SiStripApvGainFakeESSource::m_genMode
std::string m_genMode
Definition: SiStripApvGainFakeESSource.cc:40
SiStripApvGainFakeESSource::SiStripApvGainFakeESSource
SiStripApvGainFakeESSource(const edm::ParameterSet &)
Definition: SiStripApvGainFakeESSource.cc:51
dqmiolumiharvest.j
j
Definition: dqmiolumiharvest.py:66
edm::FileInPath::fullPath
std::string fullPath() const
Definition: FileInPath.cc:161