CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Member Functions | Private Attributes
FSimEvent Class Reference

#include <FSimEvent.h>

Inheritance diagram for FSimEvent:
FBaseSimEvent

Public Member Functions

void fill (const HepMC::GenEvent &hev, edm::EventID &Id, RandomEngineAndDistribution const *)
 fill the FBaseSimEvent from the current HepMC::GenEvent More...
 
void fill (const reco::GenParticleCollection &parts, edm::EventID &Id, RandomEngineAndDistribution const *)
 fill the FBaseSimEvent from the current reco::GenParticleCollection More...
 
void fill (const std::vector< SimTrack > &simTracks, const std::vector< SimVertex > &simVertices)
 fill the FBaseSimEvent from the SimTrack's and SimVert'ices More...
 
 FSimEvent (const edm::ParameterSet &kine)
 Default constructor. More...
 
 FSimEvent (const edm::ParameterSet &vtx, const edm::ParameterSet &kine)
 
edm::EventID id () const
 Method to return the EventId. More...
 
void load (edm::SimTrackContainer &c, edm::SimTrackContainer &m) const
 Load containers of tracks (and muons) and vertices for the edm::Event. More...
 
void load (edm::SimVertexContainer &c) const
 
void load (FSimVertexTypeCollection &c) const
 
unsigned int nGenParts () const
 Number of MC particles. More...
 
unsigned int nTracks () const
 Number of tracks. More...
 
unsigned int nVertices () const
 Number of vertices. More...
 
float weight () const
 Method to return the event weight. More...
 
virtual ~FSimEvent ()
 usual virtual destructor More...
 
- Public Member Functions inherited from FBaseSimEvent
void addChargedTrack (int id)
 Add an id in the vector of charged tracks id's. More...
 
void addParticles (const HepMC::GenEvent &hev, RandomEngineAndDistribution const *)
 Add the particles and their vertices to the list. More...
 
void addParticles (const reco::GenParticleCollection &myGenParticles, RandomEngineAndDistribution const *)
 
int addSimTrack (const RawParticle *p, int iv, int ig=-1, const HepMC::GenVertex *ev=0)
 Add a new track to the Event and to the various lists. More...
 
int addSimVertex (const XYZTLorentzVector &decayVertex, int im=-1, FSimVertexType::VertexType type=FSimVertexType::ANY)
 Add a new vertex to the Event and to the various lists. More...
 
int chargedTrack (int id) const
 return "reconstructed" charged tracks index. More...
 
void clear ()
 clear the FBaseSimEvent content before the next event More...
 
const HepMC::GenParticle * embdGenpart (int i) const
 return MC track with a given id More...
 
const SimTrackembdTrack (int i) const
 return embedded track with given id More...
 
const SimVertexembdVertex (int i) const
 return embedded vertex with given id More...
 
const FSimVertexTypeembdVertexType (int i) const
 return embedded vertex type with given id More...
 
 FBaseSimEvent (const edm::ParameterSet &kine)
 Default constructor. More...
 
 FBaseSimEvent (const edm::ParameterSet &vtx, const edm::ParameterSet &kine)
 
void fill (const HepMC::GenEvent &hev, RandomEngineAndDistribution const *)
 fill the FBaseSimEvent from the current HepMC::GenEvent More...
 
void fill (const reco::GenParticleCollection &hev, RandomEngineAndDistribution const *)
 fill the FBaseSimEvent from the current reco::GenParticleCollection More...
 
void fill (const std::vector< SimTrack > &, const std::vector< SimVertex > &)
 fill the FBaseSimEvent from SimTrack's and SimVert'ices More...
 
const KineParticleFilterfilter () const
 
void initializePdt (const HepPDT::ParticleDataTable *aPdt)
 Initialize the particle data table. More...
 
unsigned int nChargedTracks () const
 Number of "reconstructed" charged tracks. More...
 
unsigned int nGenParts () const
 Number of generator particles. More...
 
unsigned int nTracks () const
 Number of tracks. More...
 
unsigned int nVertices () const
 Number of vertices. More...
 
void print () const
 print the FBaseSimEvent in an intelligible way More...
 
void printMCTruth (const HepMC::GenEvent &hev)
 print the original MCTruth event More...
 
void setBeamSpot (const math::XYZPoint &aBeamSpot)
 Set the beam spot position. More...
 
PrimaryVertexGeneratorthePrimaryVertexGenerator () const
 
const HepPDT::ParticleDataTabletheTable () const
 Get the pointer to the particle data table. More...
 
FSimTracktrack (int id) const
 Return track with given Id. More...
 
FSimVertexvertex (int id) const
 Return vertex with given Id. More...
 
FSimVertexTypevertexType (int id) const
 Return vertex with given Id. More...
 
 ~FBaseSimEvent ()
 usual virtual destructor More...
 

Private Attributes

edm::EventID id_
 
double weight_
 

Additional Inherited Members

- Protected Member Functions inherited from FBaseSimEvent
std::vector
< HepMC::GenParticle * > * 
genparts () const
 The pointer to the vector of GenParticle's. More...
 
std::vector< FSimTrack > * tracks () const
 The pointer to the vector of FSimTrack's. More...
 
std::vector< FSimVertex > * vertices () const
 The pointer to the vector of FSimVertex's. More...
 

Detailed Description

Definition at line 31 of file FSimEvent.h.

Constructor & Destructor Documentation

FSimEvent::FSimEvent ( const edm::ParameterSet kine)

Default constructor.

Definition at line 6 of file FSimEvent.cc.

7  : FBaseSimEvent(kine), id_(edm::EventID(0,0,0)), weight_(0)
8 {}
FBaseSimEvent(const edm::ParameterSet &kine)
Default constructor.
double weight_
Definition: FSimEvent.h:75
edm::EventID id_
Definition: FSimEvent.h:74
FSimEvent::FSimEvent ( const edm::ParameterSet vtx,
const edm::ParameterSet kine 
)

Definition at line 10 of file FSimEvent.cc.

12  : FBaseSimEvent(vtx,kine), id_(edm::EventID(0,0,0)), weight_(0)
13 {}
FBaseSimEvent(const edm::ParameterSet &kine)
Default constructor.
double weight_
Definition: FSimEvent.h:75
edm::EventID id_
Definition: FSimEvent.h:74
FSimEvent::~FSimEvent ( )
virtual

usual virtual destructor

Definition at line 15 of file FSimEvent.cc.

16 {}

Member Function Documentation

void FSimEvent::fill ( const HepMC::GenEvent &  hev,
edm::EventID Id,
RandomEngineAndDistribution const *  random 
)

fill the FBaseSimEvent from the current HepMC::GenEvent

Definition at line 25 of file FSimEvent.cc.

References FBaseSimEvent::fill(), and id_.

Referenced by FamosManager::reconstruct().

25  {
27  id_ = Id;
28 }
TRandom random
Definition: MVATrainer.cc:138
void fill(const HepMC::GenEvent &hev, RandomEngineAndDistribution const *)
fill the FBaseSimEvent from the current HepMC::GenEvent
edm::EventID id_
Definition: FSimEvent.h:74
void FSimEvent::fill ( const reco::GenParticleCollection parts,
edm::EventID Id,
RandomEngineAndDistribution const *  random 
)

fill the FBaseSimEvent from the current reco::GenParticleCollection

Definition at line 19 of file FSimEvent.cc.

References FBaseSimEvent::fill(), and id_.

19  {
21  id_ = Id;
22 }
TRandom random
Definition: MVATrainer.cc:138
void fill(const HepMC::GenEvent &hev, RandomEngineAndDistribution const *)
fill the FBaseSimEvent from the current HepMC::GenEvent
edm::EventID id_
Definition: FSimEvent.h:74
void FSimEvent::fill ( const std::vector< SimTrack > &  simTracks,
const std::vector< SimVertex > &  simVertices 
)

fill the FBaseSimEvent from the SimTrack's and SimVert'ices

Definition at line 31 of file FSimEvent.cc.

References FBaseSimEvent::fill(), and id_.

32  {
33  FBaseSimEvent::fill(simTracks,simVertices);
34  id_ = edm::EventID();
35 }
void fill(const HepMC::GenEvent &hev, RandomEngineAndDistribution const *)
fill the FBaseSimEvent from the current HepMC::GenEvent
edm::EventID id_
Definition: FSimEvent.h:74
edm::EventID FSimEvent::id ( void  ) const

Method to return the EventId.

Definition at line 38 of file FSimEvent.cc.

References id_.

Referenced by CalorimetryManager::reconstruct().

38  {
39  return id_;
40 }
edm::EventID id_
Definition: FSimEvent.h:74
void FSimEvent::load ( edm::SimTrackContainer c,
edm::SimTrackContainer m 
) const

Load containers of tracks (and muons) and vertices for the edm::Event.

Definition at line 62 of file FSimEvent.cc.

References funct::abs(), FSimTrack::closestDaughterId(), FBaseSimEvent::embdTrack(), i, CoreSimTrack::momentum(), FSimTrack::mother(), FSimTrack::noEndVertex(), FSimTrack::noMother(), nTracks(), edmStreamStallGrapher::t, FBaseSimEvent::track(), and CoreSimTrack::type().

63 {
64  for (unsigned int i=0; i<nTracks(); ++i) {
65  // SimTrack t = SimTrack(ip,p,iv,ig);
66  const SimTrack& t = embdTrack(i);
67  // Save all tracks
68  c.push_back(t);
69  // Save also some muons for later parameterization
70  if ( abs(t.type()) == 13 &&
71  t.momentum().perp2() > 1.0 &&
72  fabs(t.momentum().eta()) < 3.0 &&
73  track(i).noEndVertex() ) {
74  // Actually save the muon mother (and the attached muon) in case
75  if ( !track(i).noMother() && track(i).mother().closestDaughterId() == (int)i ) {
76  const SimTrack& T = embdTrack(track(i).mother().id());
77  m.push_back(T);
78  }
79  m.push_back(t);
80  }
81  }
82 }
int i
Definition: DBlmapReader.cc:9
bool noEndVertex() const
no end vertex
int closestDaughterId() const
Get the index of the closest charged daughter.
Definition: FSimTrack.h:187
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
unsigned int nTracks() const
Number of tracks.
Definition: FSimEvent.cc:47
const SimTrack & embdTrack(int i) const
return embedded track with given id
int type() const
particle type (HEP PDT convension)
Definition: CoreSimTrack.h:40
const math::XYZTLorentzVectorD & momentum() const
particle info...
Definition: CoreSimTrack.h:36
bool noMother() const
no mother particle
long double T
const FSimTrack & mother() const
mother
FSimTrack & track(int id) const
Return track with given Id.
void FSimEvent::load ( edm::SimVertexContainer c) const

Definition at line 85 of file FSimEvent.cc.

References FBaseSimEvent::embdVertex(), i, and nVertices().

86 {
87  for (unsigned int i=0; i<nVertices(); ++i) {
88  // SimTrack t = SimTrack(ip,p,iv,ig);
89  c.push_back(embdVertex(i));
90  }
91 }
int i
Definition: DBlmapReader.cc:9
const SimVertex & embdVertex(int i) const
return embedded vertex with given id
unsigned int nVertices() const
Number of vertices.
Definition: FSimEvent.cc:52
void FSimEvent::load ( FSimVertexTypeCollection c) const

Definition at line 95 of file FSimEvent.cc.

References FBaseSimEvent::embdVertexType(), i, and nVertices().

96 {
97 
98  for (unsigned int i=0; i<nVertices(); ++i) {
99  c.push_back(embdVertexType(i));
100  }
101 }
int i
Definition: DBlmapReader.cc:9
const FSimVertexType & embdVertexType(int i) const
return embedded vertex type with given id
unsigned int nVertices() const
Number of vertices.
Definition: FSimEvent.cc:52
unsigned int FSimEvent::nGenParts ( ) const

Number of MC particles.

Definition at line 57 of file FSimEvent.cc.

References FBaseSimEvent::nGenParts().

Referenced by FamosManager::reconstruct().

57  {
58  return FBaseSimEvent::nGenParts();
59 }
unsigned int nGenParts() const
Number of generator particles.
unsigned int FSimEvent::nTracks ( ) const

Number of tracks.

Definition at line 47 of file FSimEvent.cc.

References FBaseSimEvent::nTracks().

Referenced by load(), FamosManager::reconstruct(), CalorimetryManager::reconstruct(), and TrajectoryManager::reconstruct().

47  {
48  return FBaseSimEvent::nTracks();
49 }
unsigned int nTracks() const
Number of tracks.
Definition: FBaseSimEvent.h:94
unsigned int FSimEvent::nVertices ( ) const

Number of vertices.

Definition at line 52 of file FSimEvent.cc.

References FBaseSimEvent::nVertices().

Referenced by load(), and FamosManager::reconstruct().

52  {
53  return FBaseSimEvent::nVertices();
54 }
unsigned int nVertices() const
Number of vertices.
Definition: FBaseSimEvent.h:99
float FSimEvent::weight ( void  ) const

Method to return the event weight.

Definition at line 42 of file FSimEvent.cc.

References weight_.

Referenced by cuy.ValElement::__init__(), cuy.additionElement::__init__(), cuy.superimposeElement::__init__(), cuy.graphElement::__init__(), and FamosManager::reconstruct().

42  {
43  return weight_;
44 }
double weight_
Definition: FSimEvent.h:75

Member Data Documentation

edm::EventID FSimEvent::id_
private

Definition at line 74 of file FSimEvent.h.

Referenced by fill(), and id().

double FSimEvent::weight_
private

Definition at line 75 of file FSimEvent.h.

Referenced by weight().