CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
DigiPileupCorrHistogramMaker.cc
Go to the documentation of this file.
9 #include "TH2F.h"
10 #include "TProfile.h"
11 #include "TProfile2D.h"
12 
14 
15 
17  m_pileupcollectionToken(iC.consumes<std::vector<PileupSummaryInfo> >(edm::InputTag("addPileupInfo"))), m_useVisibleVertices(false), m_hitname(), m_nbins(500), m_scalefact(), m_binmax(), m_labels(),
18  m_nmultvsmclumi(), m_nmultvsmclumiprof(), m_nmultvsmcnvtx(), m_nmultvsmcnvtxprof(), m_nmultvsmcnvtxprof2d(), m_subdirs(),
19  m_2dhisto(), m_ootBX(-1) { }
20 
22  m_pileupcollectionToken(iC.consumes<std::vector<PileupSummaryInfo> >(iConfig.getParameter<edm::InputTag>("pileupSummaryCollection"))),
23  m_useVisibleVertices(iConfig.getParameter<bool>("useVisibleVertices")),
24  m_hitname(iConfig.getUntrackedParameter<std::string>("hitName","digi")),
25  m_nbins(iConfig.getUntrackedParameter<int>("numberOfBins",500)),
26  m_scalefact(iConfig.getUntrackedParameter<int>("scaleFactor",5)),
27  m_labels(), m_nmultvsmclumi(), m_nmultvsmclumiprof(), m_nmultvsmcnvtx(), m_nmultvsmcnvtxprof(), m_nmultvsmcnvtxprof2d(), m_subdirs(),
28  m_2dhisto(iConfig.getUntrackedParameter<bool>("wanted2DHisto",false)),
29  m_ootBX(iConfig.getUntrackedParameter<int>("ootBX",-1))
30 {
31 
32  std::vector<edm::ParameterSet>
33  wantedsubds(iConfig.getUntrackedParameter<std::vector<edm::ParameterSet> >("wantedSubDets",std::vector<edm::ParameterSet>()));
34 
35  for(std::vector<edm::ParameterSet>::iterator ps=wantedsubds.begin();ps!=wantedsubds.end();++ps) {
36  m_labels[ps->getParameter<unsigned int>("detSelection")] = ps->getParameter<std::string>("detLabel");
37  m_binmax[ps->getParameter<unsigned int>("detSelection")] = ps->getParameter<int>("binMax");
38  }
39 
40 
41 }
42 
43 
45 
46  for(std::map<unsigned int,std::string>::const_iterator lab=m_labels.begin();lab!=m_labels.end();lab++) {
47 
48  const unsigned int i = lab->first; const std::string slab = lab->second;
49 
50  delete m_subdirs[i];
51  }
52 
53 }
54 
55 
56 
57 void DigiPileupCorrHistogramMaker::book(const std::string dirname, const std::map<unsigned int, std::string>& labels) {
58 
59  m_labels = labels;
60  book(dirname);
61 
62 }
63 
65 
67  TFileDirectory subev = tfserv->mkdir(dirname);
68 
69  SiStripTKNumbers trnumb;
70 
71  edm::LogInfo("NumberOfBins") << "Number of Bins: " << m_nbins;
72  edm::LogInfo("ScaleFactors") << "y-axis range scale factor: " << m_scalefact;
73  edm::LogInfo("BinMaxValue") << "Setting bin max values";
74 
75  for(std::map<unsigned int,std::string>::const_iterator lab=m_labels.begin();lab!=m_labels.end();lab++) {
76 
77  const unsigned int i = lab->first; const std::string slab = lab->second;
78 
79  if(m_binmax.find(i)==m_binmax.end()) {
80  edm::LogVerbatim("NotConfiguredBinMax") << "Bin max for " << lab->second
81  << " not configured: " << trnumb.nstrips(i) << " used";
82  m_binmax[i] = trnumb.nstrips(i);
83  }
84 
85  edm::LogVerbatim("BinMaxValue") << "Bin max for " << lab->second << " is " << m_binmax[i];
86 
87  }
88 
89  for(std::map<unsigned int,std::string>::const_iterator lab=m_labels.begin();lab!=m_labels.end();++lab) {
90 
91  const int i = lab->first; const std::string slab = lab->second;
92 
93  char name[200];
94  char title[500];
95 
96  m_subdirs[i] = new TFileDirectory(subev.mkdir(slab.c_str()));
97 
98  if(m_subdirs[i]) {
99  sprintf(name,"n%sdigivsmclumi",slab.c_str());
100  sprintf(title,"%s %s multiplicity ave pileup interactions",slab.c_str(),m_hitname.c_str());
101  m_nmultvsmclumi[i] = m_subdirs[i]->make<TH2F>(name,title,200,0.,50.,m_nbins,0.,m_binmax[i]/(m_scalefact*m_nbins)*m_nbins);
102  m_nmultvsmclumi[i]->GetXaxis()->SetTitle("Average Pileup Interactions"); m_nmultvsmclumi[i]->GetYaxis()->SetTitle("Number of Hits");
103  sprintf(name,"n%sdigivsmclumiprof",slab.c_str());
104  m_nmultvsmclumiprof[i] = m_subdirs[i]->make<TProfile>(name,title,200,0.,50.);
105  m_nmultvsmclumiprof[i]->GetXaxis()->SetTitle("Average Pileup Interactions"); m_nmultvsmclumiprof[i]->GetYaxis()->SetTitle("Number of Hits");
106 
107  sprintf(name,"n%sdigivsmcnvtx",slab.c_str());
108  sprintf(title,"%s %s multiplicity vs pileup interactions",slab.c_str(),m_hitname.c_str());
109  m_nmultvsmcnvtx[i] = m_subdirs[i]->make<TH2F>(name,title,60,-0.5,59.5,m_nbins,0.,m_binmax[i]/(m_scalefact*m_nbins)*m_nbins);
110  m_nmultvsmcnvtx[i]->GetXaxis()->SetTitle("Pileup Interactions"); m_nmultvsmcnvtx[i]->GetYaxis()->SetTitle("Number of Hits");
111  sprintf(name,"n%sdigivsmcnvtxprof",slab.c_str());
112  m_nmultvsmcnvtxprof[i] = m_subdirs[i]->make<TProfile>(name,title,60,-0.5,59.5);
113  m_nmultvsmcnvtxprof[i]->GetXaxis()->SetTitle("Pileup Interactions"); m_nmultvsmcnvtxprof[i]->GetYaxis()->SetTitle("Number of Hits");
114  if(m_2dhisto) {
115  sprintf(name,"n%sdigivsmcnvtxprof2d",slab.c_str());
116  m_nmultvsmcnvtxprof2d[i] = m_subdirs[i]->make<TProfile2D>(name,title,60,-0.5,59.5,60,-0.5,59.5);
117  m_nmultvsmcnvtxprof2d[i]->GetXaxis()->SetTitle("Pileup Interactions");
118  m_nmultvsmcnvtxprof2d[i]->GetYaxis()->SetTitle("Pileup Interactions OOT");
119  m_nmultvsmcnvtxprof2d[i]->GetZaxis()->SetTitle("Number of Hits");
120  }
121  }
122 
123  }
124 
125 
126 }
127 
128 void DigiPileupCorrHistogramMaker::beginRun(const unsigned int nrun) {
129 
130 
131 }
132 
133 void DigiPileupCorrHistogramMaker::fill(const edm::Event& iEvent, const std::map<unsigned int,int>& ndigi) {
134 
136  iEvent.getByToken(m_pileupcollectionToken,pileupinfos);
137 
138  // look for the intime PileupSummaryInfo
139 
140  std::vector<PileupSummaryInfo>::const_iterator pileupinfoInTime = pileupinfos->end();
141  std::vector<PileupSummaryInfo>::const_iterator pileupinfoMinusOne = pileupinfos->end();
142 
143  for(std::vector<PileupSummaryInfo>::const_iterator pileupinfo = pileupinfos->begin(); pileupinfo != pileupinfos->end() ; ++pileupinfo) {
144 
145  if(pileupinfo->getBunchCrossing()==0) pileupinfoInTime = pileupinfo;
146  if(pileupinfo->getBunchCrossing()==m_ootBX) pileupinfoMinusOne = pileupinfo;
147 
148  }
149 
150  if(pileupinfoInTime == pileupinfos->end()) {
151 
152  edm::LogError("NoInTimePileUpInfo") << "Cannot find the in-time pileup info ";
153 
154  }
155  else {
156 
157  int npileup = pileupinfoInTime->getPU_NumInteractions();
158 
159  if(m_useVisibleVertices) npileup = pileupinfoInTime->getPU_zpositions().size();
160 
161  for(std::map<unsigned int,int>::const_iterator digi=ndigi.begin();digi!=ndigi.end();digi++) {
162  if(m_labels.find(digi->first) != m_labels.end()) {
163  const unsigned int i=digi->first;
164  m_nmultvsmcnvtx[i]->Fill(npileup,digi->second);
165  m_nmultvsmcnvtxprof[i]->Fill(npileup,digi->second);
166  m_nmultvsmclumi[i]->Fill(pileupinfoInTime->getTrueNumInteractions(),digi->second);
167  m_nmultvsmclumiprof[i]->Fill(pileupinfoInTime->getTrueNumInteractions(),digi->second);
168  if(m_2dhisto) {
169  if(pileupinfoMinusOne != pileupinfos->end()) {
170  int npileupminusone = pileupinfoMinusOne->getPU_NumInteractions();
171  if(m_useVisibleVertices) npileupminusone = pileupinfoMinusOne->getPU_zpositions().size();
172  m_nmultvsmcnvtxprof2d[i]->Fill(npileup,npileupminusone,digi->second);
173  }
174  }
175  }
176  }
177  }
178 }
179 
180 
std::map< unsigned int, std::string > m_labels
T getUntrackedParameter(std::string const &, T const &) const
int i
Definition: DBlmapReader.cc:9
void fill(const edm::Event &iEvent, const std::map< unsigned int, int > &ndigi)
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:464
std::map< unsigned int, int > m_binmax
void beginRun(const unsigned int nrun)
std::map< unsigned int, TH2F * > m_nmultvsmcnvtx
std::map< unsigned int, TProfile2D * > m_nmultvsmcnvtxprof2d
std::map< unsigned int, TProfile * > m_nmultvsmclumiprof
DigiPileupCorrHistogramMaker(edm::ConsumesCollector &&iC)
int nstrips(const SiStripDetId &detid) const
int iEvent
Definition: GenABIO.cc:230
std::map< unsigned int, TProfile * > m_nmultvsmcnvtxprof
std::map< unsigned int, TH2F * > m_nmultvsmclumi
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
edm::EDGetTokenT< std::vector< PileupSummaryInfo > > m_pileupcollectionToken
std::map< unsigned int, TFileDirectory * > m_subdirs
volatile std::atomic< bool > shutdown_flag false
void book(const std::string dirname, const std::map< unsigned int, std::string > &labels)