86 TPythia8* TPythia8::fgInstance = 0;
97 Fatal(
"TPythia8",
"There's already an instance of TPythia8");
102 fPythia =
new Pythia8::Pythia();
111 fNumberOfParticles(0)
114 Fatal(
"TPythia8",
"There's already an instance of TPythia8");
119 fPythia =
new Pythia8::Pythia(xmlDir);
140 return fgInstance ? fgInstance : (fgInstance =
new TPythia8()) ;
151 fPythia->settings.mode(
"Beams:idA", idAin);
152 fPythia->settings.mode(
"Beams:idB", idBin);
153 fPythia->settings.mode(
"Beams:frameType", 1);
154 fPythia->settings.parm(
"Beams:eCM", ecms);
156 return fPythia->init();
169 fPythia->settings.mode(
"Beams:idA", idAin);
170 fPythia->settings.mode(
"Beams:idB", idBin);
171 fPythia->settings.mode(
"Beams:frameType", 2);
172 fPythia->settings.parm(
"Beams:eA", eAin);
173 fPythia->settings.parm(
"Beams:eB", eBin);
176 return fPythia->init();
187 fNumberOfParticles = fPythia->event.size() - 1;
195 if (particles == 0)
return 0;
197 clonesParticles.
Clear();
201 fNumberOfParticles = fPythia->event.size();
202 if (fPythia->event[0].id() == 90) {
206 if (!strcmp(option,
"") || !strcmp(option,
"Final")) {
208 if (fPythia->event[i].id() == 90)
continue;
209 if (fPythia->event[i].isFinal()) {
211 fPythia->event[i].id(),
212 fPythia->event[i].isFinal(),
213 fPythia->event[i].mother1() + ioff,
214 fPythia->event[i].mother2() + ioff,
215 fPythia->event[i].daughter1() + ioff,
216 fPythia->event[i].daughter2() + ioff,
217 fPythia->event[i].px(),
218 fPythia->event[i].py(),
219 fPythia->event[i].pz(),
220 fPythia->event[i].e(),
221 fPythia->event[i].xProd(),
222 fPythia->event[i].yProd(),
223 fPythia->event[i].zProd(),
224 fPythia->event[i].tProd());
228 }
else if (!strcmp(option,
"All")) {
230 if (fPythia->event[i].id() == 90)
continue;
232 fPythia->event[i].id(),
233 fPythia->event[i].isFinal(),
234 fPythia->event[i].mother1() + ioff,
235 fPythia->event[i].mother2() + ioff,
236 fPythia->event[i].daughter1() + ioff,
237 fPythia->event[i].daughter2() + ioff,
238 fPythia->event[i].px(),
239 fPythia->event[i].py(),
240 fPythia->event[i].pz(),
241 fPythia->event[i].e(),
242 fPythia->event[i].xProd(),
243 fPythia->event[i].yProd(),
244 fPythia->event[i].zProd(),
245 fPythia->event[i].tProd());
249 if(ioff==-1) fNumberOfParticles--;
260 Int_t numpart = fPythia->event.size();
261 if (fPythia->event[0].id() == 90) {
268 for (
Int_t i = 1; i <= numpart; i++) {
270 fPythia->event[i].id(),
271 fPythia->event[i].isFinal(),
272 fPythia->event[i].mother1() + ioff,
273 fPythia->event[i].mother2() + ioff,
274 fPythia->event[i].daughter1() + ioff,
275 fPythia->event[i].daughter2() + ioff,
276 fPythia->event[i].px(),
277 fPythia->event[i].py(),
278 fPythia->event[i].pz(),
279 fPythia->event[i].e(),
280 fPythia->event[i].xProd(),
281 fPythia->event[i].yProd(),
282 fPythia->event[i].zProd(),
283 fPythia->event[i].tProd());
293 return (fPythia->event.size() - 1);
301 fPythia->readString(
string);
309 fPythia->readFile(
string);
317 fPythia->settings.listAll();
325 fPythia->settings.listChanged();
333 fPythia->particleData.list(
id);
341 fPythia->particleData.listAll();
349 fPythia->particleData.listChanged();
365 fPythia->event.list();
375 0, 0,
"QCD string", 90);
377 0, 0,
"QCD diffr. state", 9900110);
379 0, 1,
"QCD diffr. state", 9900210);
381 0, 0,
"QCD diffr. state", 9900220);
383 0, 0,
"QCD diffr. state", 9900330);
385 0, 0,
"QCD diffr. state", 9900440);
387 0, 0,
"QCD diffr. state", 9902110);
389 0, 1,
"QCD diffr. state", 9902210);
void PlistAll() const
Event listing.
void PrintStatistics() const
Print end of run statistics.
virtual Int_t ImportParticles(TClonesArray *particles, Option_t *option="")
Import particles from Pythia stack.
Pythia8::Pythia * fPythia
singleton instance
TPythia8()
Number of particles.
static TPythia8 * Instance()
Return an instance of TPythia8.
void PlistChanged() const
Event listing.
virtual ~TPythia8()
Destructor.
void Fatal(const char *location, const char *msgfmt,...)
virtual void Clear(Option_t *option="")
Remove all objects from the array.
virtual void Delete(Option_t *option="")
Remove all objects from the array AND delete all heap based objects.
The interface to various event generators.
Description of the dynamic properties of a particle.
Bool_t Initialize(Int_t idAin, Int_t idBin, Double_t ecms)
Initialization.
void ListChanged() const
Event listing.
virtual void Fatal(const char *method, const char *msgfmt,...) const
Issue fatal error message.
virtual TParticlePDG * AddParticle(const char *Name, const char *Title, Double_t Mass, Bool_t Stable, Double_t DecayWidth, Double_t Charge, const char *ParticleClass, Int_t PdgCode, Int_t Anti=-1, Int_t TrackingCode=0)
Particle definition normal constructor.
Particle database manager class.
friend class TClonesArray
static TDatabasePDG * Instance()
static function
void Plist(Int_t id) const
Event listing.
void ListAll() const
Event listing.
void AddParticlesToPdgDataBase()
Add some pythia specific particle code to the data base.
virtual void Clear(Option_t *option="")
Clear the clones array.
void EventListing() const
Event listing.
TObjArray * fParticles
display neutrons if true
Int_t GetN() const
Initialization.
Int_t fNumberOfParticles
The pythia8 instance.
An array of clone (identical) objects.
virtual void GenerateEvent()
Generate the next event.
void ReadConfigFile(const char *string) const
Configuration.
void ReadString(const char *string) const
Configuration.