main463
Back to index.
// main463.cc is a part of the PYTHIA event generator.
// Copyright (C) 2025 Torbjorn Sjostrand.
// PYTHIA is licenced under the GNU GPL v2 or later, see COPYING for details.
// Please respect the MCnet Guidelines, see GUIDELINES for details.
// Authors:
// Marius Utheim
// Keywords:
// Low energy
// Simple illustration how to generate events at low energies.
// Outputs number of primary hadrons produced in the low energy interaction,
// as well as cos(theta) distribution of 2 -> 2 processes (if any).
#include "Pythia8/Pythia.h"
using namespace Pythia8;
//==========================================================================
int main() {
// Initialize Pythia.
Pythia pythia;
pythia.readFile("main463.cmnd");
// If Pythia fails to initialize, exit with error.
if (!pythia.init()) return 1;
// Histograms.
Hist multPrim("n_primary", 9, 1., 10.);
Hist thetaEl("cos(theta) for 2 -> 2 processes", 100, -1., 1.);
// Generate events and print statistics.
int nEvent = pythia.mode("Main:numberOfEvents");
int nSuccess = 0;
for (int iEvent = 0; iEvent < nEvent; ++iEvent) {
if (!pythia.next())
continue;
Event& ev = pythia.event;
nSuccess += 1;
// Fill number of primary hadrons.
int nPrimary = 0;
for (auto& particle : ev)
if (particle.isHadron() && particle.statusAbs() / 10 == 15)
nPrimary += 1;
multPrim.fill(nPrimary);
// Fill theta if scattering is elastic.
if (ev.nFinal() == 2) {
int in1 = ev[1].id(), in2 = ev[2].id();
int out1 = ev[ev.size() - 2].id(), out2 = ev[ev.size() - 1].id();
if ( (in1 == out1 && in2 == out2) || (in1 == out2 && in2 == out1) )
thetaEl.fill(cos(ev[ev.size() - 1].theta()));
}
}
// Plot histograms and statistics.
multPrim /= nSuccess;
cout << multPrim;
if (thetaEl.getEntries() > 0) {
thetaEl *= 50. / thetaEl.getEntries();
cout << thetaEl;
}
pythia.stat();
// Done.
return 0;
}