CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
DigiVertexCorrHistogramMaker.cc
Go to the documentation of this file.
7 #include "TH2F.h"
8 #include "TProfile.h"
9 
12 
13 
15  m_fhm(),
16  m_runHisto(false),
17  m_hitname(), m_nbins(500), m_scalefact(), m_maxnvtx(60), m_binmax(), m_labels(), m_nmultvsnvtx(), m_nmultvsnvtxprof(), m_nmultvsnvtxvsbxprofrun(), m_subdirs() { }
18 
20  m_fhm(),
21  m_runHisto(iConfig.getUntrackedParameter<bool>("runHisto",false)),
22  m_hitname(iConfig.getUntrackedParameter<std::string>("hitName","digi")),
23  m_nbins(iConfig.getUntrackedParameter<int>("numberOfBins",500)),
24  m_scalefact(iConfig.getUntrackedParameter<int>("scaleFactor",5)),
25  m_maxnvtx(iConfig.getUntrackedParameter<int>("maxNvtx",60)),
26  m_labels(), m_nmultvsnvtx(), m_nmultvsnvtxprof(), m_subdirs()
27 {
28 
29  std::vector<edm::ParameterSet>
30  wantedsubds(iConfig.getUntrackedParameter<std::vector<edm::ParameterSet> >("wantedSubDets",std::vector<edm::ParameterSet>()));
31 
32  for(std::vector<edm::ParameterSet>::iterator ps=wantedsubds.begin();ps!=wantedsubds.end();++ps) {
33  m_labels[ps->getParameter<unsigned int>("detSelection")] = ps->getParameter<std::string>("detLabel");
34  m_binmax[ps->getParameter<unsigned int>("detSelection")] = ps->getParameter<int>("binMax");
35  }
36 
37 
38 }
39 
40 
42 
43  for(std::map<unsigned int,std::string>::const_iterator lab=m_labels.begin();lab!=m_labels.end();lab++) {
44 
45  const unsigned int i = lab->first; const std::string slab = lab->second;
46 
47  delete m_subdirs[i];
48  delete m_fhm[i];
49  }
50 
51 }
52 
53 
54 
55 void DigiVertexCorrHistogramMaker::book(const std::string dirname, const std::map<unsigned int, std::string>& labels, edm::ConsumesCollector&& iC) {
56 
57  m_labels = labels;
58  book(dirname, iC);
59 
60 }
61 
63 
65  TFileDirectory subev = tfserv->mkdir(dirname);
66 
67  SiStripTKNumbers trnumb;
68 
69  edm::LogInfo("NumberOfBins") << "Number of Bins: " << m_nbins;
70  edm::LogInfo("ScaleFactors") << "y-axis range scale factor: " << m_scalefact;
71  edm::LogInfo("MaxNvtx") << "maximum number of vertices: " << m_maxnvtx;
72  edm::LogInfo("BinMaxValue") << "Setting bin max values";
73 
74  for(std::map<unsigned int,std::string>::const_iterator lab=m_labels.begin();lab!=m_labels.end();lab++) {
75 
76  const unsigned int i = lab->first; const std::string slab = lab->second;
77 
78  if(m_binmax.find(i)==m_binmax.end()) {
79  edm::LogVerbatim("NotConfiguredBinMax") << "Bin max for " << lab->second
80  << " not configured: " << trnumb.nstrips(i) << " used";
81  m_binmax[i] = trnumb.nstrips(i);
82  }
83 
84  edm::LogVerbatim("BinMaxValue") << "Bin max for " << lab->second << " is " << m_binmax[i];
85 
86  }
87 
88  for(std::map<unsigned int,std::string>::const_iterator lab=m_labels.begin();lab!=m_labels.end();++lab) {
89 
90  const int i = lab->first; const std::string slab = lab->second;
91 
92  char name[200];
93  char title[500];
94 
95  m_subdirs[i] = new TFileDirectory(subev.mkdir(slab.c_str()));
96  m_fhm[i] = new RunHistogramManager(iC, true);
97 
98  if(m_subdirs[i]) {
99  sprintf(name,"n%sdigivsnvtx",slab.c_str());
100  sprintf(title,"%s %s multiplicity vs Nvtx",slab.c_str(),m_hitname.c_str());
101  m_nmultvsnvtx[i] = m_subdirs[i]->make<TH2F>(name,title,m_maxnvtx,-0.5,m_maxnvtx-0.5,m_nbins,0.,(1+m_binmax[i]/(m_scalefact*m_nbins))*m_nbins);
102  m_nmultvsnvtx[i]->GetXaxis()->SetTitle("Number of Vertices"); m_nmultvsnvtx[i]->GetYaxis()->SetTitle("Number of Hits");
103  sprintf(name,"n%sdigivsnvtxprof",slab.c_str());
104  m_nmultvsnvtxprof[i] = m_subdirs[i]->make<TProfile>(name,title,m_maxnvtx,-0.5,m_maxnvtx-0.5);
105  m_nmultvsnvtxprof[i]->GetXaxis()->SetTitle("Number of Vertices"); m_nmultvsnvtxprof[i]->GetYaxis()->SetTitle("Number of Hits");
106 
107  if(m_runHisto) {
108  edm::LogInfo("RunHistos") << "Pseudo-booking run histos " << slab.c_str();
109  sprintf(name,"n%sdigivsnvtxvsbxprofrun",slab.c_str());
110  sprintf(title,"%s %s multiplicity vs Nvtx vs BX",slab.c_str(),m_hitname.c_str());
111  m_nmultvsnvtxvsbxprofrun[i] = m_fhm[i]->makeTProfile2D(name,title,3564,-0.5,3563.5,m_maxnvtx,-0.5,m_maxnvtx-0.5);
112  }
113 
114  }
115 
116  }
117 
118 
119 }
120 
122 
124 
125 
126  for(std::map<unsigned int,std::string>::const_iterator lab=m_labels.begin();lab!=m_labels.end();++lab) {
127  const int i = lab->first; const std::string slab = lab->second;
128  m_fhm[i]->beginRun(iRun,*m_subdirs[i]);
129  if(m_runHisto) {
130  (*m_nmultvsnvtxvsbxprofrun[i])->GetXaxis()->SetTitle("BX"); (*m_nmultvsnvtxvsbxprofrun[i])->GetYaxis()->SetTitle("Nvertices");
131  }
132  }
133 
134 }
135 
136 void DigiVertexCorrHistogramMaker::fill(const edm::Event& iEvent, const unsigned int nvtx, const std::map<unsigned int,int>& ndigi) {
137 
138 
140 
141 
142  for(std::map<unsigned int,int>::const_iterator digi=ndigi.begin();digi!=ndigi.end();digi++) {
143 
144  if(m_labels.find(digi->first) != m_labels.end()) {
145 
146  const unsigned int i=digi->first;
147  m_nmultvsnvtx[i]->Fill(nvtx,digi->second);
148  m_nmultvsnvtxprof[i]->Fill(nvtx,digi->second);
149 
150  if(m_nmultvsnvtxvsbxprofrun[i] && *m_nmultvsnvtxvsbxprofrun[i]) (*m_nmultvsnvtxvsbxprofrun[i])->Fill(iEvent.bunchCrossing()%3564,nvtx,digi->second);
151 
152  }
153 
154  }
155 }
156 
T getUntrackedParameter(std::string const &, T const &) const
int i
Definition: DBlmapReader.cc:9
std::map< unsigned int, TProfile2D ** > m_nmultvsnvtxvsbxprofrun
std::map< unsigned int, std::string > m_labels
int bunchCrossing() const
Definition: EventBase.h:66
std::map< unsigned int, int > m_binmax
int nstrips(const SiStripDetId &detid) const
int iEvent
Definition: GenABIO.cc:230
std::map< unsigned int, RunHistogramManager * > m_fhm
void Fill(HcalDetId &id, double val, std::vector< TH2F > &depth)
std::map< unsigned int, TFileDirectory * > m_subdirs
void book(const std::string dirname, const std::map< unsigned int, std::string > &labels, edm::ConsumesCollector &&iC)
std::map< unsigned int, TProfile * > m_nmultvsnvtxprof
TFileDirectory mkdir(const std::string &dir, const std::string &descr="")
create a new subdirectory
Definition: TFileService.h:69
TFileDirectory mkdir(const std::string &dir, const std::string &descr="")
create a new subdirectory
void fill(const edm::Event &iEvent, const unsigned int nvtx, const std::map< unsigned int, int > &ndigi)
std::map< unsigned int, TH2F * > m_nmultvsnvtx
volatile std::atomic< bool > shutdown_flag false
Definition: Run.h:43