1 #ifndef PHG4SimpleEventGenerator_H__
2 #define PHG4SimpleEventGenerator_H__
9 #include <TGeoManager.h>
10 #include <phgeom/PHGeomUtility.h>
34 void add_particles(
const std::string &name,
const unsigned int count);
43 void set_eta_range(
const double eta_min,
const double eta_max);
46 void set_phi_range(
const double phi_min,
const double phi_max);
50 void set_pt_range(
const double pt_min,
const double pt_max,
const double pt_gaus_width = 0);
54 void set_p_range(
const double p_min,
const double p_max,
const double p_gaus_width = 0);
76 const double x_min,
const double x_max,
77 const double y_min,
const double y_max,
78 const double z_min,
const double z_max
86 double smearvtx(
const double position,
const double width,
FUNCTION dist)
const;
89 std::vector<std::pair<int, unsigned int> > _particle_codes;
90 std::vector<std::pair<std::string, unsigned int> > _particle_names;
98 double _vertex_width_x;
99 double _vertex_width_y;
100 double _vertex_width_z;
101 double _vertex_offset_x;
102 double _vertex_offset_y;
103 double _vertex_offset_z;
105 double _vertex_size_mean;
106 double _vertex_size_width;
113 double _pt_gaus_width;
116 double _p_gaus_width;
118 double _px_min, _px_max;
119 double _py_min, _py_max;
120 double _pz_min, _pz_max;
126 bool _legacy_vertexgenerator;
Event generator to generate a set of particles under a condition of the vertex and the momentum.
void set_t0(const double t0)
set the starting time for the event
void add_particles(const std::string &name, const unsigned int count)
interface for adding particles by name
void set_pxpypz_range(const double x_min, const double x_max, const double y_min, const double y_max, const double z_min, const double z_max)
void set_phi_range(const double phi_min, const double phi_max)
range of randomized phi values
int End(PHCompositeNode *topNode)
Called at the end of all processing.
void set_vertex_size_function(FUNCTION r)
set the distribution function of particles about the vertex
int process_event(PHCompositeNode *topNode)
int InitRun(PHCompositeNode *topNode)
void set_eta_range(const double eta_min, const double eta_max)
range of randomized eta values
void set_vertex_distribution_width(const double x, const double y, const double z)
set the width of the vertex distribution function about the mean
PHG4SimpleEventGenerator(const std::string &name="EVTGENERATOR")
virtual ~PHG4SimpleEventGenerator()
void set_vertex_size_parameters(const double mean, const double width)
set the dimensions of the distribution of particles about the vertex
void set_pt_range(const double pt_min, const double pt_max, const double pt_gaus_width=0)
FUNCTION
supported function distributions
void set_p_range(const double p_min, const double p_max, const double p_gaus_width=0)
void set_vertex_distribution_mean(const double x, const double y, const double z)
set the mean value of the vertex distribution
void enableLegacyVtxGen()
Enable legacy vertex gen.
void set_vertex_distribution_function(FUNCTION x, FUNCTION y, FUNCTION z)
toss a new vertex according to a Uniform or Gaus distribution
void set_existing_vertex_offset_vector(const double x, const double y, const double z)
set an offset vector from the existing vertex
An SQ interface class to hold one event header.
An SQ interface class to hold one simulated-event header.
Class to generate the event vertex, based on the beam profile and the target+spectrometer materials g...