CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
SUSY_HLT_ElecFakes.cc
Go to the documentation of this file.
7 #include <iostream>
8 
10 {
11  edm::LogInfo("SUSY_HLT_ElecFakes") << "Constructor SUSY_HLT_ElecFakes::SUSY_HLT_ElecFakes " << std::endl;
12  // Get parameters from configuration file
13  theTrigSummary_ = consumes<trigger::TriggerEvent>(ps.getParameter<edm::InputTag>("trigSummary"));
14  triggerResults_ = consumes<edm::TriggerResults>(ps.getParameter<edm::InputTag>("TriggerResults"));
15  HLTProcess_ = ps.getParameter<std::string>("HLTProcess");
16  triggerPath_ = ps.getParameter<std::string>("TriggerPath");
17  triggerFilter_ = ps.getParameter<edm::InputTag>("TriggerFilter");
18  triggerJetFilter_ = ps.getParameter<edm::InputTag>("TriggerJetFilter");
19 }
20 
22 {
23  edm::LogInfo("SUSY_HLT_ElecFakes") << "Destructor SUSY_HLT_ElecFakes::~SUSY_HLT_ElecFakes " << std::endl;
24 }
25 
27 {
28 
29  bool changed;
30 
31  if (!fHltConfig.init(run, e, HLTProcess_, changed)) {
32  edm::LogError("SUSY_HLT_ElecFakes") << "Initialization of HLTConfigProvider failed!!";
33  return;
34  }
35 
36  bool pathFound = false;
37  const std::vector<std::string> allTrigNames = fHltConfig.triggerNames();
38  for(size_t j = 0; j <allTrigNames.size(); ++j) {
39  if(allTrigNames[j].find(triggerPath_) != std::string::npos) {
40  pathFound = true;
41  }
42  }
43 
44  if(!pathFound) {
45  edm::LogInfo ("SUSY_HLT_ElecFakes") << "Path not found" << "\n";
46  return;
47  }
48 
49  edm::LogInfo("SUSY_HLT_ElecFakes") << "SUSY_HLT_ElecFakes::beginRun" << std::endl;
50 }
51 
53 {
54  edm::LogInfo("SUSY_HLT_ElecFakes") << "SUSY_HLT_ElecFakes::bookHistograms" << std::endl;
55  //book at beginRun
56  bookHistos(ibooker_);
57 }
58 
60  edm::EventSetup const& context)
61 {
62  edm::LogInfo("SUSY_HLT_ElecFakes") << "SUSY_HLT_ElecFakes::beginLuminosityBlock" << std::endl;
63 }
64 
65 
66 
68  edm::LogInfo("SUSY_HLT_ElecFakes") << "SUSY_HLT_ElecFakes::analyze" << std::endl;
69 
70 
71  //-------------------------------
72  //--- Trigger
73  //-------------------------------
75  e.getByToken(triggerResults_,hltresults);
76  if(!hltresults.isValid()){
77  edm::LogError ("SUSY_HLT_ElecFakes") << "invalid collection: TriggerResults" << "\n";
78  return;
79  }
81  e.getByToken(theTrigSummary_, triggerSummary);
82  if(!triggerSummary.isValid()) {
83  edm::LogError ("SUSY_HLT_ElecFakes") << "invalid collection: TriggerSummary" << "\n";
84  return;
85  }
86 
87 
88  //get online objects
89  size_t filterIndex = triggerSummary->filterIndex( triggerFilter_ );
90  trigger::TriggerObjectCollection triggerObjects = triggerSummary->getObjects();
91  if( !(filterIndex >= triggerSummary->sizeFilters()) ){
92  const trigger::Keys& keys = triggerSummary->filterKeys( filterIndex );
93  for( size_t j = 0; j < keys.size(); ++j ){
94  trigger::TriggerObject foundObject = triggerObjects[keys[j]];
95  // if(foundObject.id() == 11){ //Electrons check number
96  h_triggerElPt->Fill(foundObject.pt());
97  h_triggerElEta->Fill(foundObject.eta());
98  h_triggerElPhi->Fill(foundObject.phi());
99  // }
100  }
101  }
102 
103  filterIndex = triggerSummary->filterIndex( triggerJetFilter_ );
104  // triggerObjects = triggerSummary->getObjects();
105  if( !(filterIndex >= triggerSummary->sizeFilters()) ){
106  const trigger::Keys& keys = triggerSummary->filterKeys( filterIndex );
107  for( size_t j = 0; j < keys.size(); ++j ){
108  trigger::TriggerObject foundObject = triggerObjects[keys[j]];
109  h_triggerJetPt->Fill(foundObject.pt());
110  h_triggerJetEta->Fill(foundObject.eta());
111  h_triggerJetPhi->Fill(foundObject.phi());
112  }
113  }
114 
115 }
116 
117 
119 {
120  edm::LogInfo("SUSY_HLT_ElecFakes") << "SUSY_HLT_ElecFakes::endLuminosityBlock" << std::endl;
121 }
122 
123 
125 {
126  edm::LogInfo("SUSY_HLT_ElecFakes") << "SUSY_HLT_ElecFakes::endRun" << std::endl;
127 }
128 
130 {
131  ibooker_.cd();
132  ibooker_.setCurrentFolder("HLT/SUSYBSM/" + triggerPath_);
133 
134  //online quantities
135  h_triggerElPt = ibooker_.book1D("triggerElPt", "Trigger El Pt; GeV", 50, 0.0, 100.0);
136  h_triggerElEta = ibooker_.book1D("triggerElEta", "Trigger El Eta", 20, -2.5, 2.5);
137  h_triggerElPhi = ibooker_.book1D("triggerElPhi", "Trigger El Phi", 20, -3.5, 3.5);
138 
139  h_triggerJetPt = ibooker_.book1D("triggerJetPt", "Trigger Jet Pt; GeV", 20, 0.0, 200.0);
140  h_triggerJetEta = ibooker_.book1D("triggerJetEta", "Trigger Jet Eta", 20, -3.0, 3.0);
141  h_triggerJetPhi = ibooker_.book1D("triggerJetPhi", "Trigger Jet Phi", 20, -3.5, 3.5);
142 
143 // h_triggerElJetdPhi = ibooker_.book1D("triggerElJetdPhi", "Trigger El,Jet dPhi", 20, -3.5, 3.5);
144 
145 
146  //num and den hists to be divided in harvesting step to make turn on curves
147  ibooker_.cd();
148 }
149 
150  //define this as a plug-in
MonitorElement * h_triggerJetPhi
T getParameter(std::string const &) const
void bookHistos(DQMStore::IBooker &)
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:462
float phi() const
Definition: TriggerObject.h:58
void cd(void)
Definition: DQMStore.cc:268
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:17
const std::vector< std::string > & triggerNames() const
names of trigger paths
void endRun(edm::Run const &run, edm::EventSetup const &eSetup)
edm::InputTag triggerJetFilter_
edm::EDGetTokenT< trigger::TriggerEvent > theTrigSummary_
float eta() const
Definition: TriggerObject.h:57
void find(edm::Handle< EcalRecHitCollection > &hits, DetId thisDet, std::vector< EcalRecHitCollection::const_iterator > &hit, bool debug=false)
Definition: FindCaloHit.cc:7
MonitorElement * h_triggerJetEta
void Fill(long long x)
Single trigger physics object (e.g., an isolated muon)
Definition: TriggerObject.h:22
void dqmBeginRun(edm::Run const &, edm::EventSetup const &) override
SUSY_HLT_ElecFakes(const edm::ParameterSet &ps)
MonitorElement * book1D(Args &&...args)
Definition: DQMStore.h:115
int j
Definition: DBlmapReader.cc:9
MonitorElement * h_triggerElEta
MonitorElement * h_triggerElPt
bool isValid() const
Definition: HandleBase.h:75
std::vector< TriggerObject > TriggerObjectCollection
collection of trigger physics objects (e.g., all isolated muons)
Definition: TriggerObject.h:81
void setCurrentFolder(const std::string &fullpath)
Definition: DQMStore.cc:276
std::vector< size_type > Keys
bool init(const edm::Run &iRun, const edm::EventSetup &iSetup, const std::string &processName, bool &changed)
d&#39;tor
void analyze(edm::Event const &e, edm::EventSetup const &eSetup)
MonitorElement * h_triggerJetPt
MonitorElement * h_triggerElPhi
HLTConfigProvider fHltConfig
void bookHistograms(DQMStore::IBooker &, edm::Run const &, edm::EventSetup const &) override
void beginLuminosityBlock(edm::LuminosityBlock const &lumi, edm::EventSetup const &eSetup)
void endLuminosityBlock(edm::LuminosityBlock const &lumi, edm::EventSetup const &eSetup)
edm::EDGetTokenT< edm::TriggerResults > triggerResults_
edm::InputTag triggerFilter_
Definition: Run.h:43