CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
SiStripOfflineDQM.cc
Go to the documentation of this file.
1 // -*- C++ -*-
2 //
3 // Package: SiStripMonitorCluster
4 // Class: SiStripOfflineDQM
5 //
13 //
14 // Original Author: Samvel Khalatyan (ksamdev at gmail dot com)
15 // Created: Wed Oct 5 16:42:34 CET 2006
16 //
17 //
18 
20 
21 
26 
28 
30 
32 
35 
37 
38 //Run Info
42 // Cabling
45 //#include "CondFormats/SiStripObjects/interface/SiStripFedCabling.h"
46 
47 #include <iostream>
48 #include <iomanip>
49 #include <stdio.h>
50 #include <string>
51 #include <sstream>
52 #include <math.h>
53 
54 
63  // Create MessageSender
64 
65  // Action Executor
67 
68  // get back-end interface
70 
71  usedWithEDMtoMEConverter_= configPar_.getUntrackedParameter<bool>("UsedWithEDMtoMEConverter",false);
72  createSummary_ = configPar_.getUntrackedParameter<bool>("CreateSummary",false);
73  createTkInfoFile_ = configPar_.getUntrackedParameter<bool>("CreateTkInfoFile",false);
75  globalStatusFilling_ = configPar_.getUntrackedParameter<int>("GlobalStatusFilling", 1);
76  printFaultyModuleList_ = configPar_.getUntrackedParameter<bool>("PrintFaultyModuleList", false);
77 
78  nEvents_ = 0;
79 
80  tkinfoTree_ = 0;
82 
83  if(createTkInfoFile_) tkinfoTree_ = fs->make<TTree>("TkDetIdInfo", "");
84 
85 }
92 
93 }
102 
103  // Essential: reads xml file to get the histogram names to create summary
104  // Read the summary configuration file
105  if (createSummary_) {
107  edm::LogInfo ("ReadConfigurationProblem") <<"SiStripOfflineDQM:: Error to read configuration file!! Summary will not be produced!!!";
108  createSummary_ = false;
109  }
110  }
111  edm::LogInfo("BeginJobDone") << "SiStripOfflineDQM::beginJob done";
112 }
123  edm::LogInfo ("BeginRun") <<"SiStripOfflineDQM:: Begining of Run";
124 
125  int nFEDs = 0;
127  if( eSetup.find( recordKey ) != 0) {
128 
129  edm::ESHandle<RunInfo> sumFED;
130  eSetup.get<RunInfoRcd>().get(sumFED);
131  if ( sumFED.isValid() ) {
132 
133  const int siStripFedIdMin = FEDNumbering::MINSiStripFEDID;
134  const int siStripFedIdMax = FEDNumbering::MAXSiStripFEDID;
135 
136  std::vector<int> FedsInIds= sumFED->m_fed_in;
137  for(unsigned int it = 0; it < FedsInIds.size(); ++it) {
138  int fedID = FedsInIds[it];
139 
140  if(fedID>=siStripFedIdMin && fedID<=siStripFedIdMax) ++nFEDs;
141  }
142  }
143  }
144  if (nFEDs > 0) trackerFEDsFound_ = true;
145  else trackerFEDsFound_ = false;
147  if (!openInputFile()) createSummary_ = false;
148  }
150 }
163  nEvents_++;
164 }
172  edm::LogInfo( "EndLumiBlock") << "SiStripOfflineDQM::endLuminosityBlock";
173  if (trackerFEDsFound_) {
175  }
176 }
184 
185  edm::LogInfo( "EndOfRun") << "SiStripOfflineDQM::endRun";
186 
187  // Access Cabling
189  eSetup.get<SiStripDetCablingRcd>().get(det_cabling);
190  // edm::ESHandle< SiStripFedCabling > fed_cabling;
191  // eSetup.get<SiStripFedCablingRcd>().get(fed_cabling);
193 
194  if (!trackerFEDsFound_) {
196  return;
197  }
198 
199  // Fill Global Status
200  if (globalStatusFilling_ > 0) actionExecutor_->fillStatus(dqmStore_, det_cabling, eSetup);
201 
203 
204  // create Summary Plots
206 
207  // Create TrackerMap
208  bool create_tkmap = configPar_.getUntrackedParameter<bool>("CreateTkMap",false);
209  if (create_tkmap) {
210  std::vector<edm::ParameterSet> tkMapOptions = configPar_.getUntrackedParameter< std::vector<edm::ParameterSet> >("TkMapOptions" );
212  std::vector<std::string> map_names;
213  for(std::vector<edm::ParameterSet>::iterator it = tkMapOptions.begin(); it != tkMapOptions.end(); ++it) {
214  edm::ParameterSet tkMapPSet = *it;
215  std::string map_type = it->getUntrackedParameter<std::string>("mapName","");
216  map_names.push_back(map_type);
217  tkMapPSet.augment(configPar_.getUntrackedParameter<edm::ParameterSet>("TkmapParameters"));
218  edm::LogInfo("TkMapParameters") << tkMapPSet;
219  actionExecutor_->createOfflineTkMap(tkMapPSet, dqmStore_, map_type, eSetup);
220  }
221  if(createTkInfoFile_) {
223  }
224  }
225  }
226 
227  }
228 }
236 
237  edm::LogInfo( "EndOfJob") << "SiStripOfflineDQM::endJob";
240  std::ostringstream str_val;
242  std::cout << str_val.str() << std::endl;
243  }
244  }
245 }
253  if (inputFileName_.size() == 0) return false;
254  edm::LogInfo("OpenFile") << "SiStripOfflineDQM::openInputFile: Accessing root File" << inputFileName_;
255  dqmStore_->open(inputFileName_, false);
256  return true;
257 }
258 
virtual ~SiStripOfflineDQM()
Destructor.
T getUntrackedParameter(std::string const &, T const &) const
SiStripActionExecutor * actionExecutor_
void analyze(edm::Event const &e, edm::EventSetup const &eSetup)
Analyze.
void createOfflineTkMap(const edm::ParameterSet &tkmapPset, DQMStore *dqm_store, std::string &map_type, const edm::EventSetup &eSetup)
SiStripOfflineDQM(const edm::ParameterSet &ps)
Constructor.
void beginJob()
BeginJob.
void beginRun(edm::Run const &run, edm::EventSetup const &eSetup)
BeginRun.
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:17
void fillStatus(DQMStore *dqm_store, const edm::ESHandle< SiStripDetCabling > &fedcabling, const edm::EventSetup &eSetup)
T * make(const Args &...args) const
make new ROOT object
Definition: TFileService.h:64
void endJob()
Endjob.
bool readTkMapConfiguration(const edm::EventSetup &eSetup)
void createStatus(DQMStore *dqm_store)
const eventsetup::EventSetupRecord * find(const eventsetup::EventSetupRecordKey &) const
Definition: EventSetup.cc:90
void augment(ParameterSet const &from)
void endLuminosityBlock(edm::LuminosityBlock const &lumiSeg, edm::EventSetup const &iSetup)
End Of Luminosity.
std::string inputFileName_
void fillStatusAtLumi(DQMStore *dqm_store)
const T & get() const
Definition: EventSetup.h:55
bool openInputFile()
Open Input File.
void createTkInfoFile(std::vector< std::string > tkhmap_names, TTree *tkinfo_tree, DQMStore *dqm_store)
void endRun(edm::Run const &run, edm::EventSetup const &eSetup)
EndRun.
void createSummaryOffline(DQMStore *dqm_store)
bool open(const std::string &filename, bool overwrite=false, const std::string &path="", const std::string &prepend="", OpenRunDirs stripdirs=KeepRunDirs, bool fileMustExist=true)
Definition: DQMStore.cc:2959
tuple cout
Definition: gather_cfg.py:121
bool isValid() const
Definition: ESHandle.h:47
void printFaultyModuleList(DQMStore *dqm_store, std::ostringstream &str_val)
Definition: Run.h:41
edm::ParameterSet configPar_
static HCTypeTag findType(char const *iTypeName)
find a type based on the types name, if not found will return default HCTypeTag
Definition: HCTypeTag.cc:125