main407

Back to index.

// main407.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:
//            Peter Skands
//            Thanks to: M di Mauro
//            for the original template for this example

// Keywords:
//            Vincia
//            Weak showers
//            LHE file
//            Dark matter

// Example showing how to run Vincia's electroweak shower with LHEF input.
// This requires the LHEF files to contain helicities for the hard partons.
// In this example, the LHEF file contains dark-matter particles annihilating
// to electron-positron pairs.

// Note: emitted weak bosons decay inclusively; it would be up to the user
// themselves to filter events with decays to specific channels if desired.

#include "Pythia8/Pythia.h"
#include "math.h"
#include <iostream>
#include <string>

using namespace std;
using namespace Pythia8;

int main() {

  // Generator.
  Pythia pythia;

  // Read Pythia settings from command file.
  pythia.readFile("main407.cmnd");

  // If Pythia fails to initialize, exit with error.
  if (!pythia.init()) return 1;

  // Allow for possibility of a few faulty events.
  int nError      = pythia.settings.mode("Main:timesAllowErrors");

  double logxMin = -9.;
  double logxMax = 0.;
  double nBins = 100;
  double DeltaBin = (logxMax-logxMin)/nBins;

  // Histogram particle spectra.
  Hist gamma("gamma spectrum", nBins, logxMin, logxMax);
  Hist electron("e+- spectrum", nBins, logxMin, logxMax);
  Hist proton("p spectrum", nBins, logxMin, logxMax);
  Hist nue("nu_e spectrum", nBins, logxMin, logxMax);
  Hist numu("nu_mu spectrum", nBins, logxMin, logxMax);
  Hist nutau("nu_tau spectrum", nBins, logxMin, logxMax);
  Hist rest("remaining particle spectrum", nBins, logxMin, logxMax);

  // Begin event loop.
  int nEvent = 0;
  int iError = 0;
  while (true) {

    // Generate the next event.
    if (!pythia.next()) {

      // If failure because reached end of file then exit event loop.
      if (pythia.info.atEndOfFile()) break;

      // Otherwise count event failure and continue/exit as necessary.
      cout << "Warning: event " << nEvent << " failed" << endl;
      if (++iError == nError) {
        cout << "Error: too many event failures... exiting" << endl;
        break;
      }

      continue;
    }

    /*
     * Process dependent checks and analysis go here ...
     */

    // Add total number of events attempted.
    ++nEvent;

    // Get DM mass.
    double mDM = pythia.event[1].m();

    // Loop over all particles and select final-state ones for histrograms.
    for (int i = 0; i < pythia.event.size(); ++i) {
      if ( !pythia.event[i].isFinal() ) continue;
      int id       = pythia.event[i].id();
      int idAbs    = pythia.event[i].idAbs();
      double e     = pythia.event[i].e();
      if (e <= 0) continue;
      double logx  = log10(e/mDM);
      // Select photons.
      if (idAbs == 22) gamma.fill(logx);
      // Select electrons (positron equivalent).
      else if (id == -11)  electron.fill(logx);
      // Select protons.
      else if (id == -2212 or idAbs == 2112) proton.fill(logx);
      // Select various neutrinos.
      else if (id == 12) nue.fill(logx);
      else if (id == 14) numu.fill(logx);
      else if (id == 16) nutau.fill(logx);
      else rest.fill(logx);
    }
  }


  //Statistic and histrograms.
  pythia.stat();

  gamma.operator*=(1./nEvent/DeltaBin);
  electron.operator*=(1./nEvent/DeltaBin);
  proton.operator*=(1./nEvent/DeltaBin);
  nue.operator*=(1./nEvent/DeltaBin);
  numu.operator*=(1./nEvent/DeltaBin);
  nutau.operator*=(1./nEvent/DeltaBin);

  // Make tables, including statistical errors (last argument = true).
  gamma.table("main407-gamma.dat", false, true, true);
  electron.table("main407-positron.dat", false, true, true);
  proton.table("main407-antiproton.dat", false, true, true);
  nue.table("main407-nue.dat", false, true, true);
  numu.table("main407-numu.dat", false, true, true);
  nutau.table("main407-nutau.dat", false, true, true);
  rest.table("main407-rest.dat", false, true, true);

  cout << gamma << electron << proton << nue << numu << nutau << rest;

  //Done
  return 0;
}