18 #include <Geant4/G4ParticleDefinition.hh>
19 #include <Geant4/G4ParticleTable.hh>
21 #include <gsl/gsl_rng.h>
29 , reuse_existing_vertex(0)
54 G4ParticleTable *particleTable = G4ParticleTable::GetParticleTable();
55 G4String particleName = name;
56 G4ParticleDefinition *particledef = particleTable->FindParticle(particleName);
59 return particledef->GetPDGEncoding();
67 G4ParticleTable *particleTable = G4ParticleTable::GetParticleTable();
68 G4ParticleDefinition *particledef = particleTable->FindParticle(pdgcode);
71 return particledef->GetParticleName();
80 G4ParticleTable *particleTable = G4ParticleTable::GetParticleTable();
81 G4ParticleDefinition *particledef = particleTable->FindParticle(
get_pdgname(pdgcode));
84 return particledef->GetPDGMass();
122 PHG4InEvent *ineve = findNode::getClass<PHG4InEvent>(topNode,
"PHG4INEVENT");
138 cout <<
PHWHERE <<
" " <<
Name() <<
" using empty process_event" << endl;
144 vector<PHG4Particle *>::const_iterator iter;
148 cout <<
"particle " << i << endl;
182 if ((particle->
get_name()).size() == 0)
200 cout <<
Name() <<
" random seed: " <<
seed << endl;
211 PHHepMCGenEventMap *genevtmap = findNode::getClass<PHHepMCGenEventMap>(topNode,
"PHHepMCGenEventMap");
220 if (iter != genevtmap->
rend())
228 set_vtx(vtx.x(), vtx.y(), vtx.z());
231 cout <<
"PHG4ParticleGeneratorBase::ReuseExistingVertex - reuse PHHepMCGenEventMap vertex "
232 << vtx.x()<<
", "<< vtx.y()<<
", "<< vtx.z()<<
" cm. Source event:"
242 PHG4InEvent *ineve = findNode::getClass<PHG4InEvent>(topNode,
"PHG4INEVENT");
246 std::pair<std::map<int, PHG4VtxPoint *>::const_iterator,
247 std::map<int, PHG4VtxPoint *>::const_iterator>
249 std::map<int, PHG4VtxPoint *>::const_iterator iter = range.first;
254 cout <<
PHWHERE <<
"::Error - PHG4SimpleEventGenerator expects an existing vertex in PHG4InEvent, but none exists" << endl;
259 cout <<
PHWHERE <<
"::Info - use this primary vertex from PHG4InEvent:" << endl;
270 findNode::getClass<PHG4TruthInfoContainer>(topNode,
281 cout <<
PHWHERE <<
"::Error - PHG4SimpleEventGenerator expects an existing truth vertex in PHG4TruthInfoContainer, but none exists"
288 cout <<
PHWHERE <<
"::Info - use this primary vertex from PHG4TruthInfoContainer:" << endl;
298 cout <<
PHWHERE <<
"::Error - PHG4SimpleEventGenerator expects an existing truth vertex, but none exists"
int verbosity
The verbosity level. 0 means not verbose at all.
virtual const std::string Name() const
Returns the name of this module.
PHBoolean addNode(PHNode *)
std::pair< std::map< int, PHG4VtxPoint * >::const_iterator, std::map< int, PHG4VtxPoint * >::const_iterator > GetVertices() const
void AddEmbeddedParticle(PHG4Particle *particle, int flag)
int get_pdgcode(const std::string &name) const
virtual int ReuseExistingVertex(PHCompositeNode *topNode)
std::vector< PHG4Particle * > particlelist
virtual void set_mom(const double x, const double y, const double z)
std::string get_pdgname(const int pdgcode) const
virtual void AddParticle(const std::string &particle, const double x, const double y, const double z)
virtual void set_vtx(const double x, const double y, const double z)
PHG4ParticleGeneratorBase(const std::string &name="GENERATORBASE")
void set_seed(const unsigned int iseed)
virtual int InitRun(PHCompositeNode *topNode)
void CheckAndCreateParticleVector()
double get_mass(const int pdgcode) const
void SetParticleId(PHG4Particle *particle, PHG4InEvent *ineve)
virtual ~PHG4ParticleGeneratorBase()
virtual int process_event(PHCompositeNode *topNode)
virtual void set_name(const std::string &particle="proton")
gsl_rng * RandomGenerator
virtual void set_pid(const int pid)
virtual void Print(const std::string &what="ALL") const
int reuse_existing_vertex
virtual int get_pid() const
virtual void set_pid(const int i)
virtual std::string get_name() const
virtual void set_py(const double x)
virtual void set_name(const std::string &name)
virtual void set_px(const double x)
virtual void set_pz(const double x)
void identify(std::ostream &os=std::cout) const
PHG4VtxPoint * GetPrimaryVtx(const int vtxid)
virtual double get_y() const
virtual double get_x() const
virtual void identify(std::ostream &os=std::cout) const
virtual double get_z() const
PHHepMCGenEventMap is collection of HEPMC events input into this simulation map of embedding ID -> PH...
ConstReverseIter rend() const
ConstReverseIter rbegin() const
iterator from lowest ID to highest, i.e. signal to background
std::map< int, PHHepMCGenEvent * >::const_reverse_iterator ConstReverseIter
const HepMC::FourVector & get_collision_vertex() const
collision vertex position in the Hall coordinate system, use PHENIX units of cm, ns
virtual void identify(std::ostream &os=std::cout) const
PHNode * findFirst(const std::string &, const std::string &)