CMS 3D CMS Logo

HLTExoticaSubAnalysis.h
Go to the documentation of this file.
1 #ifndef HLTriggerOffline_Exotica_HLTExoticaSubAnalysis_H
2 #define HLTriggerOffline_Exotica_HLTExoticaSubAnalysis_H
3 
23 
51 
53 
54 #include <cstring>
55 #include <map>
56 #include <set>
57 #include <vector>
58 
60 struct EVTColContainer;
61 
66 public:
69 
70  enum class Level { GEN = 98, RECO = 99 };
71 
73  const std::string &analysisname,
74  edm::ConsumesCollector &&consCollector);
76  void beginJob();
77  void beginRun(const edm::Run &iRun, const edm::EventSetup &iEventSetup);
78  void endRun();
79 
83  void subAnalysisBookHistos(DQMStore::IBooker &iBooker, const edm::Run &iRun, const edm::EventSetup &iSetup);
84 
88  void analyze(const edm::Event &iEvent, const edm::EventSetup &iEventSetup, EVTColContainer *cols);
89 
90 private:
96  const std::vector<unsigned int> getObjectsType(const std::string &hltpath) const;
97 
99  void getNamesOfObjects(const edm::ParameterSet &anpset);
101  void registerConsumes(edm::ConsumesCollector &consCollector);
103  void getHandlesToObjects(const edm::Event &iEvent, EVTColContainer *col);
105  void initSelector(const unsigned int &objtype);
108  void insertCandidates(const unsigned int &objtype,
109  const EVTColContainer *col,
110  std::vector<reco::LeafCandidate> *matches,
111  std::map<int, double> &theSumEt,
112  std::map<int, std::vector<const reco::Track *>> &trkObjs);
113 
115  void bookHist(DQMStore::IBooker &iBooker,
116  const std::string &source,
117  const std::string &objType,
118  const std::string &variable);
119  void fillHist(const std::string &source, const std::string &objType, const std::string &variable, const float &value);
120 
123 
126 
128  unsigned int _minCandidates;
129 
131  std::vector<std::string> _hltPathsToCheck;
133  std::set<std::string> _hltPaths;
135  std::map<std::string, std::string> _shortpath2long;
136 
142  std::map<unsigned int, edm::InputTag> _recLabels;
147  std::map<unsigned int, edm::EDGetToken> _tokens;
148 
150  std::vector<double> _parametersEta;
151  std::vector<double> _parametersPhi;
152  std::vector<double> _parametersTurnOn;
153  std::vector<double> _parametersTurnOnSumEt;
154  std::vector<double> _parametersDxy;
155 
156  // flag to switch off
157  bool _drop_pt2;
158  bool _drop_pt3;
159 
161  std::map<unsigned int, std::string> _genCut;
162  std::map<unsigned int, std::string> _recCut;
164  std::map<unsigned int, std::string> _genCut_leading;
165  std::map<unsigned int, std::string> _recCut_leading;
166 
169  std::map<unsigned int, StringCutObjectSelector<reco::GenParticle> *> _genSelectorMap;
185 
187  std::vector<HLTExoticaPlotter> _plotters;
188 
190  std::map<std::string, int> _triggerCounter;
191 
194 
196  std::map<std::string, MonitorElement *> _elements;
197 };
198 
199 #endif
StringCutObjectSelector< reco::Track > * _recMuonTrkSelector
unsigned int _minCandidates
The minimum number of reco/gen candidates needed by the analysis.
void getNamesOfObjects(const edm::ParameterSet &anpset)
Creates the maps that map which collection should come from which label.
std::map< unsigned int, std::string > _genCut
gen/rec objects cuts
std::vector< HLTExoticaPlotter > _plotters
The plotters: managers of each hlt path where the plots are done.
StringCutObjectSelector< reco::CaloJet > * _recCaloJetSelector
StringCutObjectSelector< reco::GenMET > * _genMETSelector
std::vector< double > _parametersPhi
void fillHist(const std::string &source, const std::string &objType, const std::string &variable, const float &value)
container with all the objects needed
void analyze(const edm::Event &iEvent, const edm::EventSetup &iEventSetup, EVTColContainer *cols)
StringCutObjectSelector< reco::MET > * _recMETSelector
edm::EDGetTokenT< edm::TriggerResults > _trigResultsToken
dqm::legacy::MonitorElement MonitorElement
std::map< unsigned int, std::string > _genCut_leading
gen/rec pt-leading objects cuts
StringCutObjectSelector< reco::PFJet > * _recPFJetSelector
std::map< std::string, int > _triggerCounter
counting HLT passed events
std::map< unsigned int, edm::InputTag > _recLabels
StringCutObjectSelector< reco::GsfElectron > * _recElecSelector
std::map< unsigned int, std::string > _recCut_leading
int iEvent
Definition: GenABIO.cc:224
StringCutObjectSelector< reco::Muon > * _recMuonSelector
edm::ParameterSet _pset
Internal, working copy of the PSet passed from above.
void subAnalysisBookHistos(DQMStore::IBooker &iBooker, const edm::Run &iRun, const edm::EventSetup &iSetup)
std::vector< double > _parametersEta
Some kinematical parameters.
std::map< unsigned int, std::string > _recCut
std::vector< double > _parametersDxy
const std::vector< unsigned int > getObjectsType(const std::string &hltpath) const
closes analyze method
StringCutObjectSelector< reco::Track > * _recTrackSelector
HLTConfigProvider _hltConfig
Interface to the HLT information.
~HLTExoticaSubAnalysis()
End Constructor.
Definition: value.py:1
std::vector< std::string > _hltPathsToCheck
The hlt paths to check for.
StringCutObjectSelector< reco::CaloMET > * _recCaloMHTSelector
std::string _hltProcessName
The labels of the object collections to be used in this analysis.
void insertCandidates(const unsigned int &objtype, const EVTColContainer *col, std::vector< reco::LeafCandidate > *matches, std::map< int, double > &theSumEt, std::map< int, std::vector< const reco::Track * >> &trkObjs)
void registerConsumes(edm::ConsumesCollector &consCollector)
Registers consumption of objects.
void getHandlesToObjects(const edm::Event &iEvent, EVTColContainer *col)
Gets the collections themselves.
StringCutObjectSelector< reco::PFMET > * _recPFMETSelector
std::string _analysisname
The name of this sub-analysis.
StringCutObjectSelector< reco::Photon > * _recPhotonSelector
std::map< unsigned int, StringCutObjectSelector< reco::GenParticle > * > _genSelectorMap
void beginRun(const edm::Run &iRun, const edm::EventSetup &iEventSetup)
StringCutObjectSelector< l1extra::L1EtMissParticle > * _l1METSelector
std::vector< double > _parametersTurnOn
std::map< unsigned int, edm::EDGetToken > _tokens
std::map< std::string, MonitorElement * > _elements
Structure of the MonitorElements.
StringCutObjectSelector< reco::CaloMET > * _recCaloMETSelector
HLTExoticaSubAnalysis(const edm::ParameterSet &pset, const std::string &analysisname, edm::ConsumesCollector &&consCollector)
Constructor.
col
Definition: cuy.py:1010
dqm::legacy::DQMStore DQMStore
edm::EDGetTokenT< reco::GenParticleCollection > _genParticleToken
And also the tokens to get the object collections.
void initSelector(const unsigned int &objtype)
Initializes the selectors of the objects based on which object it is.
std::vector< double > _parametersTurnOnSumEt
std::set< std::string > _hltPaths
The hlt paths found in the hltConfig.
StringCutObjectSelector< reco::PFMET > * _recPFMHTSelector
static std::string const source
Definition: EdmProvDump.cc:47
edm::EDGetTokenT< reco::BeamSpot > _bsToken
StringCutObjectSelector< reco::PFTau > * _recPFTauSelector
void bookHist(DQMStore::IBooker &iBooker, const std::string &source, const std::string &objType, const std::string &variable)
The internal functions to book and fill histograms.
Definition: Run.h:45
std::map< std::string, std::string > _shortpath2long
Relation between the short and long versions of the path.