1 #ifndef DQMOffline_RecoB_TrackIPHistograms_h 2 #define DQMOffline_RecoB_TrackIPHistograms_h 15 const int& nBins_,
const double& lowerBound_,
const double& upperBound_,
20 const int& nBins_,
const double& lowerBound_,
const double& upperBound_,
21 const bool&
statistics,
const bool& plotLog_,
const bool& plotNormalized_,
53 const int& nBins_,
const double& lowerBound_,
const double& upperBound_,
54 const bool& statistics_,
const bool& plotLog_,
const bool& plotNormalized_,
57 FlavourHistograms<
T>(baseNameTitle_, baseNameDescription_, nBins_, lowerBound_, upperBound_, statistics_, plotLog_, plotNormalized_,
58 plotFirst_, folder, mc, ibook),
quality_(quality)
62 theQual_undefined = prov.
book1D( baseNameTitle_ +
"QualUnDef" , baseNameDescription_ +
" Undefined Quality", nBins_, lowerBound_, upperBound_);
63 theQual_loose = prov.
book1D( baseNameTitle_ +
"QualLoose" , baseNameDescription_ +
" Loose Quality", nBins_, lowerBound_, upperBound_);
64 theQual_tight = prov.
book1D( baseNameTitle_ +
"QualTight" , baseNameDescription_ +
" Tight Quality", nBins_, lowerBound_, upperBound_);
65 theQual_highpur = prov.
book1D( baseNameTitle_ +
"QualHighPur" , baseNameDescription_ +
" High Purity Quality", nBins_, lowerBound_, upperBound_);
77 const int& nBins_,
const double& lowerBound_,
const double& upperBound_,
80 FlavourHistograms<
T>(baseNameTitle_, baseNameDescription_, nBins_, lowerBound_, upperBound_,
81 plotFirst_, folder, mc, iget),
quality_(quality)
85 theQual_loose = iget.
get(
"Btag/" + folder +
"/" + baseNameTitle_ +
"QualLoose");
86 theQual_tight = iget.
get(
"Btag/" + folder +
"/" + baseNameTitle_ +
"QualTight");
115 if( theArrayDimension ==
nullptr &&
quality_) {
118 int iMax = (*theArrayDimension >
theMaxDimension) ? theMaxDimension : *theArrayDimension ;
119 for(
int i = 0;
i != iMax; ++
i) {
120 if(
quality_ && (( theIndexToPlot < 0) || (
i == theIndexToPlot)) ) {
125 if(theIndexToPlot >= iMax &&
quality_) {
126 const T& theZero =
static_cast<T> (0.0);
140 if( theArrayDimension ==
nullptr &&
quality_) {
143 int iMax = (*theArrayDimension >
theMaxDimension) ? theMaxDimension : *theArrayDimension ;
144 for(
int i = 0;
i != iMax; ++
i) {
145 if(
quality_ && (( theIndexToPlot < 0) || (
i == theIndexToPlot)) ) {
150 if(theIndexToPlot >= iMax &&
quality_) {
151 const T& theZero =
static_cast<T> (0.0);
MonitorElement * theQual_tight
TrackQuality
track quality
MonitorElement * get(const std::string &path)
~TrackIPHistograms() override
void fill(const int &flavour, const T &variable) const
virtual MonitorElement * book1D(const std::string &name, const std::string &title, const int &nchX, const double &lowX, const double &highX)
void fill(const int &flavour, const reco::TrackBase::TrackQuality &quality, const T &variable, const bool &hasTrack) const
MonitorElement * theQual_loose
void settitle(const char *title)
int * arrayDimension() const
MonitorElement * theQual_highpur
MonitorElement * theQual_undefined
void settitle(const char *title)
void setAxisTitle(const std::string &title, int axis=1)
set x-, y- or z-axis title (axis=1, 2, 3 respectively)
void fillVariable(const reco::TrackBase::TrackQuality &qual, const T &var, const bool &hasTrack) const