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)
 fill the FBaseSimEvent from the current HepMC::GenEvent More...
 
void fill (const reco::GenParticleCollection &parts, edm::EventID &Id)
 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...
 
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)
 Add the particles and their vertices to the list. More...
 
void addParticles (const reco::GenParticleCollection &myGenParticles)
 
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...
 
void fill (const HepMC::GenEvent &hev)
 fill the FBaseSimEvent from the current HepMC::GenEvent More...
 
void fill (const reco::GenParticleCollection &hev)
 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...
 
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

The FAMOS SimEvent: inherits from FBaseSimEvent, where the latter provides FAMOS-specific event features (splitting proposed by Maya STAVRIANAKOU)

An FSimEvent contains, at filling time, only particles from the GenEvent it is being filled with. Material Effects then update its content, so that it resembles the output of Geant at the end of the material effect processing.

Important : All distances are in mm

Author
Patrick Janot, CERN
Date
: 9-Dec-2003

Definition at line 29 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:70
edm::EventID id_
Definition: FSimEvent.h:69
FSimEvent::~FSimEvent ( )
virtual

usual virtual destructor

Definition at line 10 of file FSimEvent.cc.

11 {}

Member Function Documentation

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

fill the FBaseSimEvent from the current HepMC::GenEvent

Definition at line 20 of file FSimEvent.cc.

References FBaseSimEvent::fill(), and id_.

Referenced by FamosManager::reconstruct().

20  {
22  id_ = Id;
23 }
void fill(const HepMC::GenEvent &hev)
fill the FBaseSimEvent from the current HepMC::GenEvent
edm::EventID id_
Definition: FSimEvent.h:69
void FSimEvent::fill ( const reco::GenParticleCollection parts,
edm::EventID Id 
)

fill the FBaseSimEvent from the current reco::GenParticleCollection

Definition at line 14 of file FSimEvent.cc.

References FBaseSimEvent::fill(), and id_.

14  {
16  id_ = Id;
17 }
void fill(const HepMC::GenEvent &hev)
fill the FBaseSimEvent from the current HepMC::GenEvent
edm::EventID id_
Definition: FSimEvent.h:69
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 26 of file FSimEvent.cc.

References FBaseSimEvent::fill(), and id_.

27  {
28  FBaseSimEvent::fill(simTracks,simVertices);
29  id_ = edm::EventID();
30 }
void fill(const HepMC::GenEvent &hev)
fill the FBaseSimEvent from the current HepMC::GenEvent
edm::EventID id_
Definition: FSimEvent.h:69
edm::EventID FSimEvent::id ( void  ) const

Method to return the EventId.

Definition at line 33 of file FSimEvent.cc.

References id_.

Referenced by CalorimetryManager::reconstruct().

33  {
34  return id_;
35 }
edm::EventID id_
Definition: FSimEvent.h:69
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 57 of file FSimEvent.cc.

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

58 {
59  for (unsigned int i=0; i<nTracks(); ++i) {
60  // SimTrack t = SimTrack(ip,p,iv,ig);
61  const SimTrack& t = embdTrack(i);
62  // Save all tracks
63  c.push_back(t);
64  // Save also some muons for later parameterization
65  if ( abs(t.type()) == 13 &&
66  t.momentum().perp2() > 1.0 &&
67  fabs(t.momentum().eta()) < 3.0 &&
68  track(i).noEndVertex() ) {
69  // Actually save the muon mother (and the attached muon) in case
70  if ( !track(i).noMother() && track(i).mother().closestDaughterId() == (int)i ) {
71  const SimTrack& T = embdTrack(track(i).mother().id());
72  m.push_back(T);
73  }
74  m.push_back(t);
75  }
76  }
77 }
int i
Definition: DBlmapReader.cc:9
bool noEndVertex() const
no end vertex
const reco::GenParticle * mother(const reco::GenParticle &p, unsigned int imoth=0)
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:42
const SimTrack & embdTrack(int i) const
return embedded track with given id
int type() const
particle type (HEP PDT convension)
Definition: CoreSimTrack.h:25
const math::XYZTLorentzVectorD & momentum() const
Definition: CoreSimTrack.h:22
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 80 of file FSimEvent.cc.

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

81 {
82  for (unsigned int i=0; i<nVertices(); ++i) {
83  // SimTrack t = SimTrack(ip,p,iv,ig);
84  c.push_back(embdVertex(i));
85  }
86 }
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:47
void FSimEvent::load ( FSimVertexTypeCollection c) const

Definition at line 90 of file FSimEvent.cc.

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

91 {
92 
93  for (unsigned int i=0; i<nVertices(); ++i) {
94  c.push_back(embdVertexType(i));
95  }
96 }
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:47
unsigned int FSimEvent::nGenParts ( ) const

Number of MC particles.

Definition at line 52 of file FSimEvent.cc.

References FBaseSimEvent::nGenParts().

Referenced by FamosManager::reconstruct().

52  {
53  return FBaseSimEvent::nGenParts();
54 }
unsigned int nGenParts() const
Number of generator particles.
Definition: FBaseSimEvent.h:98
unsigned int FSimEvent::nTracks ( ) const

Number of tracks.

Definition at line 42 of file FSimEvent.cc.

References FBaseSimEvent::nTracks().

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

42  {
43  return FBaseSimEvent::nTracks();
44 }
unsigned int nTracks() const
Number of tracks.
Definition: FBaseSimEvent.h:88
unsigned int FSimEvent::nVertices ( ) const

Number of vertices.

Definition at line 47 of file FSimEvent.cc.

References FBaseSimEvent::nVertices().

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

47  {
48  return FBaseSimEvent::nVertices();
49 }
unsigned int nVertices() const
Number of vertices.
Definition: FBaseSimEvent.h:93
float FSimEvent::weight ( void  ) const

Method to return the event weight.

Definition at line 37 of file FSimEvent.cc.

References weight_.

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

37  {
38  return weight_;
39 }
double weight_
Definition: FSimEvent.h:70

Member Data Documentation

edm::EventID FSimEvent::id_
private

Definition at line 69 of file FSimEvent.h.

Referenced by fill(), and id().

double FSimEvent::weight_
private

Definition at line 70 of file FSimEvent.h.

Referenced by weight().