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 | Friends
TrackingVertex Class Reference

#include <TrackingVertex.h>

Public Types

typedef std::vector< SimVertex >
::const_iterator 
g4v_iterator
 
typedef
GenVertexRefVector::iterator 
genv_iterator
 
typedef edm::Ref
< edm::HepMCProduct,
HepMC::GenVertex > 
GenVertexRef
 
typedef edm::RefVector
< edm::HepMCProduct,
HepMC::GenVertex > 
GenVertexRefVector
 
typedef math::XYZTLorentzVectorD LorentzVector
 
typedef
TrackingParticleRefVector::iterator 
tp_iterator
 

Public Member Functions

void addDaughterTrack (const TrackingParticleRef &)
 
void addG4Vertex (const SimVertex &)
 
void addGenVertex (const GenVertexRef &)
 
void addParentTrack (const TrackingParticleRef &)
 
void clearDaughterTracks ()
 
void clearParentTracks ()
 
const TrackingParticleRefVectordaughterTracks () const
 
tp_iterator daughterTracks_begin () const
 
tp_iterator daughterTracks_end () const
 
const EncodedEventIdeventId () const
 
const std::vector< SimVertex > & g4Vertices () const
 
g4v_iterator g4Vertices_begin () const
 
g4v_iterator g4Vertices_end () const
 
const GenVertexRefVectorgenVertices () const
 
genv_iterator genVertices_begin () const
 
genv_iterator genVertices_end () const
 
const bool inVolume () const
 
unsigned int nDaughterTracks () const
 
unsigned int nG4Vertices () const
 
unsigned int nGenVertices () const
 
unsigned int nSourceTracks () const
 
const LorentzVectorposition () const
 
void setEventId (EncodedEventId e)
 
const TrackingParticleRefVectorsourceTracks () const
 
tp_iterator sourceTracks_begin () const
 
tp_iterator sourceTracks_end () const
 
 TrackingVertex ()
 
 TrackingVertex (const LorentzVector &position, const bool inVolume, const EncodedEventId e=EncodedEventId(0))
 

Private Attributes

TrackingParticleRefVector daughterTracks_
 
EncodedEventId eId_
 
std::vector< SimVertexg4Vertices_
 
GenVertexRefVector genVertices_
 
bool inVolume_
 
LorentzVector position_
 
TrackingParticleRefVector sourceTracks_
 

Friends

std::ostream & operator<< (std::ostream &s, const TrackingVertex &tv)
 

Detailed Description

A simulated Vertex with links to TrackingParticles for analysis of track and vertex reconstruction

Version
Id:
TrackingVertex.h,v 1.26 2008/12/11 23:03:08 bazterra Exp

Definition at line 23 of file TrackingVertex.h.

Member Typedef Documentation

typedef std::vector<SimVertex>::const_iterator TrackingVertex::g4v_iterator

Definition at line 34 of file TrackingVertex.h.

Definition at line 33 of file TrackingVertex.h.

Definition at line 31 of file TrackingVertex.h.

Definition at line 30 of file TrackingVertex.h.

Definition at line 32 of file TrackingVertex.h.

Definition at line 35 of file TrackingVertex.h.

Constructor & Destructor Documentation

TrackingVertex::TrackingVertex ( )

Definition at line 9 of file TrackingVertex.cc.

9  : position_(LorentzVector(0,0,0,0)), eId_(0)
10 {
11 // daughterTracks_.clear();
12 }
LorentzVector position_
EncodedEventId eId_
math::XYZTLorentzVectorD LorentzVector
TrackingVertex::TrackingVertex ( const LorentzVector position,
const bool  inVolume,
const EncodedEventId  e = EncodedEventId(0) 
)

Definition at line 14 of file TrackingVertex.cc.

14  :
16 {
17 // daughterTracks_.clear();
18 }
LorentzVector position_
EncodedEventId eId_
const bool inVolume() const

Member Function Documentation

void TrackingVertex::addDaughterTrack ( const TrackingParticleRef ref)

Definition at line 34 of file TrackingVertex.cc.

References daughterTracks_, and edm::RefVector< C, T, F >::push_back().

Referenced by TrackingTruthProducer::mergeBremsstrahlung().

35 {
37 }
TrackingParticleRefVector daughterTracks_
void push_back(value_type const &ref)
Add a Ref&lt;C, T&gt; to the RefVector.
Definition: RefVector.h:64
void TrackingVertex::addG4Vertex ( const SimVertex v)

Definition at line 22 of file TrackingVertex.cc.

References g4Vertices_.

Referenced by TrackingTruthProducer::setTrackingVertex().

23 {
24  g4Vertices_.push_back(v);
25 }
std::vector< SimVertex > g4Vertices_
void TrackingVertex::addGenVertex ( const GenVertexRef ref)

Definition at line 27 of file TrackingVertex.cc.

References genVertices_, and edm::RefVector< C, T, F >::push_back().

Referenced by TrackingTruthProducer::addCloseGenVertexes().

28 {
30 }
GenVertexRefVector genVertices_
void push_back(value_type const &ref)
Add a Ref&lt;C, T&gt; to the RefVector.
Definition: RefVector.h:64
void TrackingVertex::addParentTrack ( const TrackingParticleRef ref)

Definition at line 39 of file TrackingVertex.cc.

References edm::RefVector< C, T, F >::push_back(), and sourceTracks_.

Referenced by TrackingTruthProducer::mergeBremsstrahlung().

40 {
42 }
void push_back(value_type const &ref)
Add a Ref&lt;C, T&gt; to the RefVector.
Definition: RefVector.h:64
TrackingParticleRefVector sourceTracks_
void TrackingVertex::clearDaughterTracks ( )

Definition at line 44 of file TrackingVertex.cc.

References edm::RefVector< C, T, F >::clear(), and daughterTracks_.

Referenced by TrackingTruthProducer::mergeBremsstrahlung().

45 {
47 }
TrackingParticleRefVector daughterTracks_
void clear()
Clear the vector.
Definition: RefVector.h:133
void TrackingVertex::clearParentTracks ( )

Definition at line 49 of file TrackingVertex.cc.

References edm::RefVector< C, T, F >::clear(), and sourceTracks_.

Referenced by TrackingTruthProducer::mergeBremsstrahlung().

50 {
52 }
void clear()
Clear the vector.
Definition: RefVector.h:133
TrackingParticleRefVector sourceTracks_
const TrackingParticleRefVector & TrackingVertex::daughterTracks ( ) const

Definition at line 105 of file TrackingVertex.cc.

References daughterTracks_.

Referenced by VertexFitterResult::fill(), and operator<<().

106 {
107  return daughterTracks_;
108 }
TrackingParticleRefVector daughterTracks_
TrackingVertex::tp_iterator TrackingVertex::daughterTracks_begin ( ) const

Definition at line 74 of file TrackingVertex.cc.

References edm::RefVector< C, T, F >::begin(), and daughterTracks_.

Referenced by VertexFitterResult::fill(), TrackingTruthProducer::isBremsstrahlungVertex(), and operator<<().

75 {
76  return daughterTracks_.begin();
77 }
const_iterator begin() const
Initialize an iterator over the RefVector.
Definition: RefVector.h:244
TrackingParticleRefVector daughterTracks_
TrackingVertex::tp_iterator TrackingVertex::daughterTracks_end ( ) const

Definition at line 78 of file TrackingVertex.cc.

References daughterTracks_, and edm::RefVector< C, T, F >::end().

Referenced by VertexFitterResult::fill(), TrackingTruthProducer::isBremsstrahlungVertex(), and operator<<().

79 {
80  return daughterTracks_.end();
81 }
const_iterator end() const
Termination of iteration.
Definition: RefVector.h:249
TrackingParticleRefVector daughterTracks_
const EncodedEventId& TrackingVertex::eventId ( ) const
inline

Definition at line 95 of file TrackingVertex.h.

References eId_.

Referenced by TrackingTruthProducer::addCloseGenVertexes(), PrimaryVertexAnalyzer4PU::getSimEvents(), and operator<<().

96  {
97  return eId_;
98  };
EncodedEventId eId_
const std::vector< SimVertex > & TrackingVertex::g4Vertices ( ) const

Definition at line 93 of file TrackingVertex.cc.

References g4Vertices_.

94 {
95  return g4Vertices_;
96 }
std::vector< SimVertex > g4Vertices_
TrackingVertex::g4v_iterator TrackingVertex::g4Vertices_begin ( ) const

Definition at line 65 of file TrackingVertex.cc.

References g4Vertices_.

Referenced by operator<<().

66 {
67  return g4Vertices_.begin();
68 }
std::vector< SimVertex > g4Vertices_
TrackingVertex::g4v_iterator TrackingVertex::g4Vertices_end ( ) const

Definition at line 69 of file TrackingVertex.cc.

References g4Vertices_.

Referenced by operator<<().

70 {
71  return g4Vertices_.end();
72 }
std::vector< SimVertex > g4Vertices_
const GenVertexRefVector & TrackingVertex::genVertices ( ) const

Definition at line 97 of file TrackingVertex.cc.

References genVertices_.

98 {
99  return genVertices_;
100 }
GenVertexRefVector genVertices_
TrackingVertex::genv_iterator TrackingVertex::genVertices_begin ( ) const

Definition at line 57 of file TrackingVertex.cc.

References edm::RefVector< C, T, F >::begin(), and genVertices_.

Referenced by operator<<().

58 {
59  return genVertices_.begin();
60 }
const_iterator begin() const
Initialize an iterator over the RefVector.
Definition: RefVector.h:244
GenVertexRefVector genVertices_
TrackingVertex::genv_iterator TrackingVertex::genVertices_end ( ) const

Definition at line 61 of file TrackingVertex.cc.

References edm::RefVector< C, T, F >::end(), and genVertices_.

Referenced by operator<<().

62 {
63  return genVertices_.end();
64 }
const_iterator end() const
Termination of iteration.
Definition: RefVector.h:249
GenVertexRefVector genVertices_
const bool TrackingVertex::inVolume ( ) const
inline

Definition at line 99 of file TrackingVertex.h.

References inVolume_.

100  {
101  return inVolume_;
102  };
unsigned int TrackingVertex::nDaughterTracks ( ) const
inline

Definition at line 67 of file TrackingVertex.h.

References daughterTracks_, and edm::RefVector< C, T, F >::size().

68  {
69  return daughterTracks_.size();
70  };
TrackingParticleRefVector daughterTracks_
size_type size() const
Size of the RefVector.
Definition: RefVector.h:89
unsigned int TrackingVertex::nG4Vertices ( ) const
inline

Definition at line 59 of file TrackingVertex.h.

References g4Vertices_.

60  {
61  return g4Vertices_.size();
62  };
std::vector< SimVertex > g4Vertices_
unsigned int TrackingVertex::nGenVertices ( ) const
inline

Definition at line 63 of file TrackingVertex.h.

References genVertices_, and edm::RefVector< C, T, F >::size().

64  {
65  return genVertices_.size();
66  };
GenVertexRefVector genVertices_
size_type size() const
Size of the RefVector.
Definition: RefVector.h:89
unsigned int TrackingVertex::nSourceTracks ( ) const
inline

Definition at line 71 of file TrackingVertex.h.

References edm::RefVector< C, T, F >::size(), and sourceTracks_.

72  {
73  return sourceTracks_.size();
74  };
size_type size() const
Size of the RefVector.
Definition: RefVector.h:89
TrackingParticleRefVector sourceTracks_
const LorentzVector& TrackingVertex::position ( ) const
inline
void TrackingVertex::setEventId ( EncodedEventId  e)
inline

Definition at line 43 of file TrackingVertex.h.

References alignCSCRings::e, and eId_.

44  {
45  eId_=e;
46  };
EncodedEventId eId_
const TrackingParticleRefVector & TrackingVertex::sourceTracks ( ) const

Definition at line 101 of file TrackingVertex.cc.

References sourceTracks_.

Referenced by TrackingTruthProducer::isBremsstrahlungVertex(), and TrackingTruthProducer::mergeBremsstrahlung().

102 {
103  return sourceTracks_;
104 }
TrackingParticleRefVector sourceTracks_
TrackingVertex::tp_iterator TrackingVertex::sourceTracks_begin ( ) const

Definition at line 82 of file TrackingVertex.cc.

References edm::RefVector< C, T, F >::begin(), and sourceTracks_.

Referenced by operator<<().

83 {
84  return sourceTracks_.begin();
85 }
const_iterator begin() const
Initialize an iterator over the RefVector.
Definition: RefVector.h:244
TrackingParticleRefVector sourceTracks_
TrackingVertex::tp_iterator TrackingVertex::sourceTracks_end ( ) const

Definition at line 86 of file TrackingVertex.cc.

References edm::RefVector< C, T, F >::end(), and sourceTracks_.

Referenced by operator<<().

87 {
88  return sourceTracks_.end();
89 }
const_iterator end() const
Termination of iteration.
Definition: RefVector.h:249
TrackingParticleRefVector sourceTracks_

Friends And Related Function Documentation

std::ostream& operator<< ( std::ostream &  s,
const TrackingVertex tv 
)
friend

Definition at line 110 of file TrackingVertex.cc.

111 {
112 
113  using std::endl;
115  typedef std::vector<SimVertex>::const_iterator g4v_iterator;
117  typedef std::vector<SimTrack>::const_iterator g4t_iterator;
118 
119  s << "Vertex Position & Event #" << v.position() << " " << v.eventId().bunchCrossing() << "." << v.eventId().event() << endl;
120  s << " Associated with " << v.daughterTracks().size() << " tracks" << endl;
121  for (genv_iterator genV = v.genVertices_begin(); genV != v.genVertices_end(); ++genV)
122  {
123  s << " HepMC vertex position " << (*(*genV)).position().x() << ","<< (*(*genV)).position().y() << (*(*genV)).position().z() << endl;
124  }
125 
126  for (g4v_iterator g4V = v.g4Vertices_begin(); g4V != v.g4Vertices_end(); ++g4V)
127  {
128  s << " Geant vertex position " << (*g4V).position() << endl;
129  // Probably empty all the time, currently
130  }
131 
132  // Loop over daughter track(s)
133  for (tp_iterator iTP = v.daughterTracks_begin(); iTP != v.daughterTracks_end(); ++iTP)
134  {
135  s << " Daughter starts: " << (*(*iTP)).vertex();
136  for (g4t_iterator g4T = (*(*iTP)).g4Track_begin(); g4T != (*(*iTP)).g4Track_end(); ++g4T)
137  {
138  s << " p " << g4T->momentum();
139  }
140  s << endl;
141  }
142 
143  // Loop over source track(s) (can be multiple since vertices are collapsed)
144  for (tp_iterator iTP = v.sourceTracks_begin(); iTP != v.sourceTracks_end(); ++iTP)
145  {
146  s << " Source starts: " << (*(*iTP)).vertex();
147  for (g4t_iterator g4T = (*iTP)->g4Track_begin(); g4T != (*iTP)->g4Track_end(); ++g4T)
148  {
149  s << ", p " << g4T ->momentum();
150  }
151  s << endl;
152  }
153  return s;
154 }
GenVertexRefVector::iterator genv_iterator
std::vector< SimVertex >::const_iterator g4v_iterator
TrackingParticleRefVector::iterator tp_iterator
mathSSE::Vec4< T > v
const LorentzVector & position() const
TrackingParticle::g4t_iterator g4t_iterator

Member Data Documentation

TrackingParticleRefVector TrackingVertex::daughterTracks_
private
EncodedEventId TrackingVertex::eId_
private

Definition at line 108 of file TrackingVertex.h.

Referenced by eventId(), and setEventId().

std::vector<SimVertex> TrackingVertex::g4Vertices_
private
GenVertexRefVector TrackingVertex::genVertices_
private
bool TrackingVertex::inVolume_
private

Definition at line 107 of file TrackingVertex.h.

Referenced by inVolume().

LorentzVector TrackingVertex::position_
private

Definition at line 102 of file TrackingVertex.h.

Referenced by position().

TrackingParticleRefVector TrackingVertex::sourceTracks_
private