#include <CaloTowerCreatorForTauHLT.h>
Public Member Functions | |
CaloTowerCreatorForTauHLT (const edm::ParameterSet &) | |
constructor from parameter set | |
~CaloTowerCreatorForTauHLT () | |
destructor | |
Private Member Functions | |
void | produce (edm::Event &e, const edm::EventSetup &) override |
process one event | |
Private Attributes | |
double | mCone |
use only towers in cone mCone around L1 candidate for regional jet reco | |
double | mEThreshold |
E threshold. | |
double | mEtThreshold |
ET threshold. | |
edm::InputTag | ml1seeds |
imitator of L1 seeds | |
int | mTauId |
edm::InputTag | mTauTrigger |
label of tau trigger type analysis | |
edm::InputTag | mtowers |
label of source collection | |
int | mVerbose |
verbosity |
Framework module that produces a collection of calo towers in the region of interest for Tau HLT reconnstruction, depending on tau type trigger: Tau1 - take location of 1st L1 Tau Tau2 - take location of 2nd L1 Tau; if does not exists, take location of 1st Calo Tower ETau - take L1 Tau candidate which is not collinear to HLT (or L1) electron candidate.
Definition at line 27 of file CaloTowerCreatorForTauHLT.h.
CaloTowerCreatorForTauHLT::CaloTowerCreatorForTauHLT | ( | const edm::ParameterSet & | p | ) |
constructor from parameter set
Definition at line 23 of file CaloTowerCreatorForTauHLT.cc.
: mVerbose (p.getUntrackedParameter<int> ("verbose", 0)), mtowers (p.getParameter<InputTag> ("towers")), mCone (p.getParameter<double> ("UseTowersInCone")), mTauTrigger (p.getParameter<InputTag> ("TauTrigger")), // ml1seeds (p.getParameter<InputTag> ("l1seeds")), mEtThreshold (p.getParameter<double> ("minimumEt")), mEThreshold (p.getParameter<double> ("minimumE")), mTauId (p.getParameter<int> ("TauId")) { produces<CaloTowerCollection>(); }
CaloTowerCreatorForTauHLT::~CaloTowerCreatorForTauHLT | ( | ) |
void CaloTowerCreatorForTauHLT::produce | ( | edm::Event & | e, |
const edm::EventSetup & | |||
) | [override, private, virtual] |
process one event
Implements edm::EDProducer.
Definition at line 40 of file CaloTowerCreatorForTauHLT.cc.
References HiRecoJets_cff::caloTowers, gather_cfg::cout, delta, reco::LeafCandidate::energy(), CaloTower::et(), reco::LeafCandidate::eta(), edm::Event::getByLabel(), customizeTrackingMonitorSeedNumber::idx, mCone, mEThreshold, mEtThreshold, mTauId, mTauTrigger, mtowers, mVerbose, AlCaHLTBitMon_ParallelJobs::p, reco::LeafCandidate::phi(), and edm::Event::put().
{ edm::Handle<CaloTowerCollection> caloTowers; evt.getByLabel( mtowers, caloTowers ); // imitate L1 seeds edm::Handle<L1JetParticleCollection> jetsgen; evt.getByLabel(mTauTrigger, jetsgen); std::auto_ptr<CaloTowerCollection> cands( new CaloTowerCollection ); cands->reserve( caloTowers->size() ); int idTau =0; L1JetParticleCollection::const_iterator myL1Jet = jetsgen->begin(); for(;myL1Jet != jetsgen->end();myL1Jet++) { if(idTau == mTauId) { double Sum08 = 0.; unsigned idx = 0; for (; idx < caloTowers->size(); idx++) { const CaloTower* cal = &((*caloTowers) [idx]); if (mVerbose == 2) { std::cout << "CaloTowerCreatorForTauHLT::produce-> " << idx << " tower et/eta/phi/e: " << cal->et() << '/' << cal->eta() << '/' << cal->phi() << '/' << cal->energy() << " is..."; } if (cal->et() >= mEtThreshold && cal->energy() >= mEThreshold ) { math::PtEtaPhiELorentzVector p( cal->et(), cal->eta(), cal->phi(), cal->energy() ); double delta = ROOT::Math::VectorUtil::DeltaR((*myL1Jet).p4().Vect(), p); if(delta < mCone) { Sum08 += cal->et(); cands->push_back( *cal ); } } else { if (mVerbose == 2) std::cout << "rejected " << std::endl; } } } idTau++; } evt.put( cands ); }
double CaloTowerCreatorForTauHLT::mCone [private] |
use only towers in cone mCone around L1 candidate for regional jet reco
Definition at line 42 of file CaloTowerCreatorForTauHLT.h.
Referenced by produce().
double CaloTowerCreatorForTauHLT::mEThreshold [private] |
double CaloTowerCreatorForTauHLT::mEtThreshold [private] |
imitator of L1 seeds
Definition at line 46 of file CaloTowerCreatorForTauHLT.h.
int CaloTowerCreatorForTauHLT::mTauId [private] |
Definition at line 53 of file CaloTowerCreatorForTauHLT.h.
Referenced by produce().
label of tau trigger type analysis
Definition at line 44 of file CaloTowerCreatorForTauHLT.h.
Referenced by produce().
label of source collection
Definition at line 40 of file CaloTowerCreatorForTauHLT.h.
Referenced by produce().
int CaloTowerCreatorForTauHLT::mVerbose [private] |