1 #ifndef PHG4TRUTHINFOCONTAINER_H__
2 #define PHG4TRUTHINFOCONTAINER_H__
17 typedef std::map<int,PHG4Particle *>
Map;
20 typedef std::pair<Iterator, Iterator>
Range;
21 typedef std::pair<ConstIterator, ConstIterator>
ConstRange;
23 typedef std::map<int,PHG4VtxPoint *>
VtxMap;
26 typedef std::pair<VtxIterator, VtxIterator>
VtxRange;
32 typedef std::pair<ShowerIterator, ShowerIterator>
ShowerRange;
39 void identify(std::ostream& os = std::cout)
const;
63 unsigned int size(
void )
const {
return particlemap.size();}
65 return std::distance(particlemap.upper_bound(0),particlemap.end());
78 std::pair< std::map<int,int>::const_iterator,
80 return std::make_pair(particle_embed_flags.begin(), particle_embed_flags.end());
88 particle_embed_flags.insert(std::make_pair(
id,flag));
135 std::pair< std::map<int,int>::const_iterator,
137 return std::make_pair(vertex_embed_flags.begin(), vertex_embed_flags.end());
145 vertex_embed_flags.insert(std::make_pair(
id,flag));
217 std::map< int, int> particle_embed_flags;
218 std::map< int, int> vertex_embed_flags;
VtxRange GetVtxRange()
Get a range of iterators covering the entire vertex container.
std::pair< ShowerIterator, ShowerIterator > ShowerRange
ConstRange GetParticleRange() const
ConstShowerRange GetShowerRange() const
bool is_primary(const PHG4Particle *p) const
unsigned int GetNumVertices() const
Get the number of vertices stored.
void AddEmbededTrkId(const int id, const int flag)
VtxMap::const_iterator ConstVtxIterator
void delete_shower(ShowerIterator piter)
Range GetParticleRange()
Get a range of iterators covering the entire container.
std::map< int, PHG4Shower * > ShowerMap
Range GetPrimaryParticleRange()
ConstIterator AddParticle(const int particleid, PHG4Particle *newparticle)
Add a particle that the user has created.
const VtxMap & GetVtxMap() const
Get the Vertex Map storage.
ConstRange GetPrimaryParticleRange() const
std::pair< Iterator, Iterator > Range
int isEmbeded(const int trackid) const
int maxshowerindex() const
std::pair< ConstIterator, ConstIterator > ConstRange
ConstRange GetSecondaryParticleRange() const
ConstVtxRange GetPrimaryVtxRange() const
ShowerRange GetSecondaryShowerRange()
VtxRange GetPrimaryVtxRange()
const ShowerMap & GetShowerMap() const
Get the Shower Map storage.
void identify(std::ostream &os=std::cout) const
PHG4VtxPoint * GetVtx(const int vtxid)
std::map< int, PHG4Particle * > Map
ConstShowerIterator AddShower(const int showerid, PHG4Shower *newshower)
Add a shower that the user has created.
std::pair< std::map< int, int >::const_iterator, std::map< int, int >::const_iterator > GetEmbeddedVtxIds() const
void delete_particle(Iterator piter)
std::pair< ConstShowerIterator, ConstShowerIterator > ConstShowerRange
ConstVtxRange GetVtxRange() const
int GetNumPrimaryVertexParticles()
Map::const_iterator ConstIterator
int isEmbededVtx(const int vtxid) const
Range GetSecondaryParticleRange()
VtxMap::iterator VtxIterator
std::pair< VtxIterator, VtxIterator > VtxRange
PHG4Particle * GetPrimaryParticle(const int particleid)
ConstVtxRange GetSecondaryVtxRange() const
std::pair< std::map< int, int >::const_iterator, std::map< int, int >::const_iterator > GetEmbeddedTrkIds() const
std::map< int, PHG4VtxPoint * > VtxMap
ConstShowerRange GetPrimaryShowerRange() const
ShowerMap::const_iterator ConstShowerIterator
PHG4Particle * GetParticle(const int particleid)
PHG4Shower * GetShower(const int showerid)
ConstVtxIterator AddVertex(const int vtxid, PHG4VtxPoint *vertex)
Add a vertex and return an iterator to the user.
PHG4Shower * GetPrimaryShower(const int showerid)
ShowerRange GetShowerRange()
Get a range of iterators covering the entire container.
unsigned int size(void) const
particle size
int minshowerindex() const
void delete_vtx(VtxIterator viter)
PHG4VtxPoint * GetPrimaryVtx(const int vtxid)
int GetPrimaryVertexIndex() const
unsigned int shower_size(void) const
shower size
ShowerMap::iterator ShowerIterator
VtxRange GetSecondaryVtxRange()
void AddEmbededVtxId(const int id, const int flag)
const Map & GetMap() const
Get the Particle Map storage.
bool is_primary_vtx(const PHG4VtxPoint *v) const
ShowerRange GetPrimaryShowerRange()
virtual ~PHG4TruthInfoContainer()
ConstShowerRange GetSecondaryShowerRange() const
std::pair< ConstVtxIterator, ConstVtxIterator > ConstVtxRange