Main Page
Namespaces
Classes
Package Documentation
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Properties
Friends
Macros
Pages
HLTriggerOffline
Tau
interface
HLTTauMCProducer.h
Go to the documentation of this file.
1
/*HLTTauMCProducer
2
Producer that creates LorentzVector Collections
3
from offline reconstructed quantities to be used
4
in Offline Trigger DQM etc
5
*/
6
7
#ifndef HLTTauMCProducer_h
8
#define HLTTauMCProducer_h
9
10
#include "
FWCore/Framework/interface/Frameworkfwd.h
"
11
#include "
FWCore/Framework/interface/EDProducer.h
"
12
#include "
FWCore/Framework/interface/Event.h
"
13
#include "
FWCore/ParameterSet/interface/ParameterSet.h
"
14
#include "
FWCore/Utilities/interface/InputTag.h
"
15
#include "
DataFormats/Common/interface/Handle.h
"
16
#include "
FWCore/MessageLogger/interface/MessageLogger.h
"
17
#include "
SimDataFormats/GeneratorProducts/interface/HepMCProduct.h
"
18
#include "
DataFormats/HepMCCandidate/interface/GenParticle.h
"
19
#include "
DataFormats/HepMCCandidate/interface/GenParticleFwd.h
"
20
#include "
DataFormats/Candidate/interface/Candidate.h
"
21
#include "
DataFormats/Math/interface/LorentzVector.h
"
22
#include "HepMC/GenEvent.h"
23
#include <vector>
24
#include <string>
25
#include "TLorentzVector.h"
26
27
typedef
math::XYZTLorentzVectorD
LorentzVector
;
28
typedef
std::vector<LorentzVector>
LorentzVectorCollection
;
29
30
class
HLTTauMCProducer
:
public
edm::EDProducer
{
31
32
public
:
33
explicit
HLTTauMCProducer
(
const
edm::ParameterSet
&);
34
~HLTTauMCProducer
();
35
36
virtual
void
produce
(
edm::Event
&,
const
edm::EventSetup
&);
37
38
private
:
39
40
void
getGenDecayProducts
(
const
reco::GenParticleRef
&,
reco::GenParticleRefVector
&,
41
int
status
=1,
int
pdgId
=0);
42
43
enum
tauDecayModes
{
kElectron
,
kMuon
,
44
kOneProng0pi0
,
kOneProng1pi0
,
kOneProng2pi0
,
45
kThreeProng0pi0
,
kThreeProng1pi0
,
46
kOther
,
kUndefined
};
47
48
edm::EDGetTokenT<reco::GenParticleCollection>
MC_
;
49
double
ptMinMCTau_
;
50
double
ptMinMCElectron_
;
51
double
ptMinMCMuon_
;
52
std::vector<int>
m_PDG_
;
53
double
etaMax
;
54
55
};
56
57
#endif
HLTTauMCProducer::ptMinMCTau_
double ptMinMCTau_
Definition:
HLTTauMCProducer.h:49
MessageLogger.h
HLTTauMCProducer::kMuon
Definition:
HLTTauMCProducer.h:43
math::XYZTLorentzVectorD
ROOT::Math::LorentzVector< ROOT::Math::PxPyPzE4D< double > > XYZTLorentzVectorD
Lorentz vector with cylindrical internal representation using pseudorapidity.
Definition:
LorentzVector.h:14
HLTTauMCProducer
Definition:
HLTTauMCProducer.h:30
HLTTauMCProducer::m_PDG_
std::vector< int > m_PDG_
Definition:
HLTTauMCProducer.h:52
edm::Ref< GenParticleCollection >
HLTTauMCProducer::tauDecayModes
tauDecayModes
Definition:
HLTTauMCProducer.h:43
GenParticle.h
Event.h
HLTTauMCProducer::MC_
edm::EDGetTokenT< reco::GenParticleCollection > MC_
Definition:
HLTTauMCProducer.h:48
Handle.h
edm::EDGetTokenT< reco::GenParticleCollection >
Frameworkfwd.h
edm::EDProducer
Definition:
EDProducer.h:35
ParameterSet.h
HLTTauMCProducer::~HLTTauMCProducer
~HLTTauMCProducer()
Definition:
HLTTauMCProducer.cc:31
Candidate.h
HLTTauMCProducer::HLTTauMCProducer
HLTTauMCProducer(const edm::ParameterSet &)
Definition:
HLTTauMCProducer.cc:7
HLTTauMCProducer::getGenDecayProducts
void getGenDecayProducts(const reco::GenParticleRef &, reco::GenParticleRefVector &, int status=1, int pdgId=0)
Definition:
HLTTauMCProducer.cc:253
HLTTauMCProducer::etaMax
double etaMax
Definition:
HLTTauMCProducer.h:53
HLTTauMCProducer::kThreeProng0pi0
Definition:
HLTTauMCProducer.h:45
HLTTauMCProducer::ptMinMCMuon_
double ptMinMCMuon_
Definition:
HLTTauMCProducer.h:51
GenParticleFwd.h
edm::EventSetup
Definition:
EventSetup.h:44
LorentzVector.h
HepMCProduct.h
LorentzVectorCollection
std::vector< LorentzVector > LorentzVectorCollection
Definition:
HLTTauMCProducer.h:28
EDProducer.h
HLTTauMCProducer::kUndefined
Definition:
HLTTauMCProducer.h:46
HLTTauMCProducer::kOneProng2pi0
Definition:
HLTTauMCProducer.h:44
HLTTauMCProducer::kThreeProng1pi0
Definition:
HLTTauMCProducer.h:45
HLTTauMCProducer::kOneProng1pi0
Definition:
HLTTauMCProducer.h:44
edm::RefVector< GenParticleCollection >
HLTTauMCProducer::kOther
Definition:
HLTTauMCProducer.h:46
HLTTauMCProducer::ptMinMCElectron_
double ptMinMCElectron_
Definition:
HLTTauMCProducer.h:50
HLTTauMCProducer::produce
virtual void produce(edm::Event &, const edm::EventSetup &)
Definition:
HLTTauMCProducer.cc:33
HLTTauMCProducer::kOneProng0pi0
Definition:
HLTTauMCProducer.h:44
HLTTauMCProducer::kElectron
Definition:
HLTTauMCProducer.h:43
InputTag.h
edm::ParameterSet
Definition:
ParameterSet.h:36
benchmark_cfg.pdgId
tuple pdgId
Definition:
benchmark_cfg.py:18
ntuplemaker.status
tuple status
Definition:
ntuplemaker.py:245
edm::Event
Definition:
Event.h:61
reco::JetExtendedAssociation::LorentzVector
math::PtEtaPhiELorentzVectorF LorentzVector
Definition:
JetExtendedAssociation.h:25
Generated for CMSSW Reference Manual by
1.8.5