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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
|
#ifndef MuonRecoOneHLT_H
#define MuonRecoOneHLT_H
#include <memory>
#include <fstream>
#include "FWCore/Framework/interface/Frameworkfwd.h"
#include "FWCore/Framework/interface/Event.h"
#include "FWCore/Framework/interface/MakerMacros.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include "FWCore/ServiceRegistry/interface/Service.h"
#include "DQMServices/Core/interface/DQMStore.h"
#include "DQMServices/Core/interface/DQMEDAnalyzer.h"
#include "DataFormats/Common/interface/TriggerResults.h"
#include "DataFormats/HLTReco/interface/TriggerEvent.h"
#include "DataFormats/HLTReco/interface/TriggerObject.h"
#include "DataFormats/HLTReco/interface/TriggerTypeDefs.h"
#include "HLTrigger/HLTcore/interface/HLTConfigProvider.h"
#include "CommonTools/TriggerUtils/interface/GenericTriggerEventFlag.h"
#include "DataFormats/Common/interface/Handle.h"
#include "DataFormats/MuonReco/interface/Muon.h"
#include "DataFormats/MuonReco/interface/MuonFwd.h"
#include "DataFormats/MuonReco/interface/MuonEnergy.h"
#include "FWCore/Common/interface/TriggerNames.h"
#include "DataFormats/TrackReco/interface/Track.h"
#include "DataFormats/TrackReco/interface/TrackFwd.h"
#include "DataFormats/BeamSpot/interface/BeamSpot.h"
#include "FWCore/MessageLogger/interface/MessageLogger.h"
#include "DataFormats/VertexReco/interface/Vertex.h"
#include "DataFormats/VertexReco/interface/VertexFwd.h"
#include "DataFormats/MuonReco/interface/MuonSelectors.h"
#include "DataFormats/Common/interface/TriggerResults.h"
#include "DataFormats/HLTReco/interface/TriggerEvent.h"
#include "DataFormats/HLTReco/interface/TriggerObject.h"
#include "DataFormats/HLTReco/interface/TriggerTypeDefs.h"
#include "HLTrigger/HLTcore/interface/HLTConfigProvider.h"
class MuonRecoOneHLT : public DQMEDAnalyzer {
public:
/// Constructor
MuonRecoOneHLT(const edm::ParameterSet&);
/// Destructor
~MuonRecoOneHLT() override;
void analyze(const edm::Event&, const edm::EventSetup&) override;
void bookHistograms(DQMStore::IBooker&, edm::Run const&, edm::EventSetup const&) override;
private:
// ----------member data ---------------------------
edm::ParameterSet parameters;
// Switch for verbosity
std::string metname;
// STA Label
edm::EDGetTokenT<reco::MuonCollection> theMuonCollectionLabel_;
edm::EDGetTokenT<reco::VertexCollection> theVertexLabel_;
edm::EDGetTokenT<reco::BeamSpot> theBeamSpotLabel_;
edm::EDGetTokenT<edm::TriggerResults> theTriggerResultsLabel_;
std::vector<std::string> singlemuonExpr_;
std::vector<std::string> doublemuonExpr_;
GenericTriggerEventFlag* _SingleMuonEventFlag;
GenericTriggerEventFlag* _DoubleMuonEventFlag;
//histo binning parameters
int ptBin;
float ptMin;
float ptMax;
int etaBin;
float etaMin;
float etaMax;
int phiBin;
float phiMin;
float phiMax;
int chi2Bin;
float chi2Min;
float chi2Max;
//the histos
MonitorElement* muReco;
// global muon
std::vector<MonitorElement*> etaGlbTrack;
std::vector<MonitorElement*> phiGlbTrack;
std::vector<MonitorElement*> chi2OvDFGlbTrack;
std::vector<MonitorElement*> ptGlbTrack;
// tight muon
MonitorElement* etaTight;
MonitorElement* phiTight;
MonitorElement* chi2OvDFTight;
MonitorElement* ptTight;
// tracker muon
MonitorElement* etaTrack;
MonitorElement* phiTrack;
MonitorElement* chi2OvDFTrack;
MonitorElement* ptTrack;
// sta muon
MonitorElement* etaStaTrack;
MonitorElement* phiStaTrack;
MonitorElement* chi2OvDFStaTrack;
MonitorElement* ptStaTrack;
};
#endif
|