CMS 3D CMS Logo

HLTScoutingEgammaProducer.cc
Go to the documentation of this file.
1 // -*- C++ -*-
2 //
3 // Package: HLTrigger/Egamma
4 // Class: HLTScoutingEgammaProducer
5 //
11 //
12 // Original Author: David G. Sheffield (Rutgers)
13 // Created: Mon, 20 Jul 2015
14 //
15 //
16 
18 
19 //
20 // constructors and destructor
21 //
23  EgammaCandidateCollection_(consumes<reco::RecoEcalCandidateCollection>
24  (iConfig.getParameter<edm::InputTag>("EgammaCandidates"))),
25  EgammaGsfTrackCollection_(consumes<reco::GsfTrackCollection>
26  (iConfig.getParameter<edm::InputTag>("EgammaGsfTracks"))),
27  SigmaIEtaIEtaMap_(consumes<RecoEcalCandMap>(iConfig.getParameter<edm::InputTag>(
28  "SigmaIEtaIEtaMap"))),
29  HoverEMap_(consumes<RecoEcalCandMap>(iConfig.getParameter<edm::InputTag>("HoverEMap"))),
30  DetaMap_(consumes<RecoEcalCandMap>(iConfig.getParameter<edm::InputTag>("DetaMap"))),
31  DphiMap_(consumes<RecoEcalCandMap>(iConfig.getParameter<edm::InputTag>("DphiMap"))),
32  MissingHitsMap_(consumes<RecoEcalCandMap>(iConfig.getParameter<edm::InputTag>(
33  "MissingHitsMap"))),
34  OneOEMinusOneOPMap_(consumes<RecoEcalCandMap>(iConfig.getParameter<edm::InputTag>(
35  "OneOEMinusOneOPMap"))),
36  EcalPFClusterIsoMap_(consumes<RecoEcalCandMap>(iConfig.getParameter<edm::InputTag>(
37  "EcalPFClusterIsoMap"))),
38  EleGsfTrackIsoMap_(consumes<RecoEcalCandMap>(iConfig.getParameter<edm::InputTag>(
39  "EleGsfTrackIsoMap"))),
40  HcalPFClusterIsoMap_(consumes<RecoEcalCandMap>(iConfig.getParameter<edm::InputTag>(
41  "HcalPFClusterIsoMap"))),
42  egammaPtCut(iConfig.getParameter<double>("egammaPtCut")),
43  egammaEtaCut(iConfig.getParameter<double>("egammaEtaCut")),
44  egammaHoverECut(iConfig.getParameter<double>("egammaHoverECut"))
45 {
46  //register products
47  produces<ScoutingElectronCollection>();
48  produces<ScoutingPhotonCollection>();
49 }
50 
52 
53 // ------------ method called to produce the data ------------
55 {
56  using namespace edm;
57 
58  std::unique_ptr<ScoutingElectronCollection> outElectrons(new ScoutingElectronCollection());
59  std::unique_ptr<ScoutingPhotonCollection> outPhotons(new ScoutingPhotonCollection());
60 
61  // Get RecoEcalCandidate
62  Handle<reco::RecoEcalCandidateCollection> EgammaCandidateCollection;
64  EgammaCandidateCollection)){
65  iEvent.put(std::move(outElectrons));
66  iEvent.put(std::move(outPhotons));
67  return;
68  }
69 
70  // Get GsfTrack
71  Handle<reco::GsfTrackCollection> EgammaGsfTrackCollection;
73  EgammaGsfTrackCollection)){
74  iEvent.put(std::move(outElectrons));
75  iEvent.put(std::move(outPhotons));
76  return;
77  }
78 
79  // Get SigmaIEtaIEtaMap
80  Handle<RecoEcalCandMap> SigmaIEtaIEtaMap;
81  if(!iEvent.getByToken(SigmaIEtaIEtaMap_, SigmaIEtaIEtaMap)){
82  iEvent.put(std::move(outElectrons));
83  iEvent.put(std::move(outPhotons));
84  return;
85  }
86 
87  // Get HoverEMap
88  Handle<RecoEcalCandMap> HoverEMap;
89  if(!iEvent.getByToken(HoverEMap_, HoverEMap)){
90  iEvent.put(std::move(outElectrons));
91  iEvent.put(std::move(outPhotons));
92  return;
93  }
94 
95  // Get DetaMap
97  if(!iEvent.getByToken(DetaMap_, DetaMap)){
98  iEvent.put(std::move(outElectrons));
99  iEvent.put(std::move(outPhotons));
100  return;
101  }
102 
103  // Get DphiMap
104  Handle<RecoEcalCandMap> DphiMap;
105  if(!iEvent.getByToken(DphiMap_, DphiMap)){
106  iEvent.put(std::move(outElectrons));
107  iEvent.put(std::move(outPhotons));
108  return;
109  }
110 
111  // Get MissingHitsMap
112  Handle<RecoEcalCandMap> MissingHitsMap;
113  if(!iEvent.getByToken(MissingHitsMap_, MissingHitsMap)){
114  iEvent.put(std::move(outElectrons));
115  iEvent.put(std::move(outPhotons));
116  return;
117  }
118 
119  // Get 1/E - 1/p Map
120  Handle<RecoEcalCandMap> OneOEMinusOneOPMap;
121  if(!iEvent.getByToken(OneOEMinusOneOPMap_, OneOEMinusOneOPMap)){
122  iEvent.put(std::move(outElectrons));
123  iEvent.put(std::move(outPhotons));
124  return;
125  }
126 
127  // Get EcalPFClusterIsoMap
128  Handle<RecoEcalCandMap> EcalPFClusterIsoMap;
129  if(!iEvent.getByToken(EcalPFClusterIsoMap_, EcalPFClusterIsoMap)){
130  iEvent.put(std::move(outElectrons));
131  iEvent.put(std::move(outPhotons));
132  return;
133  }
134 
135  // Get EleGsfTrackIsoMap
136  Handle<RecoEcalCandMap> EleGsfTrackIsoMap;
137  if(!iEvent.getByToken(EleGsfTrackIsoMap_, EleGsfTrackIsoMap)){
138  iEvent.put(std::move(outElectrons));
139  iEvent.put(std::move(outPhotons));
140  return;
141  }
142 
143  // Get HcalPFClusterIsoMap
144  Handle<RecoEcalCandMap> HcalPFClusterIsoMap;
145  if(!iEvent.getByToken(HcalPFClusterIsoMap_, HcalPFClusterIsoMap)){
146  iEvent.put(std::move(outElectrons));
147  iEvent.put(std::move(outPhotons));
148  return;
149  }
150 
151  // Produce electrons and photons
152  int index = 0;
153  for (auto &candidate : *EgammaCandidateCollection) {
154  reco::RecoEcalCandidateRef candidateRef = getRef(EgammaCandidateCollection, index);
155  ++index;
156  if (candidateRef.isNull() && !candidateRef.isAvailable())
157  continue;
158 
159  if ((*HoverEMap)[candidateRef] > egammaHoverECut)
160  continue;
161  if (candidate.pt() < egammaPtCut)
162  continue;
163  if (fabs(candidate.eta()) > egammaEtaCut)
164  continue;
165 
166  reco::SuperClusterRef scRef = candidate.superCluster();
167  if (scRef.isNull() && !scRef.isAvailable())
168  continue;
169  float d0 = 0.0;
170  float dz = 0.0;
171  int charge = -999;
172  for (auto &track: *EgammaGsfTrackCollection) {
173  RefToBase<TrajectorySeed> seed = track.extra()->seedRef();
175  RefToBase<reco::CaloCluster> caloCluster = elseed->caloCluster();
176  reco::SuperClusterRef scRefFromTrk = caloCluster.castTo<reco::SuperClusterRef>() ;
177  if (scRefFromTrk == scRef) {
178  d0 = track.d0();
179  dz = track.dz();
180  charge = track.charge();
181  }
182  }
183  if (charge == -999) { // No associated track. Candidate is a scouting photon
184  outPhotons->emplace_back(candidate.pt(), candidate.eta(), candidate.phi(),
185  candidate.mass(), (*SigmaIEtaIEtaMap)[candidateRef],
186  (*HoverEMap)[candidateRef],
187  (*EcalPFClusterIsoMap)[candidateRef],
188  (*HcalPFClusterIsoMap)[candidateRef]);
189  } else { // Candidate is a scouting electron
190  outElectrons->emplace_back(candidate.pt(), candidate.eta(), candidate.phi(),
191  candidate.mass(), d0, dz, (*DetaMap)[candidateRef],
192  (*DphiMap)[candidateRef], (*SigmaIEtaIEtaMap)[candidateRef],
193  (*HoverEMap)[candidateRef],
194  (*OneOEMinusOneOPMap)[candidateRef],
195  (*MissingHitsMap)[candidateRef], charge,
196  (*EcalPFClusterIsoMap)[candidateRef],
197  (*HcalPFClusterIsoMap)[candidateRef],
198  (*EleGsfTrackIsoMap)[candidateRef]);
199  }
200  }
201 
202  // Put output
203  iEvent.put(std::move(outElectrons));
204  iEvent.put(std::move(outPhotons));
205 }
206 
207 // ------------ method fills 'descriptions' with the allowed parameters for the module ------------
210  desc.add<edm::InputTag>("EgammaCandidates", edm::InputTag("hltEgammaCandidates"));
211  desc.add<edm::InputTag>("EgammaGsfTracks", edm::InputTag("hltEgammaGsfTracks"));
212  desc.add<edm::InputTag>("SigmaIEtaIEtaMap", edm::InputTag(
213  "hltEgammaClusterShape:sigmaIEtaIEta5x5"));
214  desc.add<edm::InputTag>("HoverEMap", edm::InputTag("hltEgammaHoverE"));
215  desc.add<edm::InputTag>("DetaMap", edm::InputTag("hltEgammaGsfTrackVars:Deta"));
216  desc.add<edm::InputTag>("DphiMap", edm::InputTag("hltEgammaGsfTrackVars:Dphi"));
217  desc.add<edm::InputTag>("MissingHitsMap", edm::InputTag("hltEgammaGsfTrackVars:MissingHits"));
218  desc.add<edm::InputTag>("OneOEMinusOneOPMap", edm::InputTag(
219  "hltEgammaGsfTrackVars:OneOESuperMinusOneOP"));
220  desc.add<edm::InputTag>("EcalPFClusterIsoMap", edm::InputTag("hltEgammaEcalPFClusterIso"));
221  desc.add<edm::InputTag>("EleGsfTrackIsoMap", edm::InputTag("hltEgammaEleGsfTrackIso"));
222  desc.add<edm::InputTag>("HcalPFClusterIsoMap", edm::InputTag("hltEgammaHcalPFClusterIso"));
223  desc.add<double>("egammaPtCut", 4.0);
224  desc.add<double>("egammaEtaCut", 2.5);
225  desc.add<double>("egammaHoverECut", 1.0);
226  descriptions.add("hltScoutingEgammaProducer", desc);
227 }
228 
229 // declare this class as a framework plugin
helper::MatcherGetRef< C >::ref_type getRef(const Handle< C > &c, size_t k)
Definition: getRef.h:28
bool isAvailable() const
Definition: Ref.h:575
const edm::EDGetTokenT< RecoEcalCandMap > SigmaIEtaIEtaMap_
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:125
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:517
def setup(process, global_tag, zero_tesla=False)
Definition: GeneralSetup.py:2
const edm::EDGetTokenT< reco::GsfTrackCollection > EgammaGsfTrackCollection_
const edm::EDGetTokenT< RecoEcalCandMap > EleGsfTrackIsoMap_
const edm::EDGetTokenT< RecoEcalCandMap > HoverEMap_
const edm::EDGetTokenT< reco::RecoEcalCandidateCollection > EgammaCandidateCollection_
int iEvent
Definition: GenABIO.cc:224
const edm::EDGetTokenT< RecoEcalCandMap > DetaMap_
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:16
std::vector< GsfTrack > GsfTrackCollection
collection of GsfTracks
Definition: GsfTrackFwd.h:9
ParameterDescriptionBase * add(U const &iLabel, T const &value)
bool isNull() const
Checks for null.
Definition: Ref.h:248
std::vector< ScoutingElectron > ScoutingElectronCollection
void produce(edm::StreamID sid, edm::Event &iEvent, edm::EventSetup const &setup) const final
const edm::EDGetTokenT< RecoEcalCandMap > OneOEMinusOneOPMap_
const edm::EDGetTokenT< RecoEcalCandMap > MissingHitsMap_
const edm::EDGetTokenT< RecoEcalCandMap > DphiMap_
REF castTo() const
Definition: RefToBase.h:289
void add(std::string const &label, ParameterSetDescription const &psetDescription)
static void fillDescriptions(edm::ConfigurationDescriptions &descriptions)
std::vector< RecoEcalCandidate > RecoEcalCandidateCollection
collectin of RecoEcalCandidate objects
fixed size matrix
HLT enums.
~HLTScoutingEgammaProducer() override
const edm::EDGetTokenT< RecoEcalCandMap > HcalPFClusterIsoMap_
std::vector< ScoutingPhoton > ScoutingPhotonCollection
def move(src, dest)
Definition: eostools.py:511
const edm::EDGetTokenT< RecoEcalCandMap > EcalPFClusterIsoMap_
HLTScoutingEgammaProducer(const edm::ParameterSet &)