CMS 3D CMS Logo

Pythia6EGun.cc
Go to the documentation of this file.
1 
2 #include <iostream>
3 
4 #include "Pythia6EGun.h"
5 
7 
10 
12 
14 
15 using namespace edm;
16 using namespace gen;
17 
18 Pythia6EGun::Pythia6EGun(const ParameterSet& pset) : Pythia6ParticleGun(pset) {
19  // ParameterSet defpset ;
20  ParameterSet pgun_params = pset.getParameter<ParameterSet>("PGunParameters"); // , defpset ) ;
21  fMinEta = pgun_params.getParameter<double>("MinEta"); // ,-2.2);
22  fMaxEta = pgun_params.getParameter<double>("MaxEta"); // , 2.2);
23  fMinE = pgun_params.getParameter<double>("MinE"); // , 0.);
24  fMaxE = pgun_params.getParameter<double>("MaxE"); // , 0.);
25  fAddAntiParticle = pgun_params.getParameter<bool>("AddAntiParticle"); //, false) ;
26 }
27 
29 
30 void Pythia6EGun::generateEvent(CLHEP::HepRandomEngine*) {
31  Pythia6Service::InstanceWrapper guard(fPy6Service); // grab Py6 instance
32 
33  // now actualy, start cooking up the event gun
34  //
35 
36  // 1st, primary vertex
37  //
38  HepMC::GenVertex* Vtx = new HepMC::GenVertex(HepMC::FourVector(0., 0., 0.));
39 
40  // here re-create fEvt (memory)
41  //
42  fEvt = new HepMC::GenEvent();
43 
44  int ip = 1;
45  for (size_t i = 0; i < fPartIDs.size(); i++) {
46  int particleID = fPartIDs[i]; // this is PDG - need to convert to Py6 !!!
47  int py6PID = HepPID::translatePDTtoPythia(particleID);
48  int dum = 0;
49  double ee = 0, the = 0, eta = 0;
50  double mass = pymass_(particleID);
51 
52  // fill p(ip,5) (in PYJETS) with mass value right now,
53  // because the (hardcoded) mstu(10)=1 will make py1ent
54  // pick the mass from there
55  pyjets.p[4][ip - 1] = mass;
56 
57  double phi = (fMaxPhi - fMinPhi) * pyr_(&dum) + fMinPhi;
58  ee = (fMaxE - fMinE) * pyr_(&dum) + fMinE;
59  eta = (fMaxEta - fMinEta) * pyr_(&dum) + fMinEta;
60  the = 2. * atan(exp(-eta));
61 
62  py1ent_(ip, py6PID, ee, the, phi);
63 
64  double px = pyjets.p[0][ip - 1]; // pt*cos(phi) ;
65  double py = pyjets.p[1][ip - 1]; // pt*sin(phi) ;
66  double pz = pyjets.p[2][ip - 1]; // mom*cos(the) ;
67 
68  HepMC::FourVector p(px, py, pz, ee);
69  HepMC::GenParticle* Part = new HepMC::GenParticle(p, particleID, 1);
70  Part->suggest_barcode(ip);
71  Vtx->add_particle_out(Part);
72 
73  if (fAddAntiParticle) {
74  ip = ip + 1;
75  HepMC::GenParticle* APart = addAntiParticle(ip, particleID, ee, eta, phi);
76  if (APart)
77  Vtx->add_particle_out(APart);
78  }
79  ip++;
80  }
81 
82  fEvt->add_vertex(Vtx);
83 
84  // run pythia
85  pyexec_();
86 
87  return;
88 }
89 
T getParameter(std::string const &) const
HepMC::GenParticle * addAntiParticle(int &, int &, double &, double &, double &)
Definition: Pythia6Gun.cc:198
HepMC::GenEvent * fEvt
Definition: Pythia6Gun.h:66
double p[5][pyjets_maxn]
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:16
double fMinPhi
Definition: Pythia6Gun.h:61
double pymass_(int &)
std::vector< int > fPartIDs
double fMaxPhi
Definition: Pythia6Gun.h:62
~Pythia6EGun() override
Definition: Pythia6EGun.cc:28
void py1ent_(int &ip, int &kf, double &pe, double &the, double &phi)
HLT enums.
Pythia6Service * fPy6Service
Definition: Pythia6Gun.h:56
double pyr_(int *idummy)
void pyexec_()
void generateEvent(CLHEP::HepRandomEngine *) override
Definition: Pythia6EGun.cc:30