BTagPerformanceHarvester

Macros

Line Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48
#ifndef BTagPerformanceHarvester_H
#define BTagPerformanceHarvester_H

#include "FWCore/Framework/interface/Frameworkfwd.h"
#include "DQMServices/Core/interface/DQMEDHarvester.h"
#include "DQMOffline/RecoB/interface/BaseBTagPlotter.h"
#include "DQMOffline/RecoB/interface/JetTagPlotter.h"
#include "DQMOffline/RecoB/interface/TagCorrelationPlotter.h"
#include "DQMOffline/RecoB/interface/BaseTagInfoPlotter.h"
#include "DQMOffline/RecoB/interface/BTagDifferentialPlot.h"

/** \class BTagPerformanceHarvester
 *
 *  Top level steering routine for b tag performance harvesting.
 *
 */

class BTagPerformanceHarvester : public DQMEDHarvester {
public:
  explicit BTagPerformanceHarvester(const edm::ParameterSet& pSet);
  ~BTagPerformanceHarvester() override;

private:
  void dqmEndJob(DQMStore::IBooker&, DQMStore::IGetter&) override;
  EtaPtBin getEtaPtBin(const int& iEta, const int& iPt);

  // Get histogram plotting options from configuration.
  std::vector<double> etaRanges, ptRanges;
  bool produceEps, producePs;
  std::string psBaseName, epsBaseName;
  std::vector<std::string> tiDataFormatType;

  std::vector<std::vector<std::shared_ptr<JetTagPlotter>>> binJetTagPlotters;
  std::vector<std::vector<std::unique_ptr<TagCorrelationPlotter>>> binTagCorrelationPlotters;
  std::vector<std::vector<std::unique_ptr<BaseTagInfoPlotter>>> binTagInfoPlotters;
  std::vector<edm::InputTag> jetTagInputTags;
  std::vector<std::pair<edm::InputTag, edm::InputTag>> tagCorrelationInputTags;
  std::vector<std::vector<edm::InputTag>> tagInfoInputTags;
  // Contains plots for each bin of rapidity and pt.
  std::vector<std::vector<std::unique_ptr<BTagDifferentialPlot>>> differentialPlots;
  std::vector<edm::ParameterSet> moduleConfig;

  std::string flavPlots_;
  unsigned int mcPlots_;
  bool makeDiffPlots_;
};

#endif