CMS 3D CMS Logo

AlCaRecoTriggerBitsRcdRead.cc
Go to the documentation of this file.
1 
18 #include <memory>
19 
20 #include <map>
21 #include <string>
22 //#include <vector>
23 #include <sstream>
24 #include <fstream>
25 
26 // Framework
36 
37 // What I want to read:
40 
42 public:
45 
46  void analyze(const edm::Event &evt, const edm::EventSetup &evtSetup) override {}
47  void beginRun(const edm::Run &run, const edm::EventSetup &evtSetup) override;
48  void endJob() override;
49 
50 private:
51  // types
52  enum OutputType { kText, kTwiki, kPython }; //kHtml};
53 
54  // methods
55  OutputType stringToEnum(const std::string &outputType) const;
57 
58  // members
64  std::unique_ptr<std::ofstream> output_;
65 };
66 
70 
72  : outputType_(this->stringToEnum(cfg.getUntrackedParameter<std::string>("outputType"))), firstRun_(0), lastRun_(0) {
73  // edm::LogInfo("") << "@SUB=AlCaRecoTriggerBitsRcdRead"
74  // << cfg.getParameter<std::string>("@module_label");
75 
76  std::string fileName(cfg.getUntrackedParameter<std::string>("rawFileName"));
77  switch (outputType_) { // now append suffix
78  case kText:
79  fileName += ".txt";
80  break;
81  case kPython:
82  fileName += ".py";
83  break;
84  case kTwiki:
85  fileName += ".twiki";
86  break;
87  }
88  if (!fileName.empty()) {
89  output_ = std::make_unique<std::ofstream>(fileName.c_str());
90  if (!output_->good()) {
91  edm::LogError("IOproblem") << "Could not open output file " << fileName << ".";
92  output_.reset();
93  }
94  }
95 }
96 
99  if (outputTypeStr == "text")
100  return kText;
101  if (outputTypeStr == "twiki")
102  return kTwiki;
103  if (outputTypeStr == "python")
104  return kPython;
105  // if (outputTypeStr == "html") return kHtml;
106 
107  throw cms::Exception("BadConfig") << "AlCaRecoTriggerBitsRcdRead: "
108  << "outputType '" << outputTypeStr << "' not known,"
109  << " use 'text', 'twiki' or 'python'\n";
110 
111  return kTwiki; // never reached, to please compiler
112 }
113 
116  if (watcher_.check(iSetup)) { // new IOV for this run
117  // Print last IOV - if there has already been one:
118  if (lastRun_ != 0)
120 
121  // Get AlCaRecoTriggerBits from EventSetup:
123  iSetup.get<AlCaRecoTriggerBitsRcd>().get(triggerBits);
124  lastTriggerBits_ = *triggerBits; // copy for later use
125  firstRun_ = run.run(); // keep track where it started
126  }
127 
128  lastRun_ = run.run(); // keep track of last visited run
129 }
130 
133  // Print for very last IOV, not treated yet in beginRun(..):
135 }
136 
140  const AlCaRecoTriggerBits &triggerBits) const {
141  // Get map of strings to concatenated list of names of HLT paths:
142  typedef std::map<std::string, std::string> TriggerMap;
143  const TriggerMap &triggerMap = triggerBits.m_alcarecoToTrig;
144 
145  // Collect output for given run numbers via ostringstream.
146  // Format depends on outputType_ configuration.
147  std::ostringstream output;
148  switch (outputType_) {
149  case kPython:
150  output << " triggerLists = cms.VPSet(\n";
151  [[fallthrough]];
152  case kText:
153  output << "#\n# AlCaRecoTriggerBits settings for IOV " << firstRun << "-" << lastRun << ":\n#\n";
154  break;
155  case kTwiki:
156  output << "---+++++ *IOV*: " << firstRun << "-" << lastRun << "\n"
157  << "| *TriggerBits list key* | *HLT paths* |\n";
158  break;
159  }
160 
161  // if (outputType_ == kPython) output << " triggerLists = cms.VPSet(\n";
162 
163  // loop over entries in map
164  for (TriggerMap::const_iterator i = triggerMap.begin(); i != triggerMap.end(); ++i) {
165  if (outputType_ == kPython && i != triggerMap.begin())
166  output << ",\n";
167 
168  switch (outputType_) {
169  case kPython:
170  output << " cms.PSet(listName = cms.string('" << i->first << "'),\n"
171  << " hltPaths = cms.vstring(";
172  break;
173  case kText:
174  output << "trigger list key: '" << i->first << "'\npaths:\n";
175  break;
176  case kTwiki:
177  output << "| '" << i->first << "' | ";
178  }
179  // We must avoid a map<string,vector<string> > in DB for performance reason,
180  // so the paths are mapped into one string separated by ';':
181  const std::vector<std::string> paths = triggerBits.decompose(i->second);
182  for (unsigned int iPath = 0; iPath < paths.size(); ++iPath) {
183  if (iPath != 0) {
184  output << ", "; // next path
185  switch (outputType_) {
186  case kPython: // only 2 per line
187  case kText: // only 4 per line
188  if (0 == (iPath % (outputType_ == kPython ? 2 : 4))) {
189  output << "\n";
190  if (outputType_ == kPython)
191  output << " ";
192  }
193  break;
194  case kTwiki: // Twiki will handle that
195  break;
196  }
197  }
198  output << "'" << paths[iPath] << "'";
199  }
200  switch (outputType_) {
201  case kPython:
202  output << ")\n )";
203  break;
204  case kText:
205  output << "\n#\n";
206  break;
207  case kTwiki:
208  output << " |\n";
209  }
210  }
211  if (outputType_ == kPython)
212  output << "\n ) # closing of VPSet triggerLists\n";
213 
214  // Final output - either message logger or output file:
215  if (output_.get())
216  *output_ << output.str();
217  else
218  edm::LogInfo("") << output.str();
219 }
220 
221 //define this as a plug-in
edm::ESWatcher::check
bool check(const edm::EventSetup &iSetup)
Definition: ESWatcher.h:52
dataset.firstRun
firstRun
Definition: dataset.py:940
AlCaRecoTriggerBitsRcdRead::AlCaRecoTriggerBitsRcdRead
AlCaRecoTriggerBitsRcdRead(const edm::ParameterSet &cfg)
Definition: AlCaRecoTriggerBitsRcdRead.cc:71
edm::RunNumber_t
unsigned int RunNumber_t
Definition: RunLumiEventNumber.h:14
mps_fire.i
i
Definition: mps_fire.py:428
MessageLogger.h
edm::ESWatcher< AlCaRecoTriggerBitsRcd >
ESHandle.h
convertSQLitetoXML_cfg.output
output
Definition: convertSQLitetoXML_cfg.py:72
edm::Run
Definition: Run.h:45
AlCaRecoTriggerBitsRcdRead::analyze
void analyze(const edm::Event &evt, const edm::EventSetup &evtSetup) override
Definition: AlCaRecoTriggerBitsRcdRead.cc:46
AlCaRecoTriggerBitsRcdRead::firstRun_
edm::RunNumber_t firstRun_
Definition: AlCaRecoTriggerBitsRcdRead.cc:61
AlCaRecoTriggerBitsRcdRead::~AlCaRecoTriggerBitsRcdRead
~AlCaRecoTriggerBitsRcdRead() override
Definition: AlCaRecoTriggerBitsRcdRead.cc:44
AlCaRecoTriggerBitsRcdRead::lastRun_
edm::RunNumber_t lastRun_
Definition: AlCaRecoTriggerBitsRcdRead.cc:62
EDAnalyzer.h
edm::LogInfo
Log< level::Info, false > LogInfo
Definition: MessageLogger.h:125
MillePedeFileConverter_cfg.fileName
fileName
Definition: MillePedeFileConverter_cfg.py:32
AlCaRecoTriggerBits.h
AlCaRecoTriggerBitsRcdRead::printMap
void printMap(edm::RunNumber_t firstRun, edm::RunNumber_t lastRun, const AlCaRecoTriggerBits &triggerMap) const
Definition: AlCaRecoTriggerBitsRcdRead.cc:138
edm::EDAnalyzer
Definition: EDAnalyzer.h:28
AlCaRecoTriggerBitsRcdRead::lastTriggerBits_
AlCaRecoTriggerBits lastTriggerBits_
Definition: AlCaRecoTriggerBitsRcdRead.cc:63
MakerMacros.h
edm::EventSetup::get
T get() const
Definition: EventSetup.h:87
DEFINE_FWK_MODULE
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:16
Run.h
edm::ESHandle
Definition: DTSurvey.h:22
AlCaRecoTriggerBits::decompose
std::vector< std::string > decompose(const std::string &concatPaths) const
Decompose one value of map from concatenated string.
Definition: AlCaRecoTriggerBits.cc:31
AlCaRecoTriggerBits
Definition: AlCaRecoTriggerBits.h:9
AlCaHLTBitMon_QueryRunRegistry.string
string
Definition: AlCaHLTBitMon_QueryRunRegistry.py:256
AlCaRecoTriggerBitsRcdRead::beginRun
void beginRun(const edm::Run &run, const edm::EventSetup &evtSetup) override
Definition: AlCaRecoTriggerBitsRcdRead.cc:115
BeamSpotPI::lastRun
Definition: BeamSpotPayloadInspectorHelper.h:40
AlCaRecoTriggerBitsRcd
Definition: AlCaRecoTriggerBitsRcd.h:22
edm::ParameterSet
Definition: ParameterSet.h:47
AlCaRecoTriggerBitsRcdRead::output_
std::unique_ptr< std::ofstream > output_
Definition: AlCaRecoTriggerBitsRcdRead.cc:64
AlCaRecoTriggerBitsRcdRead::kText
Definition: AlCaRecoTriggerBitsRcdRead.cc:52
AlCaRecoTriggerBitsRcdRead::kPython
Definition: AlCaRecoTriggerBitsRcdRead.cc:52
AlCaRecoTriggerBitsRcd.h
edm::EventSetup
Definition: EventSetup.h:58
edm::LogError
Log< level::Error, false > LogError
Definition: MessageLogger.h:123
AlCaRecoTriggerBitsRcdRead::kTwiki
Definition: AlCaRecoTriggerBitsRcdRead.cc:52
get
#define get
AlCaRecoTriggerBitsRcdRead::endJob
void endJob() override
Definition: AlCaRecoTriggerBitsRcdRead.cc:132
looper.cfg
cfg
Definition: looper.py:297
AlCaRecoTriggerBitsRcdRead::outputType_
const OutputType outputType_
Definition: AlCaRecoTriggerBitsRcdRead.cc:59
AlCaRecoTriggerBitsRcdRead::stringToEnum
OutputType stringToEnum(const std::string &outputType) const
Definition: AlCaRecoTriggerBitsRcdRead.cc:98
std
Definition: JetResolutionObject.h:76
writedatasetfile.run
run
Definition: writedatasetfile.py:27
AlCaRecoTriggerBitsRcdRead
Definition: AlCaRecoTriggerBitsRcdRead.cc:41
AlCaRecoTriggerBits::m_alcarecoToTrig
std::map< std::string, std::string > m_alcarecoToTrig
Definition: AlCaRecoTriggerBits.h:21
ESWatcher.h
Exception
Definition: hltDiff.cc:245
AlCaRecoTriggerBitsRcdRead::watcher_
edm::ESWatcher< AlCaRecoTriggerBitsRcd > watcher_
Definition: AlCaRecoTriggerBitsRcdRead.cc:60
EventSetup.h
Skims_PA_cff.paths
paths
Definition: Skims_PA_cff.py:18
Exception.h
ParameterSet.h
AlCaRecoTriggerBitsRcdRead::OutputType
OutputType
Definition: AlCaRecoTriggerBitsRcdRead.cc:52
edm::Event
Definition: Event.h:73