11 #ifndef SIMULATION_CORESOFTWARE_SIMULATION_G4SIMULATION_PHHEPMC_PHHEPMCGENHELPER_H_
12 #define SIMULATION_CORESOFTWARE_SIMULATION_G4SIMULATION_PHHEPMC_PHHEPMCGENHELPER_H_
27 #include <gsl/gsl_rng.h>
73 _reuse_vertex_embedding_id = src_embedding_id;
102 _geneventmap = geneventmap;
114 double smear(
const double position,
const double width,
VTXFUNC dist)
const;
127 double _vertex_width_x;
128 double _vertex_width_y;
129 double _vertex_width_z;
130 double _vertex_width_t;
141 int _reuse_vertex_embedding_id;
148 bool _legacy_vertexgenerator;
PHHepMCGenEventMap is collection of HEPMC events input into this simulation map of embedding ID -> PH...
PHHepMCGenHelper provides service of DST upload of HepMC subevent, vertex assignment and random gener...
double get_LegacyPARatio()
void set_geneventmap(PHHepMCGenEventMap *geneventmap)
void set_vertex_distribution_function(VTXFUNC x, VTXFUNC y, VTXFUNC z, VTXFUNC t)
toss a new vertex according to a Uniform or Gaus distribution
void set_vertex_distribution_width(const double x, const double y, const double z, const double t)
set the width of the vertex distribution function about the mean, use PHENIX units of cm,...
PHHepMCGenEventMap * get_geneventmap()
virtual ~PHHepMCGenHelper()
void enableLegacyVtxGen()
to use the vertex from legacy generator
int create_node_tree(PHCompositeNode *topNode)
init interface nodes
const PHHepMCGenEventMap * get_geneventmap() const
int get_embedding_id() const
void set_embedding_id(int id)
VTXFUNC
supported function distributions
@ Gaus
normal distribution with sigma width set via set_vertex_distribution_width()
@ Uniform
uniform distribution with half width set via set_vertex_distribution_width()
void set_vertex_distribution_mean(const double x, const double y, const double z, const double t)
set the mean value of the vertex distribution, use PHENIX units of cm, ns
PHHepMCGenEvent * insert_event(HepMC::GenEvent *evt)
send HepMC::GenEvent to DST tree. This function takes ownership of evt
gsl_rng * get_random_generator()
gsl_rng * RandomGenerator
void set_reuse_vertex(int src_embedding_id)
reuse vertex from another PHHepMCGenEvent with embedding_id = src_embedding_id Additional smearing an...
void move_vertex(PHHepMCGenEvent *genevent)
move vertex according to vertex settings
double smear(const double position, const double width, VTXFUNC dist) const
Class to generate the event vertex, based on the beam profile and the target+spectrometer materials g...