1 #ifndef PHG4PSScanGenerator_H__
2 #define PHG4PSScanGenerator_H__
29 void add_particles(
const std::string &name,
const unsigned int count);
38 void set_eta_range(
const double eta_min,
const double eta_max);
41 void set_phi_range(
const double phi_min,
const double phi_max);
45 void set_pt_range(
const double pt_min,
const double pt_max,
46 const double pt_gaus_width = 0);
50 void set_p_range(
const double p_min,
const double p_max,
51 const double p_gaus_width = 0);
76 const double y_min,
const double y_max,
const double z_min,
110 double smearvtx(
const double position,
const double width,
114 std::vector<std::pair<int, unsigned int> > _particle_codes;
115 std::vector<std::pair<std::string, unsigned int> > _particle_names;
123 double _vertex_width_x;
124 double _vertex_width_y;
125 double _vertex_width_z;
126 double _vertex_offset_x;
127 double _vertex_offset_y;
128 double _vertex_offset_z;
130 double _vertex_size_mean;
131 double _vertex_size_width;
138 double _pt_gaus_width;
141 double _p_gaus_width;
143 double _px_min, _px_max;
144 double _py_min, _py_max;
145 double _pz_min, _pz_max;
virtual ~PHG4PSScanGenerator()
void set_py_step(double pyStep)
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
void set_p_range(const double p_min, const double p_max, const double p_gaus_width=0)
void set_eta_range(const double eta_min, const double eta_max)
range of randomized eta values
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)
double get_px_step() const
double get_pz_step() const
void set_vertex_size_function(FUNCTION r)
set the distribution function of particles about the vertex
FUNCTION
supported function distributions
void set_t0(const double t0)
set the starting time for the event
void set_vertex_distribution_mean(const double x, const double y, const double z)
set the mean value of the vertex distribution
void set_existing_vertex_offset_vector(const double x, const double y, const double z)
set an offset vector from the existing vertex
int process_event(PHCompositeNode *topNode)
void add_particles(const std::string &name, const unsigned int count)
interface for adding particles by name
void set_vertex_size_parameters(const double mean, const double width)
set the dimensions of the distribution of particles about the vertex
int InitRun(PHCompositeNode *topNode)
void set_vertex_distribution_function(FUNCTION x, FUNCTION y, FUNCTION z)
toss a new vertex according to a Uniform or Gaus distribution
void set_phi_range(const double phi_min, const double phi_max)
range of randomized phi values
double get_py_step() const
void set_px_step(double pxStep)
PHG4PSScanGenerator(const std::string &name="EVTGENERATOR")
void set_pz_step(double pzStep)
void set_pt_range(const double pt_min, const double pt_max, const double pt_gaus_width=0)