1 #ifndef RecoJets_JetProducers_plugins_VirtualJetProducer_h
2 #define RecoJets_JetProducers_plugins_VirtualJetProducer_h
19 #include "fastjet/JetDefinition.hh"
20 #include "fastjet/ClusterSequence.hh"
21 #include "fastjet/ClusterSequenceArea.hh"
22 #include "fastjet/PseudoJet.hh"
23 #include "fastjet/GhostedAreaSpec.hh"
27 #include <boost/shared_ptr.hpp>
56 return fTag == JetType::PFJet;
62 return fTag == JetType::TrackJet;
65 return fTag == JetType::PFClusterJet;
68 return fTag == JetType::BasicJet;
81 typedef boost::shared_ptr<fastjet::JetDefinition::Plugin>
PluginPtr;
82 typedef boost::shared_ptr<fastjet::JetDefinition>
JetDefPtr;
85 typedef boost::shared_ptr<fastjet::RangeDefinition>
RangeDefPtr;
108 virtual void inputTowers();
114 virtual void copyConstituents(
const std::vector<fastjet::PseudoJet>&fjConstituents,
123 void offsetCorrectJets(std::vector<fastjet::PseudoJet> & orphanInput);
134 template<
typename T >
137 template<
typename T>
143 virtual std::vector<reco::CandidatePtr>
144 getConstituents(
const std::vector<fastjet::PseudoJet>&fjConstituents);
179 std::vector<edm::Ptr<reco::Candidate> >
inputs_;
boost::shared_ptr< fastjet::AreaDefinition > AreaDefinitionPtr
std::string jetType() const
reco::Particle::Point vertex_
static const HistoName names[]
edm::EDGetTokenT< reco::CandidateView > input_candidateview_token_
std::vector< fastjet::PseudoJet > fjJets_
virtual void produce(Event &, EventSetup const &)=0
Base class for all types of Jets.
boost::shared_ptr< fastjet::JetDefinition::Plugin > PluginPtr
std::string puSubtractorName_
std::vector< double > puCenters_
bool makeGenJet(const JetType::Type &fTag)
bool makeBasicJet(const JetType::Type &fTag)
static std::string const input
boost::shared_ptr< fastjet::RangeDefinition > RangeDefPtr
bool makeTrackJet(const JetType::Type &fTag)
bool makePFJet(const JetType::Type &fTag)
std::vector< fastjet::PseudoJet > fjInputs_
std::string jetCollInstanceName_
boost::shared_ptr< PileUpSubtractor > subtractor_
std::vector< edm::Ptr< reco::Candidate > > inputs_
ClusterSequencePtr fjClusterSeq_
math::XYZPoint Point
point in the space
std::string jetAlgorithm_
boost::shared_ptr< fastjet::JetDefinition > JetDefPtr
bool useDeterministicSeed_
std::auto_ptr< AnomalousTower > anomalousTowerDef_
ActiveAreaSpecPtr fjActiveArea_
bool makePFClusterJet(const JetType::Type &fTag)
edm::EDGetTokenT< reco::VertexCollection > input_vertex_token_
edm::EDGetTokenT< std::vector< edm::FwdPtr< reco::PFCandidate > > > input_candidatefwdptr_token_
boost::shared_ptr< fastjet::GhostedAreaSpec > ActiveAreaSpecPtr
AreaDefinitionPtr fjAreaDefinition_
bool makeCaloJet(const JetType::Type &fTag)
bool doFastJetNonUniform_
boost::shared_ptr< fastjet::ClusterSequence > ClusterSequencePtr
JetDefPtr fjJetDefinition_