1 #ifndef HEPMCNODEREADER_H__
2 #define HEPMCNODEREADER_H__
8 #include <gsl/gsl_rng.h>
33 void Embed(
const int i = 1);
38 void VertexPosition(
const double v_x,
const double v_y,
const double v_z);
44 void SmearVertex(
const double s_x,
const double s_y,
const double s_z);
48 void SetT0(
const double t0) { vertex_t0 = t0; }
60 void enable_position_filter(
const double x_min,
const double x_max,
const double y_min,
const double y_max,
const double z_min,
const double z_max);
72 double smeargauss(
const double width);
73 double smearflat(
const double width);
84 bool _particle_filter_on;
85 std::vector<int> _particle_filter_pid;
92 bool _position_filter_on;
93 double _pos_filter_x_min;
94 double _pos_filter_x_max;
95 double _pos_filter_y_min;
96 double _pos_filter_y_max;
97 double _pos_filter_z_min;
98 double _pos_filter_z_max;
101 gsl_rng *RandomGenerator;
void VertexPosition(const double v_x, const double v_y, const double v_z)
void insert_particle_filter_pid(const int a)
void enable_position_filter(const double x_min, const double x_max, const double y_min, const double y_max, const double z_min, const double z_max)
Enable and define a position filter. The x,y,z limits are in cm.
void SmearVertex(const double s_x, const double s_y, const double s_z)
int Init(PHCompositeNode *topNode)
bool PassParticleFilter(HepMC::GenParticle *p)
void Embed(const int i=1)
virtual ~HepMCNodeReader()
int process_event(PHCompositeNode *topNode)
void SetT0(const double t0)
HepMCNodeReader(const std::string &name="HEPMCREADER")
void Set_pxy2pz_rat(const double rat)
Sets the minimum Px(y)/Pz cut for inclusvie background generation.
void set_particle_filter_on(const bool a)
void SetSeed(const unsigned int i)
Override seed.