CMS 3D CMS Logo

DQMDcsInfo.cc
Go to the documentation of this file.
1 /*
2  * \file DQMDcsInfo.cc
3  * \author A.Meyer - DESY
4  * Last Update:
5  *
6  */
7 
8 #include "DQMDcsInfo.h"
13 
14 // Framework
15 
17 {
18 
19  parameters_ = ps;
20 
21  subsystemname_ = parameters_.getUntrackedParameter<std::string>("subSystemFolder", "Info") ;
22  dcsinfofolder_ = parameters_.getUntrackedParameter<std::string>("dcsInfoFolder", "DcsInfo") ;
23  gtCollection_ = consumes<L1GlobalTriggerReadoutRecord>(parameters_.getUntrackedParameter<std::string>("gtCollection","gtDigis"));
24  dcsStatusCollection_ = consumes<DcsStatusCollection>(parameters_.getUntrackedParameter<std::string>("dcsStatusCollection","scalersRawToDigi"));
25 
26  // initialize
27  for (bool & dc : dcs) dc=true;
28 }
29 
30 DQMDcsInfo::~DQMDcsInfo() = default;
31 
33  edm::Run const & /* iRun */,
34  edm::EventSetup const & /* iSetup */) {
35 
36  // Fetch GlobalTag information and fill the string/ME.
37  ibooker.cd();
38  ibooker.setCurrentFolder(subsystemname_ +"/CMSSWInfo/");
39 
40  const edm::ParameterSet &globalTagPSet =
42  .getParameterSet("PoolDBESSource@GlobalTag");
43 
44  ibooker.bookString("globalTag_Step1", globalTagPSet.getParameter<std::string>("globaltag"));
45 
46  ibooker.cd();
48 
49  DCSbyLS_ = ibooker.book1D("DCSbyLS","DCS",25,0.,25.);
51 
52  // initialize
53  for (bool & dc : dcs) dc=true;
54 }
55 
57 
58  makeDcsInfo(e);
59  makeGtInfo(e);
60 
61  return;
62 }
63 
64 void
66 {
67  // int nlumi = l.id().luminosityBlock();
68 
69  // fill dcs vs lumi
70  /* set those bins 0 for which bits are ON
71  needed for merge off lumi histograms across files */
72  for (int i=0;i<25;i++)
73  {
74  if (dcs[i])
75  DCSbyLS_->setBinContent(i+1,0.);
76  else
77  DCSbyLS_->setBinContent(i+1,1.);
78 
79  dcs[i]=true;
80  }
81 
82  return;
83 }
84 
85 void
87 {
88 
90  if ( ! e.getByToken(dcsStatusCollection_, dcsStatus) )
91  {
92  for (int i=0;i<24;i++) dcs[i]=false;
93  return;
94  }
95 
96  if ( ! dcsStatus.isValid() )
97  {
98  edm::LogWarning("DQMDcsInfo") << "scalersRawToDigi not found" ;
99  for (int i=0;i<24;i++) dcs[i]=false; // info not available: set to false
100  return;
101  }
102 
103  for (auto const & dcsStatusItr : *dcsStatus)
104  {
105  if (!dcsStatusItr.ready(DcsStatus::CSCp)) dcs[0]=false;
106  if (!dcsStatusItr.ready(DcsStatus::CSCm)) dcs[1]=false;
107  if (!dcsStatusItr.ready(DcsStatus::DT0)) dcs[2]=false;
108  if (!dcsStatusItr.ready(DcsStatus::DTp)) dcs[3]=false;
109  if (!dcsStatusItr.ready(DcsStatus::DTm)) dcs[4]=false;
110  if (!dcsStatusItr.ready(DcsStatus::EBp)) dcs[5]=false;
111  if (!dcsStatusItr.ready(DcsStatus::EBm)) dcs[6]=false;
112  if (!dcsStatusItr.ready(DcsStatus::EEp)) dcs[7]=false;
113  if (!dcsStatusItr.ready(DcsStatus::EEm)) dcs[8]=false;
114  if (!dcsStatusItr.ready(DcsStatus::ESp)) dcs[9]=false;
115  if (!dcsStatusItr.ready(DcsStatus::ESm)) dcs[10]=false;
116  if (!dcsStatusItr.ready(DcsStatus::HBHEa)) dcs[11]=false;
117  if (!dcsStatusItr.ready(DcsStatus::HBHEb)) dcs[12]=false;
118  if (!dcsStatusItr.ready(DcsStatus::HBHEc)) dcs[13]=false;
119  if (!dcsStatusItr.ready(DcsStatus::HF)) dcs[14]=false;
120  if (!dcsStatusItr.ready(DcsStatus::HO)) dcs[15]=false;
121  if (!dcsStatusItr.ready(DcsStatus::BPIX)) dcs[16]=false;
122  if (!dcsStatusItr.ready(DcsStatus::FPIX)) dcs[17]=false;
123  if (!dcsStatusItr.ready(DcsStatus::RPC)) dcs[18]=false;
124  if (!dcsStatusItr.ready(DcsStatus::TIBTID)) dcs[19]=false;
125  if (!dcsStatusItr.ready(DcsStatus::TOB)) dcs[20]=false;
126  if (!dcsStatusItr.ready(DcsStatus::TECp)) dcs[21]=false;
127  if (!dcsStatusItr.ready(DcsStatus::TECm)) dcs[22]=false;
128  if (!dcsStatusItr.ready(DcsStatus::CASTOR)) dcs[23]=false;
129  }
130 
131  return ;
132 }
133 
134 void
136 {
137 
139  if ( ! e.getByToken(gtCollection_, gtrr_handle) )
140  {
141  dcs[24]=false; // info not available: set to false
142  return;
143  }
144 
145  if ( ! gtrr_handle.isValid() )
146  {
147  edm::LogWarning("DQMDcsInfo") << " gtDigis not found" ;
148  dcs[24]=false; // info not available: set to false
149  return;
150  }
151 
152  L1GlobalTriggerReadoutRecord const* gtrr = gtrr_handle.product();
153  L1GtFdlWord fdlWord ;
154  if (gtrr)
155  fdlWord = gtrr->gtFdlWord();
156  else
157  {
158  edm::LogWarning ("DQMDcsInfo") << " phys decl. bit not accessible !!!";
159  dcs[24]=false; // info not available: set to false
160  return;
161  }
162 
163  if (fdlWord.physicsDeclared() !=1) dcs[24]=false;
164 
165  return;
166 }
T getParameter(std::string const &) const
T getUntrackedParameter(std::string const &, T const &) const
void setBinContent(int binx, double content)
set content of bin (1-D)
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:579
MonitorElement * bookString(Args &&...args)
Definition: DQMStore.h:100
void endLuminosityBlock(const edm::LuminosityBlock &l, const edm::EventSetup &c) override
Definition: DQMDcsInfo.cc:65
ModuleDescription const & moduleDescription() const
ParameterSet const & getProcessParameterSetContainingModule(ModuleDescription const &moduleDescription)
return((rh^lh)&mask)
void setLumiFlag()
this ME is meant to be stored for each luminosity section
MonitorElement * book1D(Args &&...args)
Definition: DQMStore.h:118
bool isValid() const
Definition: HandleBase.h:74
edm::EDGetTokenT< L1GlobalTriggerReadoutRecord > gtCollection_
Definition: DQMDcsInfo.h:50
edm::ParameterSet parameters_
Definition: DQMDcsInfo.h:47
bool dcs[25]
Definition: DQMDcsInfo.h:53
void analyze(const edm::Event &e, const edm::EventSetup &c) override
Analyze.
Definition: DQMDcsInfo.cc:56
void setCurrentFolder(const std::string &fullpath)
Definition: DQMStore.cc:274
T const * product() const
Definition: Handle.h:81
void bookHistograms(DQMStore::IBooker &, edm::Run const &, edm::EventSetup const &) override
Definition: DQMDcsInfo.cc:32
const L1GtFdlWord gtFdlWord(int bxInEventValue) const
get / set FDL word (record) in the GT readout record
ParameterSet const & getParameterSet(std::string const &) const
std::string dcsinfofolder_
Definition: DQMDcsInfo.h:49
const cms_uint16_t physicsDeclared() const
get/set "physics declared" bit
Definition: L1GtFdlWord.h:227
void makeDcsInfo(const edm::Event &e)
Definition: DQMDcsInfo.cc:86
std::string subsystemname_
Definition: DQMDcsInfo.h:48
DQMDcsInfo(const edm::ParameterSet &ps)
Constructor.
Definition: DQMDcsInfo.cc:16
~DQMDcsInfo() override
Destructor.
MonitorElement * DCSbyLS_
Definition: DQMDcsInfo.h:55
edm::EDGetTokenT< DcsStatusCollection > dcsStatusCollection_
Definition: DQMDcsInfo.h:51
void makeGtInfo(const edm::Event &e)
Definition: DQMDcsInfo.cc:135
Definition: Run.h:44