1 #ifndef RecoMuon_L3MuonProducer_L3TkMuonProducer_H
2 #define RecoMuon_L3MuonProducer_L3TkMuonProducer_H
46 typedef std::pair<unsigned int,unsigned int>
pseudoRef;
47 typedef std::map<pseudoRef, std::pair<reco::TrackRef,SeedRef> >
LXtoL3sMap;
53 return std::make_pair(l1ref.
id().
id(),l1ref.
key());
54 }
else return std::make_pair(l2ref.
id().
id(),l2ref.
key());
64 if (l2ref1.
isNull()) pt1=s1->l1Particle()->pt();
65 else pt1=l2ref1->pt();
67 if (l2ref2.
isNull()) pt2=s2->l1Particle()->pt();
68 else pt2=l2ref2->pt();
73 return (t1->pt()>t2->pt());
std::pair< unsigned int, unsigned int > pseudoRef
reco::TrackRef l2Track() const
Get L2 info.
bool sharedSeed(const L3MuonTrajectorySeed &s1, const L3MuonTrajectorySeed &s2)
bool isNull() const
Checks for null.
static bool trackRefBypT(const reco::TrackRef &t1, const reco::TrackRef &t2)
static bool seedRefBypT(const SeedRef &s1, const SeedRef &s2)
auto const T2 &decltype(t1.eta()) t2
L3TkMuonProducer(const edm::ParameterSet &)
constructor with config
virtual void produce(edm::Event &, const edm::EventSetup &)
produce candidates
edm::Ref< L3MuonTrajectorySeedCollection > SeedRef
std::map< pseudoRef, std::pair< reco::TrackRef, SeedRef > > LXtoL3sMap
l1extra::L1MuonParticleRef l1Particle() const
Get L1 info.
key_type key() const
Accessor for product key.
virtual ~L3TkMuonProducer()
destructor
pseudoRef makePseudoRef(const L3MuonTrajectorySeed &s)
ProductID id() const
Accessor for product ID.
edm::InputTag theL3CollectionLabel