CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
SiStripMonitorQuality.cc
Go to the documentation of this file.
1 // -*- C++ -*-
2 //
3 // Package: SiStripMonitorQuality
4 // Class: SiStripMonitorQuality
5 //
13 //
14 // Original Author: Suchandra Dutta
15 // Created: Fri Dec 7 20:50 CET 2007
16 //
17 //
18 
20 
23 
30 
31 
34 
36 
37 // std
38 #include <cstdlib>
39 #include <cmath>
40 #include <numeric>
41 #include <algorithm>
42 
44  dqmStore_(edm::Service<DQMStore>().operator->()),
45  conf_(iConfig),
46  m_cacheID_(0)
47 
48 
49 {
50  edm::LogInfo("SiStripMonitorQuality") <<"SiStripMonitorQuality "
51  << " Constructing....... ";
52 }
53 
54 
56 {
57  edm::LogInfo("SiStripMonitorQuality") <<"SiStripMonitorQuality "
58  << " Destructing....... ";
59 }
60 //
61 // -- Begin Job
62 //
64 }
65 //
66 // -- BeginRun
67 //
69 }
70 
71 
72 // ------------ method called to produce the data ------------
74 {
75  unsigned long long cacheID = eSetup.get<SiStripQualityRcd>().cacheIdentifier();
76  if (m_cacheID_ == cacheID) return;
77 
78  //Retrieve tracker topology from geometry
80  eSetup.get<IdealGeometryRecord>().get(tTopoHandle);
81  const TrackerTopology* const tTopo = tTopoHandle.product();
82 
83  m_cacheID_ = cacheID;
84 
85  std::string quality_label = conf_.getParameter<std::string>("StripQualityLabel");
86  eSetup.get<SiStripQualityRcd>().get(quality_label,stripQuality_);
87  eSetup.get<SiStripDetCablingRcd>().get( detCabling_ );
88 
89  edm::LogInfo("SiStripMonitorQuality") << "SiStripMonitorQuality::analyze: "<<
90  " Reading SiStripQuality "<< std::endl;
91 
92  SiStripBadStrip::RegistryIterator rbegin = stripQuality_->getRegistryVectorBegin();
93  SiStripBadStrip::RegistryIterator rend = stripQuality_->getRegistryVectorEnd();
94  uint32_t detid;
95 
96  if (rbegin==rend) return;
97 
98  for (SiStripBadStrip::RegistryIterator rp=rbegin; rp != rend; ++rp) {
99 
100  detid = rp->detid;
101  // Check consistency in DetId
102  if (detid == 0 || detid == 0xFFFFFFFF){
103  edm::LogError("SiStripMonitorQuality") <<"SiStripMonitorQuality::analyze : "
104  << "Wrong DetId !!!!!! " << detid << " Neglecting !!!!!! ";
105  continue;
106  }
107  // check if the detid is connected in cabling
108  if (!detCabling_->IsConnected(detid)) {
109  edm::LogError("SiStripMonitorQuality") <<"SiStripMonitorQuality::analyze : "
110  << " DetId " << detid << " not connected, Neglecting !!!!!! ";
111  continue;
112  }
113  MonitorElement* me = getQualityME(detid, tTopo);
114  SiStripBadStrip::Range range = SiStripBadStrip::Range( stripQuality_->getDataVectorBegin()+rp->ibegin ,
115  stripQuality_->getDataVectorBegin()+rp->iend );
116  SiStripBadStrip::ContainerIterator it=range.first;
117  for(;it!=range.second;++it){
118  unsigned int value=(*it);
119  short str_start = stripQuality_->decode(value).firstStrip;
120  short str_end = str_start + stripQuality_->decode(value).range;
121  for ( short isr = str_start; isr < str_end + 1; isr++) {
122  if (isr <= (me->getNbinsX()-1)) me->Fill(isr+1, 1.0);
123  }
124  }
125  }
126 }
127 //
128 // -- End Run
129 //
131  bool outputMEsInRootFile = conf_.getParameter<bool>("OutputMEsInRootFile");
133  if (outputMEsInRootFile) {
135  dqmStore_->save(outputFileName);
136  }
137 }
138 //
139 // -- End Job
140 //
142  edm::LogInfo("SiStripMonitorQuality") <<"SiStripMonitorQuality::EndJob: "
143  << " Finishing!! ";
144 }
145 //
146 // -- End Job
147 //
149 
150  std::map<uint32_t, MonitorElement* >::iterator pos = QualityMEs.find(idet);
151  MonitorElement* det_me;
152  if (pos != QualityMEs.end()) {
153  det_me = pos->second;
154  det_me->Reset();
155  } else {
156  int nStrip = detCabling_->nApvPairs(idet) * 256;
157 
158  // use SistripHistoId for producing histogram id (and title)
159  SiStripHistoId hidmanager;
160  // create SiStripFolderOrganizer
161  SiStripFolderOrganizer folder_organizer;
162  // set appropriate folder using SiStripFolderOrganizer
163  folder_organizer.setDetectorFolder(idet, tTopo); // pass the detid to this method
164 
165  std::string hid;
166  hid = hidmanager.createHistoId("StripQualityFromCondDB","det", idet);
167 
168  det_me = dqmStore_->book1D(hid, hid, nStrip,0.5,nStrip+0.5);
169  dqmStore_->tag(det_me, idet);
170  det_me->setAxisTitle("Strip Number",1);
171  det_me->setAxisTitle("Quality Flag from CondDB ",2);
172  QualityMEs.insert( std::make_pair(idet, det_me));
173  }
174  return det_me;
175 }
177 
T getParameter(std::string const &) const
edm::ESHandle< SiStripDetCabling > detCabling_
MonitorElement * book1D(const char *name, const char *title, int nchX, double lowX, double highX)
Book 1D histogram.
Definition: DQMStore.cc:872
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:17
std::vector< unsigned int >::const_iterator ContainerIterator
Registry::const_iterator RegistryIterator
void Fill(long long x)
void setDetectorFolder(uint32_t rawdetid, const TrackerTopology *tTopo)
void tag(MonitorElement *me, unsigned int myTag)
Definition: DQMStore.cc:1509
int iEvent
Definition: GenABIO.cc:243
MonitorElement * getQualityME(uint32_t idet, const TrackerTopology *tTopo)
edm::ESHandle< SiStripQuality > stripQuality_
virtual void beginRun(edm::Run const &run, edm::EventSetup const &eSetup)
void save(const std::string &filename, const std::string &path="", const std::string &pattern="", const std::string &rewrite="", const uint32_t run=0, SaveReferenceTag ref=SaveWithReference, int minStatus=dqm::qstatus::STATUS_OK, const std::string &fileupdate="RECREATE")
Definition: DQMStore.cc:2296
virtual void endRun(edm::Run const &run, edm::EventSetup const &eSetup)
std::string createHistoId(std::string description, std::string id_type, uint32_t component_id)
const T & get() const
Definition: EventSetup.h:55
T const * product() const
Definition: ESHandle.h:62
SiStripMonitorQuality(const edm::ParameterSet &)
virtual void analyze(const edm::Event &, const edm::EventSetup &)
std::pair< ContainerIterator, ContainerIterator > Range
unsigned long long m_cacheID_
int getNbinsX(void) const
get # of bins in X-axis
void showDirStructure(void) const
Definition: DQMStore.cc:2961
void setAxisTitle(const std::string &title, int axis=1)
set x-, y- or z-axis title (axis=1, 2, 3 respectively)
void Reset(void)
reset ME (ie. contents, errors, etc)
std::map< uint32_t, MonitorElement * > QualityMEs
Definition: Run.h:41