CMS 3D CMS Logo

List of all members | Public Member Functions | Private Attributes
SiStripCablingDQM Class Reference

#include <SiStripCablingDQM.h>

Inheritance diagram for SiStripCablingDQM:
SiStripBaseCondObjDQM

Public Member Functions

void fillMEsForDet (const ModMEs &selModME_, uint32_t selDetId_, const TrackerTopology *tTopo) override
 
void fillMEsForLayer (uint32_t selDetId_, const TrackerTopology *tTopo) override
 
void fillModMEs (const std::vector< uint32_t > &selectedDetIds, const edm::EventSetup &es) override
 
void fillSummaryMEs (const std::vector< uint32_t > &selectedDetIds, const edm::EventSetup &es) override
 
void getActiveDetIds (const edm::EventSetup &eSetup) override
 
unsigned long long getCache (const edm::EventSetup &eSetup) override
 
void getConditionObject (const edm::EventSetup &eSetup) override
 
 SiStripCablingDQM (const edm::EventSetup &eSetup, edm::RunNumber_t iRun, edm::ParameterSet const &hPSet, edm::ParameterSet const &fPSet)
 
 ~SiStripCablingDQM () override
 
- Public Member Functions inherited from SiStripBaseCondObjDQM
void analysis (const edm::EventSetup &eSetup_)
 
void analysisOnDemand (const edm::EventSetup &eSetup_, uint32_t detIdOnDemand)
 
void analysisOnDemand (const edm::EventSetup &eSetup_, const std::vector< uint32_t > &detIdsOnDemand)
 
void analysisOnDemand (const edm::EventSetup &eSetup_, std::string requestedSubDetector, uint32_t requestedSide, uint32_t requestedLayer)
 
virtual void end ()
 
std::vector< uint32_t > getCabledModules ()
 
void selectModules (std::vector< uint32_t > &detIds_, const TrackerTopology *tTopo)
 
 SiStripBaseCondObjDQM (const edm::EventSetup &eSetup, edm::RunNumber_t iRun, edm::ParameterSet const &hPSet, edm::ParameterSet const &fPSet)
 
virtual ~SiStripBaseCondObjDQM ()
 

Private Attributes

edm::ESHandle< SiStripDetCablingcablingHandle_
 

Additional Inherited Members

- Protected Member Functions inherited from SiStripBaseCondObjDQM
void fillTkMap (const uint32_t &detid, const float &value)
 
std::pair< std::string, uint32_t > getLayerNameAndId (const uint32_t &detId_, const TrackerTopology *tTopo)
 
void getModMEs (ModMEs &CondObj_ME, const uint32_t &detId_, const TrackerTopology *tTopo)
 
std::vector< uint32_t > GetSameLayerDetId (const std::vector< uint32_t > &activeDetIds, uint32_t selDetId, const TrackerTopology *tTopo)
 
std::pair< std::string, uint32_t > getStringNameAndId (const uint32_t &detId_, const TrackerTopology *tTopo)
 
void getSummaryMEs (ModMEs &CondObj_ME, const uint32_t &detId_, const TrackerTopology *tTopo)
 
- Protected Attributes inherited from SiStripBaseCondObjDQM
std::vector< uint32_t > activeDetIds
 
std::vector< uint32_t > all_DetIds
 
unsigned long long cacheID_current
 
unsigned long long cacheID_memory
 
std::string CondObj_fillId_
 
std::string CondObj_name_
 
const edm::EventSetupeSetup_
 
edm::ParameterSet fPSet_
 
bool GrandSummary_On_
 
bool HistoMaps_On_
 
edm::ParameterSet hPSet_
 
double maxValue
 
double minValue
 
bool Mod_On_
 
std::map< uint32_t, ModMEsModMEsMap_
 
SiStripDetInfoFileReaderreader
 
std::map< uint32_t, ModMEsSummaryMEsMap_
 
bool SummaryOnLayerLevel_On_
 
bool SummaryOnStringLevel_On_
 
std::unique_ptr< TkHistoMapTk_HM_
 
std::unique_ptr< TkHistoMapTk_HM_H
 
std::unique_ptr< TkHistoMapTk_HM_L
 
TrackerMaptkMap
 
std::vector< int > tkMapScaler
 

Detailed Description

Definition at line 15 of file SiStripCablingDQM.h.

Constructor & Destructor Documentation

SiStripCablingDQM::SiStripCablingDQM ( const edm::EventSetup eSetup,
edm::RunNumber_t  iRun,
edm::ParameterSet const &  hPSet,
edm::ParameterSet const &  fPSet 
)

Definition at line 8 of file SiStripCablingDQM.cc.

References edm::EventSetup::get(), SiStripBaseCondObjDQM::HistoMaps_On_, edm::ESHandle< T >::product(), and SiStripBaseCondObjDQM::Tk_HM_.

11  :SiStripBaseCondObjDQM(eSetup, iRun, hPSet, fPSet){
12 
13  // Build the Histo_TkMap:
14  if ( HistoMaps_On_ ) {
15  edm::ESHandle<TkDetMap> tkDetMapHandle;
16  eSetup.get<TrackerTopologyRcd>().get(tkDetMapHandle);
17  Tk_HM_ = std::make_unique<TkHistoMap>(tkDetMapHandle.product(), "SiStrip/Histo_Map","Cabling_TkMap",0.);
18  }
19 }
SiStripBaseCondObjDQM(const edm::EventSetup &eSetup, edm::RunNumber_t iRun, edm::ParameterSet const &hPSet, edm::ParameterSet const &fPSet)
const T & get() const
Definition: EventSetup.h:59
T const * product() const
Definition: ESHandle.h:86
std::unique_ptr< TkHistoMap > Tk_HM_
SiStripCablingDQM::~SiStripCablingDQM ( )
override

Definition at line 23 of file SiStripCablingDQM.cc.

23 {}

Member Function Documentation

void SiStripCablingDQM::fillMEsForDet ( const ModMEs selModME_,
uint32_t  selDetId_,
const TrackerTopology tTopo 
)
inlineoverridevirtual

Implements SiStripBaseCondObjDQM.

Definition at line 29 of file SiStripCablingDQM.h.

29 {;}
void SiStripCablingDQM::fillMEsForLayer ( uint32_t  selDetId_,
const TrackerTopology tTopo 
)
inlineoverridevirtual

Implements SiStripBaseCondObjDQM.

Definition at line 30 of file SiStripCablingDQM.h.

References getActiveDetIds().

30 {;}
void SiStripCablingDQM::fillModMEs ( const std::vector< uint32_t > &  selectedDetIds,
const edm::EventSetup es 
)
inlineoverridevirtual

Reimplemented from SiStripBaseCondObjDQM.

Definition at line 26 of file SiStripCablingDQM.h.

26 {;}
void SiStripCablingDQM::fillSummaryMEs ( const std::vector< uint32_t > &  selectedDetIds,
const edm::EventSetup es 
)
inlineoverridevirtual

Reimplemented from SiStripBaseCondObjDQM.

Definition at line 27 of file SiStripCablingDQM.h.

27 {;}
void SiStripCablingDQM::getActiveDetIds ( const edm::EventSetup eSetup)
overridevirtual

Implements SiStripBaseCondObjDQM.

Definition at line 29 of file SiStripCablingDQM.cc.

References SiStripBaseCondObjDQM::activeDetIds, SiStripDetCabling::addActiveDetectorsRawIds(), SiStripDetCabling::addAllDetectorsRawIds(), alignmentValidation::c1, cablingHandle_, fastjetJetProducer_validation_cfg::DQMStore, SiStripBaseCondObjDQM::dqmStore_, MonitorElement::Fill(), SiStripBaseCondObjDQM::fillTkMap(), SiStripBaseCondObjDQM::fPSet_, edm::EventSetup::get(), getConditionObject(), SiStripDetCabling::getConnections(), edm::ParameterSet::getParameter(), MonitorElement::getTH1(), SiStripBaseCondObjDQM::HistoMaps_On_, SiStripBaseCondObjDQM::hPSet_, mps_fire::i, edm::ESHandleBase::isValid(), dataset::name, SiStripDetCabling::nApvPairs(), Utilities::operator, edm::ESHandle< T >::product(), MonitorElement::setAxisTitle(), AlCaHLTBitMon_QueryRunRegistry::string, DetId::subdetId(), StripSubdetector::TEC, TrackerTopology::tecSide(), TrackerTopology::tecWheel(), StripSubdetector::TIB, TrackerTopology::tibLayer(), StripSubdetector::TID, TrackerTopology::tidSide(), TrackerTopology::tidWheel(), SiStripBaseCondObjDQM::Tk_HM_, StripSubdetector::TOB, and TrackerTopology::tobLayer().

Referenced by fillMEsForLayer().

29  {
30 
31  //Retrieve tracker topology from geometry
33  eSetup.get<TrackerTopologyRcd>().get(tTopoHandle);
34  const TrackerTopology* const tTopo = tTopoHandle.product();
35 
36  // Get active and total detIds
37  getConditionObject(eSetup);
38  if(!cablingHandle_.isValid()) {
39  edm::LogError("InvalidCablingHandle") << "Invalid Cabling Handle";
40  return;
41  }
44 
45 
46  //Initialize arrays for counting:
47  int counterTIB[4];
48  for(int i=0;i<4;i++) counterTIB[i]=0;
49  int counterTID[2][3];
50  for(int i=0;i<2;i++){
51  for(int j=0;j<3;j++)counterTID[i][j]=0;
52  }
53  int counterTOB[6];
54  for(int i=0;i<6;i++)counterTOB[i]=0;
55  int counterTEC[2][9];
56  for(int i=0;i<2;i++){
57  for(int j=0;j<9;j++)counterTEC[i][j]=0;
58  }
59 
60 
61 
62  std::vector<uint32_t>::const_iterator idet=activeDetIds.begin();
63 
64  //fill arrays for counting and fill Histo_Map with value for connected :
65  for(;idet!=activeDetIds.end();++idet){
66  uint32_t detId = *idet;
67  StripSubdetector subdet(detId);
68 
69  if(HistoMaps_On_ ) {Tk_HM_->fill(detId, cablingHandle_->nApvPairs(detId)*2);}
70  if(fPSet_.getParameter<bool>("TkMap_On") || hPSet_.getParameter<bool>("TkMap_On")){
71 
72  int32_t n_conn = 0;
73  for(uint32_t connDet_i=0; connDet_i<cablingHandle_->getConnections(detId).size(); connDet_i++){
74  if(cablingHandle_->getConnections(detId)[connDet_i]!=nullptr && cablingHandle_->getConnections(detId)[connDet_i]->isConnected()!=0) n_conn++;
75  }
76  fillTkMap(detId,n_conn*2.);
77  }
78  switch (subdet.subdetId())
79  {
81  {
82  int i = tTopo->tibLayer(detId) - 1;
83  counterTIB[i]++;
84  break;
85  }
87  {
88  int j = tTopo->tidWheel(detId) - 1;
89  int side = tTopo->tidSide(detId);
90  if (side == 2) {
91  counterTID[0][j]++;
92  } else if (side == 1) {
93  counterTID[1][j]++;
94  }
95  break;
96  }
98  {
99  int i = tTopo->tobLayer(detId) - 1;
100  counterTOB[i]++;
101  break;
102  }
104  {
105  int j = tTopo->tecWheel(detId) - 1;
106  int side = tTopo->tecSide(detId);
107  if (side == 2) {
108  counterTEC[0][j]++;
109  } else if (side == 1) {
110  counterTEC[1][j]++;
111  }
112  break;
113  }
114  }
115 
116  } // idet
117 
118  //obtained from tracker.dat and hard-coded
119  int TIBDetIds[4]={672,864,540,648};
120  int TIDDetIds[2][3]={{136,136,136},{136,136,136}};
121  int TOBDetIds[6]={1008,1152,648,720,792,888};
122  int TECDetIds[2][9]={{408,408,408,360,360,360,312,312,272},{408,408,408,360,360,360,312,312,272}};
123 
124 
125 
127 
128  std::string FolderName=fPSet_.getParameter<std::string>("FolderName_For_QualityAndCabling_SummaryHistos");
129 
130  dqmStore_->setCurrentFolder(FolderName);
131 
132  // dqmStore_->cd("SiStrip/MechanicalView/");
134  ME = dqmStore_->book2D("SummaryOfCabling","SummaryOfCabling",6,0.5,6.5,9,0.5,9.5);
135  ME->setAxisTitle("Sub Det",1);
136  ME->setAxisTitle("Layer",2);
137 
138 
139  ME->getTH1()->GetXaxis()->SetBinLabel(1,"TIB");
140  ME->getTH1()->GetXaxis()->SetBinLabel(2,"TID F");
141  ME->getTH1()->GetXaxis()->SetBinLabel(3,"TID B");
142  ME->getTH1()->GetXaxis()->SetBinLabel(4,"TOB");
143  ME->getTH1()->GetXaxis()->SetBinLabel(5,"TEC F");
144  ME->getTH1()->GetXaxis()->SetBinLabel(6,"TEC B");
145 
146  for(int i=0;i<4;i++){
147  ME->Fill(1,i+1,float(counterTIB[i])/TIBDetIds[i]);
148  }
149 
150  for(int i=0;i<2;i++){
151  for(int j=0;j<3;j++){
152  ME->Fill(i+2,j+1,float(counterTID[i][j])/TIDDetIds[i][j]);
153  }
154  }
155 
156  for(int i=0;i<6;i++){
157  ME->Fill(4,i+1,float(counterTOB[i])/TOBDetIds[i]);
158  }
159 
160  for(int i=0;i<2;i++){
161  for(int j=0;j<9;j++){
162  ME->Fill(i+5,j+1,float(counterTEC[i][j])/TECDetIds[i][j]);
163  }
164  }
165 
166  if (fPSet_.getParameter<bool>("OutputSummaryAtLayerLevelAsImage")){
167 
168  TCanvas c1("c1");
169  ME->getTH1()->Draw("TEXT");
170  ME->getTH1()->SetStats(kFALSE);
171  std::string name (ME->getTH1()->GetTitle());
172  name+=".png";
173  c1.Print(name.c_str());
174  }
175 
176 }
T getParameter(std::string const &) const
void addActiveDetectorsRawIds(std::vector< uint32_t > &) const
unsigned int tibLayer(const DetId &id) const
void getConditionObject(const edm::EventSetup &eSetup) override
TH1 * getTH1() const
unsigned int tidWheel(const DetId &id) const
void fillTkMap(const uint32_t &detid, const float &value)
void Fill(long long x)
const std::vector< const FedChannelConnection * > & getConnections(uint32_t det_id) const
unsigned int tidSide(const DetId &id) const
edm::ESHandle< SiStripDetCabling > cablingHandle_
const T & get() const
Definition: EventSetup.h:59
const uint16_t nApvPairs(uint32_t det_id) const
MonitorElement ME
std::vector< uint32_t > activeDetIds
bool isValid() const
Definition: ESHandle.h:47
void addAllDetectorsRawIds(std::vector< uint32_t > &vector_to_fill_with_detids) const
unsigned int tecWheel(const DetId &id) const
void setAxisTitle(const std::string &title, int axis=1)
set x-, y- or z-axis title (axis=1, 2, 3 respectively)
T const * product() const
Definition: ESHandle.h:86
std::unique_ptr< TkHistoMap > Tk_HM_
unsigned int tobLayer(const DetId &id) const
unsigned int tecSide(const DetId &id) const
unsigned long long SiStripCablingDQM::getCache ( const edm::EventSetup eSetup)
inlineoverridevirtual

Implements SiStripBaseCondObjDQM.

Definition at line 33 of file SiStripCablingDQM.h.

References edm::EventSetup::get().

33 { return eSetup.get<SiStripDetCablingRcd>().cacheIdentifier();}
const T & get() const
Definition: EventSetup.h:59
void SiStripCablingDQM::getConditionObject ( const edm::EventSetup eSetup)
inlineoverridevirtual

Member Data Documentation

edm::ESHandle<SiStripDetCabling> SiStripCablingDQM::cablingHandle_
private

Definition at line 45 of file SiStripCablingDQM.h.

Referenced by getActiveDetIds(), and getConditionObject().