test
CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Member Functions | Private Types | Private Member Functions | Private Attributes
HLTTauRefProducer Class Reference

#include <HLTTauRefProducer.h>

Inheritance diagram for HLTTauRefProducer:
edm::EDProducer edm::ProducerBase edm::EDConsumerBase edm::ProductRegistryHelper

Public Member Functions

 HLTTauRefProducer (const edm::ParameterSet &)
 
virtual void produce (edm::Event &, const edm::EventSetup &)
 
 ~HLTTauRefProducer ()
 
- Public Member Functions inherited from edm::EDProducer
 EDProducer ()
 
ModuleDescription const & moduleDescription () const
 
virtual ~EDProducer ()
 
- Public Member Functions inherited from edm::ProducerBase
void callWhenNewProductsRegistered (std::function< void(BranchDescription const &)> const &func)
 
std::vector
< edm::ProductResolverIndex >
const & 
indiciesForPutProducts (BranchType iBranchType) const
 
 ProducerBase ()
 
void registerProducts (ProducerBase *, ProductRegistry *, ModuleDescription const &)
 
std::function< void(BranchDescription
const &)> 
registrationCallback () const
 used by the fwk to register list of products More...
 
void resolvePutIndicies (BranchType iBranchType, std::unordered_multimap< std::string, edm::ProductResolverIndex > const &iIndicies, std::string const &moduleLabel)
 
virtual ~ProducerBase () noexcept(false)
 
- Public Member Functions inherited from edm::EDConsumerBase
std::vector< ConsumesInfoconsumesInfo () const
 
 EDConsumerBase ()
 
 EDConsumerBase (EDConsumerBase const &)=delete
 
 EDConsumerBase (EDConsumerBase &&)=default
 
ProductResolverIndexAndSkipBit indexFrom (EDGetToken, BranchType, TypeID const &) const
 
void itemsMayGet (BranchType, std::vector< ProductResolverIndexAndSkipBit > &) const
 
void itemsToGet (BranchType, std::vector< ProductResolverIndexAndSkipBit > &) const
 
std::vector
< ProductResolverIndexAndSkipBit >
const & 
itemsToGetFromEvent () const
 
void labelsForToken (EDGetToken iToken, Labels &oLabels) const
 
void modulesWhoseProductsAreConsumed (std::vector< ModuleDescription const * > &modules, ProductRegistry const &preg, std::map< std::string, ModuleDescription const * > const &labelsToDesc, std::string const &processName) const
 
EDConsumerBase const & operator= (EDConsumerBase const &)=delete
 
EDConsumerBaseoperator= (EDConsumerBase &&)=default
 
bool registeredToConsume (ProductResolverIndex, bool, BranchType) const
 
bool registeredToConsumeMany (TypeID const &, BranchType) const
 
void updateLookup (BranchType iBranchType, ProductResolverIndexHelper const &, bool iPrefetchMayGet)
 
virtual ~EDConsumerBase () noexcept(false)
 

Private Types

typedef math::XYZTLorentzVectorD LorentzVector
 
typedef std::vector
< LorentzVector
LorentzVectorCollection
 

Private Member Functions

void doElectrons (edm::Event &, const edm::EventSetup &)
 
void doElectronsFromZ (edm::Event &, const edm::EventSetup &, std::unique_ptr< LorentzVectorCollection > &)
 
void doJets (edm::Event &, const edm::EventSetup &)
 
void doMET (edm::Event &, const edm::EventSetup &)
 
void doMuons (edm::Event &, const edm::EventSetup &)
 
void doPFTaus (edm::Event &, const edm::EventSetup &)
 
void doPhotons (edm::Event &, const edm::EventSetup &)
 
void doTowers (edm::Event &, const edm::EventSetup &)
 
double ElectronTrkIsolation (const reco::TrackCollection *, const reco::GsfElectron &)
 

Private Attributes

bool doElecFromZ_
 
bool doElectrons_
 
bool doJets_
 
bool doMET_
 
bool doMuons_
 
bool doPFTaus_
 
bool doPhotons_
 
bool doTowers_
 
edm::EDGetTokenT
< reco::TrackCollection
e_ctfTrackCollection_
 
edm::InputTag e_ctfTrackCollectionSrc_
 
bool e_doID_
 
bool e_doTrackIso_
 
double e_FromZet_
 
edm::EDGetTokenT
< reco::ElectronIDAssociationCollection
e_idAssocProd_
 
double e_isoMaxSumPt_
 
double e_lipCut_
 
double e_maxIsoDR_
 
double e_minIsoDR_
 
double e_trackMinPt_
 
double e_zMmax_
 
double e_zMmin_
 
edm::EDGetTokenT
< reco::GsfElectronCollection
Electrons_
 
double etaMax
 
edm::EDGetTokenT
< reco::CaloJetCollection
Jets_
 
edm::EDGetTokenT
< reco::CaloMETCollection
MET_
 
edm::EDGetTokenT
< reco::MuonCollection
Muons_
 
std::vector< edm::EDGetTokenT
< reco::PFTauDiscriminator > > 
PFTauDis_
 
edm::EDGetTokenT
< reco::PFTauCollection
PFTaus_
 
double photonEcalIso_
 
edm::EDGetTokenT
< reco::PhotonCollection
Photons_
 
double ptMinElectron_
 
double ptMinJet_
 
double ptMinMET_
 
double ptMinMuon_
 
double ptMinPFTau_
 
double ptMinPhoton_
 
double ptMinTower_
 
double towerIsol_
 
edm::EDGetTokenT
< CaloTowerCollection
Towers_
 

Additional Inherited Members

- Public Types inherited from edm::EDProducer
typedef EDProducer ModuleType
 
- Public Types inherited from edm::ProducerBase
typedef
ProductRegistryHelper::TypeLabelList 
TypeLabelList
 
- Public Types inherited from edm::EDConsumerBase
typedef ProductLabels Labels
 
- Static Public Member Functions inherited from edm::EDProducer
static const std::string & baseType ()
 
static void fillDescriptions (ConfigurationDescriptions &descriptions)
 
static void prevalidate (ConfigurationDescriptions &descriptions)
 
- Protected Member Functions inherited from edm::EDConsumerBase
template<typename ProductType , BranchType B = InEvent>
EDGetTokenT< ProductType > consumes (edm::InputTag const &tag)
 
EDGetToken consumes (const TypeToGet &id, edm::InputTag const &tag)
 
template<BranchType B>
EDGetToken consumes (TypeToGet const &id, edm::InputTag const &tag)
 
ConsumesCollector consumesCollector ()
 Use a ConsumesCollector to gather consumes information from helper functions. More...
 
template<typename ProductType , BranchType B = InEvent>
void consumesMany ()
 
void consumesMany (const TypeToGet &id)
 
template<BranchType B>
void consumesMany (const TypeToGet &id)
 
template<typename ProductType , BranchType B = InEvent>
EDGetTokenT< ProductType > mayConsume (edm::InputTag const &tag)
 
EDGetToken mayConsume (const TypeToGet &id, edm::InputTag const &tag)
 
template<BranchType B>
EDGetToken mayConsume (const TypeToGet &id, edm::InputTag const &tag)
 

Detailed Description

Definition at line 52 of file HLTTauRefProducer.h.

Member Typedef Documentation

Definition at line 61 of file HLTTauRefProducer.h.

Definition at line 62 of file HLTTauRefProducer.h.

Constructor & Destructor Documentation

HLTTauRefProducer::HLTTauRefProducer ( const edm::ParameterSet iConfig)
explicit

Definition at line 33 of file HLTTauRefProducer.cc.

References HI_PhotonSkim_cff::electrons, HLT_25ns10e33_v2_cff::etaMax, edm::ParameterSet::getUntrackedParameter(), fwrapper::jets, objects.METAnalyzer::met, patZpeak::muons, interactiveExample::photons, GlobalPosition_Frontier_DevDB_cff::tag, and HLT_25ns10e33_v2_cff::towers.

34 {
35 
36 
37  //One Parameter Set per Collection
38 
39  ParameterSet pfTau = iConfig.getUntrackedParameter<edm::ParameterSet>("PFTaus");
40  PFTaus_ = consumes<reco::PFTauCollection>(pfTau.getUntrackedParameter<InputTag>("PFTauProducer"));
41  auto discs = pfTau.getUntrackedParameter<std::vector<InputTag> >("PFTauDiscriminators");
42  for(edm::InputTag& tag: discs) {
43  PFTauDis_.push_back(consumes<reco::PFTauDiscriminator>(tag));
44  }
45  doPFTaus_ = pfTau.getUntrackedParameter<bool>("doPFTaus",false);
46  ptMinPFTau_= pfTau.getUntrackedParameter<double>("ptMin",15.);
47 
49  Electrons_ = consumes<reco::GsfElectronCollection>(electrons.getUntrackedParameter<InputTag>("ElectronCollection"));
50  doElectrons_ = electrons.getUntrackedParameter<bool>("doElectrons",false);
51  e_doID_ = electrons.getUntrackedParameter<bool>("doID",false);
52  if(e_doID_) {
53  e_idAssocProd_ = consumes<reco::ElectronIDAssociationCollection>(electrons.getUntrackedParameter<InputTag>("IdCollection"));
54  }
55  e_ctfTrackCollectionSrc_ = electrons.getUntrackedParameter<InputTag>("TrackCollection");
56  e_ctfTrackCollection_ = consumes<reco::TrackCollection>(e_ctfTrackCollectionSrc_);
57  ptMinElectron_= electrons.getUntrackedParameter<double>("ptMin",15.);
58  e_doTrackIso_ = electrons.getUntrackedParameter<bool>("doTrackIso",false);
59  e_trackMinPt_= electrons.getUntrackedParameter<double>("ptMinTrack",1.5);
60  e_lipCut_= electrons.getUntrackedParameter<double>("lipMinTrack",1.5);
61  e_minIsoDR_= electrons.getUntrackedParameter<double>("InnerConeDR",0.02);
62  e_maxIsoDR_= electrons.getUntrackedParameter<double>("OuterConeDR",0.6);
63  e_isoMaxSumPt_= electrons.getUntrackedParameter<double>("MaxIsoVar",0.02);
64 
66  Muons_ = consumes<reco::MuonCollection>(muons.getUntrackedParameter<InputTag>("MuonCollection"));
67  doMuons_ = muons.getUntrackedParameter<bool>("doMuons",false);
68  ptMinMuon_= muons.getUntrackedParameter<double>("ptMin",15.);
69 
71  Jets_ = consumes<reco::CaloJetCollection>(jets.getUntrackedParameter<InputTag>("JetCollection"));
72  doJets_ = jets.getUntrackedParameter<bool>("doJets");
73  ptMinJet_= jets.getUntrackedParameter<double>("etMin");
74 
76  Towers_ = consumes<CaloTowerCollection>(towers.getUntrackedParameter<InputTag>("TowerCollection"));
77  doTowers_ = towers.getUntrackedParameter<bool>("doTowers");
78  ptMinTower_= towers.getUntrackedParameter<double>("etMin");
79  towerIsol_= towers.getUntrackedParameter<double>("towerIsolation");
80 
82  Photons_ = consumes<reco::PhotonCollection>(photons.getUntrackedParameter<InputTag>("PhotonCollection"));
83  doPhotons_ = photons.getUntrackedParameter<bool>("doPhotons");
84  ptMinPhoton_= photons.getUntrackedParameter<double>("etMin");
85  photonEcalIso_= photons.getUntrackedParameter<double>("ECALIso");
86 
88  MET_ = consumes<reco::CaloMETCollection>(met.getUntrackedParameter<InputTag>("METCollection"));
89  doMET_ = met.getUntrackedParameter<bool>("doMET",false);
90  ptMinMET_= met.getUntrackedParameter<double>("ptMin",15.);
91 
92 
93  etaMax = iConfig.getUntrackedParameter<double>("EtaMax",2.5);
94 
95 
96  //recoCollections
97  produces<LorentzVectorCollection>("PFTaus");
98  produces<LorentzVectorCollection>("Electrons");
99  produces<LorentzVectorCollection>("Muons");
100  produces<LorentzVectorCollection>("Jets");
101  produces<LorentzVectorCollection>("Photons");
102  produces<LorentzVectorCollection>("Towers");
103  produces<LorentzVectorCollection>("MET");
104 
105 }
T getUntrackedParameter(std::string const &, T const &) const
edm::EDGetTokenT< reco::MuonCollection > Muons_
edm::EDGetTokenT< reco::CaloMETCollection > MET_
edm::EDGetTokenT< reco::GsfElectronCollection > Electrons_
edm::EDGetTokenT< reco::TrackCollection > e_ctfTrackCollection_
vector< PseudoJet > jets
edm::EDGetTokenT< CaloTowerCollection > Towers_
edm::EDGetTokenT< reco::PhotonCollection > Photons_
edm::EDGetTokenT< reco::PFTauCollection > PFTaus_
edm::EDGetTokenT< reco::ElectronIDAssociationCollection > e_idAssocProd_
std::vector< edm::EDGetTokenT< reco::PFTauDiscriminator > > PFTauDis_
edm::InputTag e_ctfTrackCollectionSrc_
tuple muons
Definition: patZpeak.py:38
edm::EDGetTokenT< reco::CaloJetCollection > Jets_
HLTTauRefProducer::~HLTTauRefProducer ( )

Definition at line 107 of file HLTTauRefProducer.cc.

107 { }

Member Function Documentation

void HLTTauRefProducer::doElectrons ( edm::Event iEvent,
const edm::EventSetup iES 
)
private

Definition at line 163 of file HLTTauRefProducer.cc.

References edm::AssociationMap< edm::OneToOne< GsfElectronCollection, ElectronIDCollection > >::const_iterator, HI_PhotonSkim_cff::electrons, relval_parameters_module::energy, eta, HLT_25ns10e33_v2_cff::etaMax, edm::Event::getByToken(), i, xuti::id_tag(), edm::HandleBase::isValid(), HLT_25ns10e33_v2_cff::lip, eostools::move(), edm::Handle< T >::product(), EnergyCorrector::pt, edm::Event::put(), and mathSSE::sqrt().

164 {
165  unique_ptr<LorentzVectorCollection> product_Electrons(new LorentzVectorCollection);
166  //Retrieve the collections
167 
169  if(e_doID_){//UGLY HACK UNTIL GET ELETRON ID WORKING IN 210
170 
171  iEvent.getByToken(e_idAssocProd_, pEleID);
172 
173  if (!pEleID.isValid()){
174  edm::LogInfo("")<< "Error! Can't get electronIDAssocProducer by label. ";
175  e_doID_ = false;
176  }
177  }
179  iEvent.getByToken(e_ctfTrackCollection_, pCtfTracks);
180  if (!pCtfTracks.isValid()) {
181  edm::LogInfo("")<< "Error! Can't get " << e_ctfTrackCollectionSrc_.label() << " by label. ";
182  iEvent.put(std::move(product_Electrons),"Electrons");
183  return;
184  }
185  const reco::TrackCollection * ctfTracks = pCtfTracks.product();
187  if(iEvent.getByToken(Electrons_,electrons))
188  for(size_t i=0;i<electrons->size();++i)
189  {
190  edm::Ref<reco::GsfElectronCollection> electronRef(electrons,i);
191  bool idDec=false;
192  if(e_doID_){
194  tagIDAssocItr = pEleID->find(electronRef);
195  const reco::ElectronIDRef& id_tag = tagIDAssocItr->val;
196  idDec=id_tag->cutBasedDecision();
197  }else idDec=true;
198  if((*electrons)[i].pt()>ptMinElectron_&&fabs((*electrons)[i].eta())<etaMax&&idDec)
199  {
200  if(e_doTrackIso_){
201  reco::TrackCollection::const_iterator tr = ctfTracks->begin();
202  double sum_of_pt_ele=0;
203  for(;tr != ctfTracks->end();++tr)
204  {
205  double lip = (*electrons)[i].gsfTrack()->dz() - tr->dz();
206  if(tr->pt() > e_trackMinPt_ && fabs(lip) < e_lipCut_){
207  double dphi=fabs(tr->phi()-(*electrons)[i].trackMomentumAtVtx().phi());
208  if(dphi>acos(-1.))dphi=2*acos(-1.)-dphi;
209  double deta=fabs(tr->eta()-(*electrons)[i].trackMomentumAtVtx().eta());
210  double dr_ctf_ele = sqrt(deta*deta+dphi*dphi);
211  if((dr_ctf_ele>e_minIsoDR_) && (dr_ctf_ele<e_maxIsoDR_)){
212  double cft_pt_2 = (tr->pt())*(tr->pt());
213  sum_of_pt_ele += cft_pt_2;
214  }
215  }
216  }
217  double isolation_value_ele = sum_of_pt_ele/((*electrons)[i].trackMomentumAtVtx().Rho()*(*electrons)[i].trackMomentumAtVtx().Rho());
218  if(isolation_value_ele<e_isoMaxSumPt_){
219  LorentzVector vec((*electrons)[i].px(),(*electrons)[i].py(),(*electrons)[i].pz(),(*electrons)[i].energy());
220  product_Electrons->push_back(vec);
221  }
222 
223  }
224  else{
225  LorentzVector vec((*electrons)[i].px(),(*electrons)[i].py(),(*electrons)[i].pz(),(*electrons)[i].energy());
226  product_Electrons->push_back(vec);
227  }
228  }
229  }
230 
231  iEvent.put(std::move(product_Electrons),"Electrons");
232 }
int i
Definition: DBlmapReader.cc:9
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:122
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:457
math::XYZTLorentzVector LorentzVector
const std::string id_tag("id")
std::vector< Track > TrackCollection
collection of Tracks
Definition: TrackFwd.h:14
edm::EDGetTokenT< reco::GsfElectronCollection > Electrons_
edm::EDGetTokenT< reco::TrackCollection > e_ctfTrackCollection_
T sqrt(T t)
Definition: SSEVec.h:18
def move
Definition: eostools.py:510
bool isValid() const
Definition: HandleBase.h:75
std::vector< LorentzVector > LorentzVectorCollection
edm::EDGetTokenT< reco::ElectronIDAssociationCollection > e_idAssocProd_
edm::InputTag e_ctfTrackCollectionSrc_
T const * product() const
Definition: Handle.h:81
std::string const & label() const
Definition: InputTag.h:36
void HLTTauRefProducer::doElectronsFromZ ( edm::Event ,
const edm::EventSetup ,
std::unique_ptr< LorentzVectorCollection > &   
)
private
void HLTTauRefProducer::doJets ( edm::Event iEvent,
const edm::EventSetup iES 
)
private

Definition at line 259 of file HLTTauRefProducer.cc.

References relval_parameters_module::energy, eta, HLT_25ns10e33_v2_cff::etaMax, edm::Event::getByToken(), i, fwrapper::jets, eostools::move(), and edm::Event::put().

260 {
261  unique_ptr<LorentzVectorCollection> product_Jets(new LorentzVectorCollection);
262  //Retrieve the collection
264  if(iEvent.getByToken(Jets_,jets))
265  for(size_t i = 0 ;i<jets->size();++i)
266  {
267  if((*jets)[i].et()>ptMinJet_&&fabs((*jets)[i].eta())<etaMax)
268  {
269  LorentzVector vec((*jets)[i].px(),(*jets)[i].py(),(*jets)[i].pz(),(*jets)[i].energy());
270  product_Jets->push_back(vec);
271  }
272  }
273  iEvent.put(std::move(product_Jets),"Jets");
274 }
int i
Definition: DBlmapReader.cc:9
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:122
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:457
math::XYZTLorentzVector LorentzVector
vector< PseudoJet > jets
def move
Definition: eostools.py:510
std::vector< LorentzVector > LorentzVectorCollection
edm::EDGetTokenT< reco::CaloJetCollection > Jets_
void HLTTauRefProducer::doMET ( edm::Event iEvent,
const edm::EventSetup iES 
)
private

Definition at line 326 of file HLTTauRefProducer.cc.

References edm::Event::getByToken(), objects.METAnalyzer::met, eostools::move(), EnergyCorrector::pt, and edm::Event::put().

327 {
328  unique_ptr<LorentzVectorCollection> product_MET(new LorentzVectorCollection);
329  //Retrieve the collection
331  if(iEvent.getByToken(MET_,met)){
332  double px = met->front().p4().Px();
333  double py = met->front().p4().Py();
334  double pt = met->front().p4().Pt();
335  LorentzVector vec(px,py,0,pt);
336  product_MET->push_back(vec);
337  }
338  iEvent.put(std::move(product_MET),"MET");
339 }
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:122
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:457
math::XYZTLorentzVector LorentzVector
edm::EDGetTokenT< reco::CaloMETCollection > MET_
def move
Definition: eostools.py:510
std::vector< LorentzVector > LorentzVectorCollection
void HLTTauRefProducer::doMuons ( edm::Event iEvent,
const edm::EventSetup iES 
)
private

Definition at line 235 of file HLTTauRefProducer.cc.

References relval_parameters_module::energy, eta, HLT_25ns10e33_v2_cff::etaMax, edm::Event::getByToken(), i, eostools::move(), patZpeak::muons, and edm::Event::put().

236 {
237  unique_ptr<LorentzVectorCollection> product_Muons(new LorentzVectorCollection);
238  //Retrieve the collection
240  if(iEvent.getByToken(Muons_,muons))
241 
242  for(size_t i = 0 ;i<muons->size();++i)
243  {
244 
245  if((*muons)[i].pt()>ptMinMuon_&&fabs((*muons)[i].eta())<etaMax)
246  {
247  LorentzVector vec((*muons)[i].px(),(*muons)[i].py(),(*muons)[i].pz(),(*muons)[i].energy());
248  product_Muons->push_back(vec);
249  }
250  }
251 
252 
253  iEvent.put(std::move(product_Muons),"Muons");
254 
255 }
int i
Definition: DBlmapReader.cc:9
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:122
edm::EDGetTokenT< reco::MuonCollection > Muons_
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:457
math::XYZTLorentzVector LorentzVector
def move
Definition: eostools.py:510
std::vector< LorentzVector > LorentzVectorCollection
tuple muons
Definition: patZpeak.py:38
void HLTTauRefProducer::doPFTaus ( edm::Event iEvent,
const edm::EventSetup iES 
)
private

Definition at line 128 of file HLTTauRefProducer.cc.

References relval_parameters_module::energy, eta, HLT_25ns10e33_v2_cff::etaMax, edm::Event::getByToken(), i, eostools::move(), edm::Event::put(), and unpackBuffers-CaloStage2::token.

129 {
130  unique_ptr<LorentzVectorCollection> product_PFTaus(new LorentzVectorCollection);
131  //Retrieve the collection
133  if(iEvent.getByToken(PFTaus_,pftaus)) {
134  for(unsigned int i=0; i<pftaus->size(); ++i) {
135  if((*pftaus)[i].pt()>ptMinPFTau_&&fabs((*pftaus)[i].eta())<etaMax)
136  {
137  reco::PFTauRef thePFTau(pftaus,i);
138  bool passAll = true;
141  if(iEvent.getByToken(token, pftaudis)) {
142  if((*pftaudis)[thePFTau] < 0.5) {
143  passAll = false;
144  break;
145  }
146  }else{
147  passAll = false;
148  break;
149  }
150  }
151  if(passAll) {
152  LorentzVector vec((*pftaus)[i].px(),(*pftaus)[i].py(),(*pftaus)[i].pz(),(*pftaus)[i].energy());
153  product_PFTaus->push_back(vec);
154  }
155  }
156  }
157  }
158  iEvent.put(std::move(product_PFTaus),"PFTaus");
159 }
int i
Definition: DBlmapReader.cc:9
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:122
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:457
math::XYZTLorentzVector LorentzVector
def move
Definition: eostools.py:510
edm::EDGetTokenT< reco::PFTauCollection > PFTaus_
std::vector< LorentzVector > LorentzVectorCollection
std::vector< edm::EDGetTokenT< reco::PFTauDiscriminator > > PFTauDis_
void HLTTauRefProducer::doPhotons ( edm::Event iEvent,
const edm::EventSetup iES 
)
private

Definition at line 307 of file HLTTauRefProducer.cc.

References relval_parameters_module::energy, eta, HLT_25ns10e33_v2_cff::etaMax, edm::Event::getByToken(), i, eostools::move(), interactiveExample::photons, and edm::Event::put().

308 {
309  unique_ptr<LorentzVectorCollection> product_Gammas(new LorentzVectorCollection);
310  //Retrieve the collection
312  if(iEvent.getByToken(Photons_,photons))
313  for(size_t i = 0 ;i<photons->size();++i)
314  if((*photons)[i].ecalRecHitSumEtConeDR04()<photonEcalIso_)
315  {
316  if((*photons)[i].et()>ptMinPhoton_&&fabs((*photons)[i].eta())<etaMax)
317  {
318  LorentzVector vec((*photons)[i].px(),(*photons)[i].py(),(*photons)[i].pz(),(*photons)[i].energy());
319  product_Gammas->push_back(vec);
320  }
321  }
322  iEvent.put(std::move(product_Gammas),"Photons");
323 }
int i
Definition: DBlmapReader.cc:9
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:122
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:457
math::XYZTLorentzVector LorentzVector
def move
Definition: eostools.py:510
edm::EDGetTokenT< reco::PhotonCollection > Photons_
std::vector< LorentzVector > LorentzVectorCollection
void HLTTauRefProducer::doTowers ( edm::Event iEvent,
const edm::EventSetup iES 
)
private

Definition at line 277 of file HLTTauRefProducer.cc.

References HLT_25ns10e33_v2_cff::DeltaR, relval_parameters_module::energy, eta, HLT_25ns10e33_v2_cff::etaMax, edm::Event::getByToken(), i, j, eostools::move(), p4, edm::Event::put(), and HLT_25ns10e33_v2_cff::towers.

278 {
279  unique_ptr<LorentzVectorCollection> product_Towers(new LorentzVectorCollection);
280  //Retrieve the collection
282  if(iEvent.getByToken(Towers_,towers))
283  for(size_t i = 0 ;i<towers->size();++i)
284  {
285  if((*towers)[i].pt()>ptMinTower_&&fabs((*towers)[i].eta())<etaMax)
286  {
287  //calculate isolation
288  double isolET=0;
289  for(unsigned int j=0;j<towers->size();++j)
290  {
291  if(ROOT::Math::VectorUtil::DeltaR((*towers)[i].p4(),(*towers)[j].p4())<0.5)
292  isolET+=(*towers)[j].pt();
293  }
294  isolET-=(*towers)[i].pt();
295  if(isolET<towerIsol_)
296  {
297  LorentzVector vec((*towers)[i].px(),(*towers)[i].py(),(*towers)[i].pz(),(*towers)[i].energy());
298  product_Towers->push_back(vec);
299  }
300  }
301  }
302  iEvent.put(std::move(product_Towers),"Towers");
303 }
int i
Definition: DBlmapReader.cc:9
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:122
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:457
math::XYZTLorentzVector LorentzVector
double p4[4]
Definition: TauolaWrapper.h:92
def move
Definition: eostools.py:510
int j
Definition: DBlmapReader.cc:9
edm::EDGetTokenT< CaloTowerCollection > Towers_
std::vector< LorentzVector > LorentzVectorCollection
double HLTTauRefProducer::ElectronTrkIsolation ( const reco::TrackCollection ,
const reco::GsfElectron  
)
private
void HLTTauRefProducer::produce ( edm::Event iEvent,
const edm::EventSetup iES 
)
virtual

Implements edm::EDProducer.

Definition at line 109 of file HLTTauRefProducer.cc.

Referenced by JSONExport.JsonExport::export(), HTMLExport.HTMLExport::export(), and HTMLExport.HTMLExportStatic::export().

110 {
111  if(doPFTaus_)
112  doPFTaus(iEvent,iES);
113  if(doElectrons_)
114  doElectrons(iEvent,iES);
115  if(doMuons_)
116  doMuons(iEvent,iES);
117  if(doJets_)
118  doJets(iEvent,iES);
119  if(doPhotons_)
120  doPhotons(iEvent,iES);
121  if(doTowers_)
122  doTowers(iEvent,iES);
123  if(doMET_)
124  doMET(iEvent,iES);
125 }
void doPFTaus(edm::Event &, const edm::EventSetup &)
void doTowers(edm::Event &, const edm::EventSetup &)
void doJets(edm::Event &, const edm::EventSetup &)
void doMET(edm::Event &, const edm::EventSetup &)
void doMuons(edm::Event &, const edm::EventSetup &)
void doPhotons(edm::Event &, const edm::EventSetup &)
void doElectrons(edm::Event &, const edm::EventSetup &)

Member Data Documentation

bool HLTTauRefProducer::doElecFromZ_
private

Definition at line 83 of file HLTTauRefProducer.h.

bool HLTTauRefProducer::doElectrons_
private

Definition at line 71 of file HLTTauRefProducer.h.

bool HLTTauRefProducer::doJets_
private

Definition at line 99 of file HLTTauRefProducer.h.

bool HLTTauRefProducer::doMET_
private

Definition at line 108 of file HLTTauRefProducer.h.

bool HLTTauRefProducer::doMuons_
private

Definition at line 94 of file HLTTauRefProducer.h.

bool HLTTauRefProducer::doPFTaus_
private

Definition at line 66 of file HLTTauRefProducer.h.

bool HLTTauRefProducer::doPhotons_
private

Definition at line 88 of file HLTTauRefProducer.h.

bool HLTTauRefProducer::doTowers_
private

Definition at line 103 of file HLTTauRefProducer.h.

edm::EDGetTokenT<reco::TrackCollection> HLTTauRefProducer::e_ctfTrackCollection_
private

Definition at line 73 of file HLTTauRefProducer.h.

edm::InputTag HLTTauRefProducer::e_ctfTrackCollectionSrc_
private

Definition at line 74 of file HLTTauRefProducer.h.

bool HLTTauRefProducer::e_doID_
private

Definition at line 76 of file HLTTauRefProducer.h.

bool HLTTauRefProducer::e_doTrackIso_
private

Definition at line 77 of file HLTTauRefProducer.h.

double HLTTauRefProducer::e_FromZet_
private

Definition at line 85 of file HLTTauRefProducer.h.

edm::EDGetTokenT<reco::ElectronIDAssociationCollection> HLTTauRefProducer::e_idAssocProd_
private

Definition at line 72 of file HLTTauRefProducer.h.

double HLTTauRefProducer::e_isoMaxSumPt_
private

Definition at line 82 of file HLTTauRefProducer.h.

double HLTTauRefProducer::e_lipCut_
private

Definition at line 79 of file HLTTauRefProducer.h.

double HLTTauRefProducer::e_maxIsoDR_
private

Definition at line 81 of file HLTTauRefProducer.h.

double HLTTauRefProducer::e_minIsoDR_
private

Definition at line 80 of file HLTTauRefProducer.h.

double HLTTauRefProducer::e_trackMinPt_
private

Definition at line 78 of file HLTTauRefProducer.h.

double HLTTauRefProducer::e_zMmax_
private

Definition at line 84 of file HLTTauRefProducer.h.

double HLTTauRefProducer::e_zMmin_
private

Definition at line 84 of file HLTTauRefProducer.h.

edm::EDGetTokenT<reco::GsfElectronCollection> HLTTauRefProducer::Electrons_
private

Definition at line 70 of file HLTTauRefProducer.h.

double HLTTauRefProducer::etaMax
private

Definition at line 111 of file HLTTauRefProducer.h.

edm::EDGetTokenT<reco::CaloJetCollection> HLTTauRefProducer::Jets_
private

Definition at line 98 of file HLTTauRefProducer.h.

edm::EDGetTokenT<reco::CaloMETCollection> HLTTauRefProducer::MET_
private

Definition at line 107 of file HLTTauRefProducer.h.

edm::EDGetTokenT<reco::MuonCollection> HLTTauRefProducer::Muons_
private

Definition at line 93 of file HLTTauRefProducer.h.

std::vector<edm::EDGetTokenT<reco::PFTauDiscriminator> > HLTTauRefProducer::PFTauDis_
private

Definition at line 65 of file HLTTauRefProducer.h.

edm::EDGetTokenT<reco::PFTauCollection> HLTTauRefProducer::PFTaus_
private

Definition at line 64 of file HLTTauRefProducer.h.

double HLTTauRefProducer::photonEcalIso_
private

Definition at line 89 of file HLTTauRefProducer.h.

edm::EDGetTokenT<reco::PhotonCollection> HLTTauRefProducer::Photons_
private

Definition at line 87 of file HLTTauRefProducer.h.

double HLTTauRefProducer::ptMinElectron_
private

Definition at line 75 of file HLTTauRefProducer.h.

double HLTTauRefProducer::ptMinJet_
private

Definition at line 100 of file HLTTauRefProducer.h.

double HLTTauRefProducer::ptMinMET_
private

Definition at line 109 of file HLTTauRefProducer.h.

double HLTTauRefProducer::ptMinMuon_
private

Definition at line 95 of file HLTTauRefProducer.h.

double HLTTauRefProducer::ptMinPFTau_
private

Definition at line 67 of file HLTTauRefProducer.h.

double HLTTauRefProducer::ptMinPhoton_
private

Definition at line 90 of file HLTTauRefProducer.h.

double HLTTauRefProducer::ptMinTower_
private

Definition at line 104 of file HLTTauRefProducer.h.

double HLTTauRefProducer::towerIsol_
private

Definition at line 105 of file HLTTauRefProducer.h.

edm::EDGetTokenT<CaloTowerCollection> HLTTauRefProducer::Towers_
private

Definition at line 102 of file HLTTauRefProducer.h.