main216
Back to index.
// main216.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:
// Basic usage
// Jet finding
// This is a simple test program, convenient for tutorials.
// It illustrates searches for a 1 TeV Z' decaying to two jets.
#include "Pythia8/Pythia.h"
using namespace Pythia8;
//==========================================================================
int main() {
// Number of events, generated and listed ones.
int nEvent = 1000;
int nListJets = 5;
// Pythia generator at LHC energy; pp is default beam setup.
Pythia pythia;
pythia.readString("Beams:eCM = 13000.");
// Z' production with 1 TeV mass (+- 200 GeV) and decay only to d/u/s/c/b.
pythia.readString("NewGaugeBoson:ffbar2gmZZprime = on");
pythia.readString("32:m0 = 1000.");
pythia.readString("PhaseSpace:mHatMin = 800.");
pythia.readString("PhaseSpace:mHatMax = 1200.");
pythia.readString("32:onMode = off");
pythia.readString("32:onIfAny = 1 2 3 4 5");
// Put other settings here.
// If Pythia fails to initialize, exit with error.
if (!pythia.init()) return 1;
// Required parameters for an anti-kT jet finder.
int jetPower = -1;
double jetRadius = 0.7;
double jetpTmin = 100.;
// Exclude high-eta and neutrinos (and other invisible) from study.
double etaMax = 4.;
int nSel = 2;
// Set up jet finder, with pion mass assumed for non-photons.
SlowJet slowJet( jetPower, jetRadius, jetpTmin, etaMax, nSel, 1);
// Histograms.
Hist massZp("true Zprime mass", 100, 0., 2000.);
Hist mass2j("two-jet mass", 100, 0., 2000.);
Hist deltaM("mass shift", 100, -500., 500.);
Hist deltaMz("mass shift zoomed", 100, -50., 50.);
// Begin event loop. Generate event. Skip if error.
for (int iEvent = 0; iEvent < nEvent; ++iEvent) {
if (!pythia.next()) continue;
// A copy of the Z' is always stored in slot 5 of the event record.
double mZp = pythia.event[5].m();
massZp.fill( mZp);
// Analyze Slowet jet properties. List first few.
slowJet.analyze( pythia.event );
if (iEvent < nListJets) slowJet.list();
// Form invariant mass of two highest-pT jets.
if ( slowJet.sizeJet() > 1) {
double m2j = (slowJet.p(0) + slowJet.p(1)).mCalc();
mass2j.fill( m2j);
// Shift in mass from true to reconstructed.
deltaM.fill( m2j - mZp);
deltaMz.fill( m2j - mZp);
}
// End of event loop. Statistics.
}
pythia.stat();
// Normalize histograms to rate per GeV and print them.
massZp *= 0.05 / double(nEvent);
mass2j *= 0.05 / double(nEvent);
deltaM *= 0.10 / double(nEvent);
deltaMz *= 1.0 / double(nEvent);
cout << massZp << mass2j << deltaM << deltaMz;
// Plot histograms for nicer output.
HistPlot hpl("plot216");
hpl.frame( "fig216", "Zprime mass distribution", "$m$ (GeV)",
"Probability");
hpl.add( massZp, "h,blue", "true mass");
hpl.add( mass2j, "h,red", "reconstructed mass");
hpl.plot();
hpl.plotFrame("", deltaM, "Zprime mass shift from true to reconstructed",
"$\\Delta m$ (GeV)", "Probability", "h,magenta", "reconstructed$-$true");
hpl.plotFrame("", deltaMz,
"Zprime mass shift from true to reconstructed (zoomed-in)",
"$\\Delta m$ (GeV)", "Probability", "h,magenta", "reconstructed$-$true");
// Done.
return 0;
}