main509

Back to index.

// main509.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:
//            Torbjorn Sjostrand

// Keywords:
//            Hidden Valley

// Test of Hidden Valley production in a few different channels.

#include "Pythia8/Pythia.h"
using namespace Pythia8;

//==========================================================================

int main() {

  // Some main settings. Many other options exist; see examples further down.

  // Process type: 1 = Fv pair, 2 = Zv portal to qv, 3 = Higgs portal to gv.
  int  procType = 1;

  // Details of simulation: QCD/QED, gammav massive or not, simplifications.
  bool doHVQCD     = true;
  bool brokenQED   = false;
  bool onlyFSR     = false;
  bool onlyHVinFSR = false;

  // Number of events.
  int nEvent = 1000;

  // Begin to set up generator: beams.
  Pythia pythia;
  Event& event = pythia.event;
  pythia.readString("Beams:eCM = 13000.");

  // Production process via Fv Fvbar.
  if (procType == 1) {
    pythia.readString("HiddenValley:gg2DvDvbar = on");
    pythia.readString("4900001:m0 = 1000.");

  // Production process via Zv.
  } else if (procType == 2) {
    pythia.readString("HiddenValley:ffbar2Zv = on");
    pythia.readString("4900023:m0   = 1000.");
    pythia.readString("4900023:mMin =  500.");
    pythia.readString("4900023:mMax = 1500.");
    pythia.readString("4900023:onMode = off");
    pythia.readString("4900023:onIfAny = 4900101 4900102 4900103");

  // Production process via H, and decay to gv gv or gammav gammav.
  } else {
    pythia.readString("HiggsSM:all = on");
    pythia.readString("25:onMode = 0");
    if (doHVQCD)
      pythia.readString("25:addChannel = 1 0.1 100 4900021 4900021");
    else
      pythia.readString("25:addChannel = 1 0.1 100 4900022 4900022");
  }

  // Hidden-Valley parton shower.
  pythia.readString("Hiddenvalley:FSR = on");
  if (doHVQCD) pythia.readString("Hiddenvalley:alphaOrder = 1");
  pythia.readString("Hiddenvalley:Lambda = 4.");
  pythia.readString("HiddenValley:pTminFSR = 6.");

  // Fragmentation process of qv to HV-mesons.
  if (doHVQCD) pythia.readString("HiddenValley:Ngauge = 3");
  else         pythia.readString("HiddenValley:Ngauge = 1");
  pythia.readString("HiddenValley:nFlav = 3");
  pythia.readString("HiddenValley:fragment = on");

  // Mass of a Hidden-Valley photon.
  if (brokenQED) pythia.readString("4900022:m0 = 1.");
  else           pythia.readString("4900022:mayDecay = off");

  // Switch off unwanted parts for HV-only simulation.
  if (onlyFSR) {
    pythia.readString("PartonLevel:ISR = off");
    pythia.readString("PartonLevel:MPI = off");
    pythia.readString("HadronLevel:all = off");
  }
  if (onlyHVinFSR) {
    pythia.readString("TimeShower:QCDshower = off");
    pythia.readString("TimeShower:QEDshowerByQ = off");
    pythia.readString("TimeShower:QEDshowerByL = off");
    pythia.readString("TimeShower:QEDshowerByGamma = off");
  }

  // Restrict output.
  pythia.readString("Next:numberShowInfo = 0");

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

  // Book histograms.
  Hist nGluonv( "number of HV gluons",  100, -0.5, 99.5);
  Hist nGammav( "number of HV gammas",  100, -0.5, 99.5);
  Hist nHadronv("number of HV hadrons", 100, -0.5, 99.5);

   // Begin event loop. Generate event. Extra HV colour output.
  for (int iEvent = 0; iEvent < nEvent; ++iEvent) {
    if (!pythia.next()) continue;
    if (iEvent == 0 && (pythia.process.hasHVcols() || event.hasHVcols())) {
      pythia.process.listHVcols();
      event.listHVcols();
    }

    // Number of "final" gv, gammav and hadronv in current event.
    int nGluonvNow  = 0;
    int nGammavNow  = 0;
    int nHadronvNow = 0;
    for (int i = 0; i < event.size(); ++i) {
      int idNow = event[i].idAbs();
      int idDau = event[ event[i].daughter1() ].idAbs();
      if      (idNow == 4900021 && idDau != 4900021) ++nGluonvNow;
      else if (idNow == 4900022 && idDau != 4900022) ++nGammavNow;
      else if (idNow >  4900110) ++nHadronvNow;
    }
    nGluonv.fill( nGluonvNow);
    nGammav.fill( nGammavNow);
    nHadronv.fill( nHadronvNow);

  // End of event loop. Print statistics and histograms.
  }
  pythia.stat();
  cout << nGluonv << nGammav << nHadronv;

  // Done.
  return 0;
}