1 #ifndef __PHPYTHIA8_H__
2 #define __PHPYTHIA8_H__
8 #include <Pythia8/Pythia.h>
12 #include <gsl/gsl_rng.h>
48 if (cfg_file) _configFile = cfg_file;
106 _legacy_vertexgenerator=
true;
129 int read_config(
const char *cfg_file = 0);
130 int read_config_hybrid (
const char *cfg_file1 = 0,
const char *cfg_file2 =0);
132 double percent_diff(
const double a,
const double b) {
return abs((a - b) / a); }
136 std::vector<PHPy8GenTrigger *> _registeredTriggers;
142 Pythia8::Pythia *_pythia;
143 Pythia8::Pythia *ppGen;
144 Pythia8::Pythia *pnGen;
147 std::string _configFile;
148 std::vector<std::string> _commands;
152 HepMC::Pythia8ToHepMC *_pythiaToHepMC;
158 bool _save_integrated_luminosity;
164 bool _legacy_vertexgenerator;
PHHepMCGenHelper provides service of DST upload of HepMC subevent, vertex assignment and random gener...
double get_LegacyPARatio()
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,...
void enableLegacyVtxGen()
to use the vertex from legacy generator
int get_embedding_id() const
void set_embedding_id(int id)
VTXFUNC
supported function distributions
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
void set_reuse_vertex(int src_embedding_id)
reuse vertex from another PHHepMCGenEvent with embedding_id = src_embedding_id Additional smearing an...
void print_config() const
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
int process_event(PHCompositeNode *topNode)
void enableLegacyVtxGen()
add interface for using legacy gen vertex; Abi
int End(PHCompositeNode *topNode)
Called at the end of all processing.
void set_vertex_distribution_function(PHHepMCGenHelper::VTXFUNC x, PHHepMCGenHelper::VTXFUNC y, PHHepMCGenHelper::VTXFUNC z, PHHepMCGenHelper::VTXFUNC t)
toss a new vertex according to a Uniform or Gaus distribution
PHPythia8(const std::string &name="PHPythia8")
void set_embedding_id(int id)
double get_LegacyPARatio()
void set_config_file(const char *cfg_file)
int ResetEvent(PHCompositeNode *topNode)
Clean up after each event.
void beam_vertex_parameters(double beamX, double beamY, double beamZ, double beamXsigma, double beamYsigma, double beamZsigma)
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,...
void process_string(std::string s)
pass commands directly to PYTHIA8
int get_embedding_id() const
void save_integrated_luminosity(const bool b)
whether to store the integrated luminosity and other event statistics to the TOP/RUN/PHGenIntegral no...
void set_reuse_vertex(int src_embedding_id)
reuse vertex from another PHHepMCGenEvent with embedding_id = src_embedding_id Additional smearing an...
void register_trigger(PHPy8GenTrigger *theTrigger)
set event selection criteria
int Init(PHCompositeNode *topNode)