main363
Back to index.
// main363.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:
// Philip Ilten
// Keywords:
// Onia
// Helaconia
// An example where the quarkonia hard process (p p -> J/psi g) is
// automatically produced externally with HelacOnia, read in, and the
// remainder of the event is then produced by Pythia (MPI, showers,
// and hadronization). A comparison is made between events produced
// with Pythia at LO and HelacOnia at LO.
// For this example to run, HelacOnia must be installed and the
// command "exe" (set by default as "ho_cluster") must be available
// via the command line. Note that this example has only been tested
// with HelacOnia version 2.2.4; due to rapid HelacOnia development,
// this example may not work with other versions. For more details on
// the LHAHelacOnia class see the comments of
// Pythia8Plugins/LHAHelacOnia.h.
#include "Pythia8/Pythia.h"
#include "Pythia8Plugins/LHAHelaconia.h"
using namespace Pythia8;
//==========================================================================
// A simple method to run Pythia, analyze the events, and fill a histogram.
bool run(Pythia& pythia, Hist& hist, int nEvent) {
pythia.readString("Random:setSeed = on");
pythia.readString("Random:seed = 1");
if (!pythia.init()) return false;
for (int iEvent = 0; iEvent < nEvent; ++iEvent) {
if (!pythia.next()) continue;
for (int i = 0; i < pythia.event.size(); ++i) {
if (pythia.event[i].id() != 443) continue;
hist.fill(pythia.event[pythia.event[i].iBotCopyId()].pT());
break;
}
}
pythia.stat();
return true;
}
//==========================================================================
int main() {
// The name of the HelacOnia executable.
// You must prepend this string with the path to the executable
// on your local installation, or otherwise make it available.
string exe("ho_cluster");
// Create the histograms.
Hist pyPtPsi("Pythia dN/dpT J/psi", 100, 0., 20.);
Hist hoPtPsi("HelacOnia dN/dpT J/psi", 100, 0., 20.);
// Produce leading-order events with Pythia.
{
Pythia pythia;
pythia.readString("Beams:eCM = 13000.");
pythia.readString("Charmonium:gg2ccbar(3S1)[3S1(1)]g = on,off");
pythia.readString("PhaseSpace:pTHatMin = 2");
// If we fail to initialize, abort.
if (!run(pythia, pyPtPsi, 1000)) return 1;
}
// Produce leading-order events with HelacOnia.
{
Pythia pythia;
shared_ptr<LHAupHelaconia> helaconiaPtr;
helaconiaPtr = make_shared<LHAupHelaconia>(&pythia, "helaconiarun", exe);
helaconiaPtr->readString("generate g g > cc~(3S11) g");
helaconiaPtr->readString("set energy_beam1 = 6500");
helaconiaPtr->readString("set energy_beam2 = 6500");
helaconiaPtr->readString("set minptconia = 2");
pythia.setLHAupPtr((LHAupPtr)helaconiaPtr);
// If we fail to initialize, abort.
if(!run(pythia, hoPtPsi, 1000)) return 1;
}
// Print the histograms.
cout << pyPtPsi;
cout << hoPtPsi;
return 0;
}