test
CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Types | Public Member Functions | Private Attributes
reco::JetTrackMatch< JetC > Class Template Reference

Association between Jets from jet collection and tracks from track collection. More...

#include <JetTrackMatch.h>

Public Types

typedef edm::Ref< JetC > JetRef
 
typedef edm::AssociationMap
< edm::OneToMany< JetC,
reco::TrackCollection > > 
Map
 
typedef edm::Ref
< reco::TrackCollection
TrackRef
 

Public Member Functions

std::vector< JetRefallJets () const
 get list of all jats in the map More...
 
std::vector< TrackRefgetTracks (const JetRef &mJet) const
 get all tracks associated with jet More...
 
void insert (const JetRef &fJet)
 insert orphan jet More...
 
void insert (const JetRef &fJet, const TrackRef &fTrack)
 assign track to jet. More...
 
 JetTrackMatch ()
 
 ~JetTrackMatch ()
 

Private Attributes

Map mMap
 

Detailed Description

template<typename JetC>
class reco::JetTrackMatch< JetC >

Association between Jets from jet collection and tracks from track collection.

Every jet may have several tracks associated with it

class definition:

template <typename jetc>=""> class JetTrackMatch { public: typedef edm::Ref<JetC> JetRef; typedef edm::Ref<reco::TrackCollection> TrackRef; JetTrackMatch (); ~JetTrackMatch (); // insert orphan jet void insert (const JetRef& fJet); // assign track to jet. void insert (const JetRef& fJet, const TrackRef& fTrack); // get list of all tracks in the map std::vector <JetRef> allJets () const; // get all tracks associated with jet std::vector <TrackRef> getTracks (const JetRef& mJet) const; };

Author
Fedor Ratnikov, UMd

Definition at line 39 of file JetTrackMatch.h.

Member Typedef Documentation

template<typename JetC>
typedef edm::Ref<JetC> reco::JetTrackMatch< JetC >::JetRef

Definition at line 41 of file JetTrackMatch.h.

template<typename JetC>
typedef edm::AssociationMap<edm::OneToMany<JetC, reco::TrackCollection> > reco::JetTrackMatch< JetC >::Map

Definition at line 43 of file JetTrackMatch.h.

template<typename JetC>
typedef edm::Ref<reco::TrackCollection> reco::JetTrackMatch< JetC >::TrackRef

Definition at line 42 of file JetTrackMatch.h.

Constructor & Destructor Documentation

template<typename JetC>
reco::JetTrackMatch< JetC >::JetTrackMatch ( )
inline

Definition at line 48 of file JetTrackMatch.h.

48 {}
template<typename JetC>
reco::JetTrackMatch< JetC >::~JetTrackMatch ( )
inline

Definition at line 49 of file JetTrackMatch.h.

49 {}

Member Function Documentation

template<typename JetC>
std::vector<JetRef> reco::JetTrackMatch< JetC >::allJets ( ) const
inline

get list of all jats in the map

Definition at line 62 of file JetTrackMatch.h.

62  {
63  std::vector <JetRef> result;
64  typename Map::const_iterator it = mMap.begin ();
65  for (; it != mMap.end(); ++it) {
66  result.push_back (it->key);
67  }
68  return result;
69  }
const_iterator end() const
last iterator over the map (read only)
tuple result
Definition: mps_fire.py:84
const_iterator begin() const
first iterator over the map (read only)
template<typename JetC>
std::vector<TrackRef> reco::JetTrackMatch< JetC >::getTracks ( const JetRef mJet) const
inline

get all tracks associated with jet

Definition at line 71 of file JetTrackMatch.h.

71  {
72  std::vector <TrackRef> result;
74  int i = tracks.size();
75  while (--i >= 0) {
76  if (!tracks [i].isNull ()) result.push_back (tracks [i]);
77  }
78  return result;
79  }
int i
Definition: DBlmapReader.cc:9
tuple result
Definition: mps_fire.py:84
tuple tracks
Definition: testEve_cfg.py:39
size_type size() const
Size of the RefVector.
Definition: RefVector.h:107
template<typename JetC>
void reco::JetTrackMatch< JetC >::insert ( const JetRef fJet)
inline

insert orphan jet

Definition at line 52 of file JetTrackMatch.h.

Referenced by BeautifulSoup.PageElement::_invert().

52  {
53  mMap.insert (fJet, TrackRef());
54  }
edm::Ref< reco::TrackCollection > TrackRef
Definition: JetTrackMatch.h:42
void insert(const key_type &k, const data_type &v)
insert an association
template<typename JetC>
void reco::JetTrackMatch< JetC >::insert ( const JetRef fJet,
const TrackRef fTrack 
)
inline

assign track to jet.

Definition at line 57 of file JetTrackMatch.h.

Referenced by BeautifulSoup.PageElement::_invert().

57  {
58  mMap.insert (fJet, fTrack);
59  }
void insert(const key_type &k, const data_type &v)
insert an association

Member Data Documentation

template<typename JetC>
Map reco::JetTrackMatch< JetC >::mMap
private