main302
Back to index.
// main302.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.
// Keywords:
// Colour reconnection
// E+e‑ events
// Authors:
// Torbjörn Sjostrand
// Plot the colour reconnection rate in W+W- hadronic events
// as a function of collision energy.
#include "Pythia8/Pythia.h"
using namespace Pythia8;
//==========================================================================
int main() {
// Number of events.
int nEvent = 4000;
// Histograms.
Hist recrateSK1("reconnection rate SK1", 40, 0., 400.);
Hist recrateSK2("reconnection rate SK2", 40, 0., 400.);
// Loop over reconnection model and CM energy.
for (int iRec = 1; iRec < 3; ++iRec) {
Hist& recrate = (iRec == 1) ? recrateSK1 : recrateSK2;
for (int iEcm = 14; iEcm < 40; ++iEcm) {
double eCM = 10. * iEcm - 5.;
// Quiet generator creation. Shorthand for the event record.
Pythia pythia ("../share/Pythia8/xmldoc", false);
Event& event = pythia.event;
// Incoming beams and energy. Optionally no ISR.
pythia.readString("Beams:idA = -11");
pythia.readString("Beams:idB = 11");
pythia.settings.parm("Beams:eCM", eCM);
pythia.readString("PDF:lepton = off");
// Hard process, with hadronic W decays.
pythia.readString("WeakDoubleBoson:ffbar2WW = on");
pythia.readString("24:onMode = off");
pythia.readString("24:onIfAny = 1 2 3 4 5");
// Switch on CR.
pythia.readString("ColourReconnection:reconnect = on");
pythia.settings.mode("ColourReconnection:mode", iRec + 2);
pythia.readString("ColourReconnection:forceResonance = on");
// Reduce printout. Switch off hadronization and decays.
pythia.readString("Print:quiet = on");
pythia.readString("HadronLevel:Hadronize = off");
pythia.readString("HadronLevel:Decay = off");
// If Pythia fails to initialize, exit with error.
if (!pythia.init()) return 1;
int nRecon = 0;
// Begin event loop.
for (int iEvent = 0; iEvent < nEvent; ++iEvent) {
if (!pythia.next()) continue;
// Check if colour reconnection has occured.
bool hasRec = false;
for (int i = 6; i < event.size(); ++i)
if (event[i].statusAbs() == 79) hasRec = true;
if (hasRec) ++nRecon;
// End of loops. Fill reconnection rate.
}
recrate.fill( eCM, double(nRecon) / double(nEvent));
}
}
// Print and plot histograms.
cout << recrateSK1 << recrateSK2;
HistPlot hpl("plot302");
hpl.frame( "fig302", "Reconnection rate as a function of CM energy for "
"e$^+$e$^-$ $\\to$ W$^+$W$^-$", "$E_{\\mathrm{CM}}$ (GeV)", "Probability");
hpl.add( recrateSK1, "h,blue", "SK I");
hpl.add( recrateSK2, "h,red", "SK II");
hpl.plot();
// Done.
return 0;
}