main342

Back to index.

// main342.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:
//            Christine O Rasmussen

// Keywords:
//            Diffraction
//            DIS
//            Photoproduction
//            Jets
//            Hard diffraction

// The y, pT, x_Pomeron and t distributions for forward Z bosons at HERA,
// within the hard diffraction framework for an inclusive event sample.
// Tests the impact of successive requirements.

#include "Pythia8/Pythia.h"

using namespace Pythia8;

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

int main() {

  // Create Pythia instance. Shorthand for event and info.
  Pythia pythia;
  const Info& info = pythia.info;

  // Set it up to generate dijets at HERA.
  pythia.readString("Beams:frametype = 2");    // Beams with different energies
  pythia.readString("Beams:idA = 2212");       // p+ at 920 GeV
  pythia.readString("Beams:eA = 920");
  pythia.readString("Beams:idB = -11");        // e+ at 27.5 GeV
  pythia.readString("Beams:eB = 27.5");
  pythia.readString("PDF:lepton2gamma = on");  // Allow for photon-from lepton
  pythia.readString("Photon:ProcessType = 0"); // Allow all photon processes
  pythia.readString("Photon:Q2max = 1.");      // Maximal Q2
  pythia.readString("HardQCD:all = on");       // All dijet MEs
  pythia.readString("PhotonParton:all = on");  // All dijet MEs with photons
  pythia.readString("PhaseSpace:pThatMin = 4.");            // Minimal pT cut
  pythia.readString("MultipartonInteractions:pT0Ref = 3."); // Tuned ep value

  // Setup of diffractive framework.
  pythia.readString("Diffraction:doHard = on");
  pythia.readString("Diffraction:sampleType = 1");   // 'PDF' sample
  pythia.readString("Diffraction:hardDiffSide = 2"); // Diff. on photon side
  pythia.readString("SigmaDiffractive:PomFlux = 7"); // H1 Fit B LO
  pythia.readString("PDF:PomSet = 6");               // H1 Fit B LO

  // Simplify printout.
  pythia.readString("Init:showChangedSettings = off");
  pythia.readString("Init:showChangedParticleData = off");
  pythia.readString("Init:showMultipartonInteractions = off");
  pythia.readString("Next:numberShowInfo = 0");
  pythia.readString("Next:numberShowProcess = 0");
  pythia.readString("Next:numberShowEvent = 0");
  pythia.readString("Next:showScaleAndVertex = off");

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

  // Collect information on the number of diffractive events
  int maxEvent      = 10000;
  int nListJets     = 5;
  int nDiffA        = 0;
  int nDiffB        = 0;
  int nReducedDiffA = 0;
  int nReducedDiffB = 0;

  // Histograms.
  Hist nJets0("number of jets, inclusive",            50, -0.5,   9.5);
  Hist nJets1("number of jets, after PDF selection",  50, -0.5,   9.5);
  Hist nJets2("number of jets, after MPI selection",  50, -0.5,   9.5);
  Hist eTjets0("pT for jets, inclusive",             100,  0.0,  50.0);
  Hist eTjets1("pT for jets, after PDF selection",   100,  0.0,  50.0);
  Hist eTjets2("pT for jets, after MPI selection",   100,  0.0,  50.0);
  Hist etaJets0("y for jets, inclusive",             100, -5.0,   5.0);
  Hist etaJets1("y for jets, after PDF selection",   100, -5.0,   5.0);
  Hist etaJets2("y for jets, after MPI selection",   100, -5.0,   5.0);
  Hist phiJets0("phi for jets, inclusive",           100, -M_PI, M_PI);
  Hist phiJets1("phi for jets, after PDF selection", 100, -M_PI, M_PI);
  Hist phiJets2("phi for jets, after MPI selection", 100, -M_PI, M_PI);
  Hist xP1("dN/dxPom after PDF selection",           100,  0.0,   1.0);
  Hist xP2("dN/dxPom after MPI selection",           100,  0.0,   1.0);
  Hist tP1("dN/dt after PDF selection",              100, -2.0,   0.0);
  Hist tP2("dN/dt after MPI selection",              100, -2.0,   0.0);

  // Parameters for the jet finder.
  double etaMax   = 4.;
  double radius   = 1.0;
  double pTjetMin = 3.;
  int    nSel     = 2; // Exclude neutrinos from study.

  // Set up SlowJet jet finder, with C/A clustering
  // and pion mass assumed for non-photons..
  SlowJet slowJet( 0, radius, pTjetMin, etaMax, nSel, 1);

  // Begin event loop. Generate event; skip if generation failed.
  for (int iEvent = 0; iEvent < maxEvent; ++iEvent) {
    if (!pythia.next()) continue;

    // Analyze Slowet jet properties. List first few.
    slowJet. analyze( pythia.event );
    if (iEvent < nListJets) slowJet.list();

    // Fill SlowJet inclusive jet distributions.
    nJets0.fill( slowJet.sizeJet() );
    for (int i = 0; i < slowJet.sizeJet(); ++i) {
      eTjets0.fill( slowJet.pT(i) );
      etaJets0.fill( slowJet.y(i) );
      phiJets0.fill( slowJet.phi(i) );
    }

    // Find diffractive events. Histogram y and pT.
    if ( info.isHardDiffractiveA() == 1 || info.isHardDiffractiveB() == 1) {
      nJets1.fill( slowJet.sizeJet() );
      for (int i = 1; i < slowJet.sizeJet(); ++i) {
        eTjets1.fill( slowJet.pT(i) );
        etaJets1.fill( slowJet.y(i) );
        phiJets1.fill( slowJet.phi(i) );
      }
      if (info.nMPI() == 1) {
        nJets2.fill( slowJet.sizeJet() );
        for (int i = 2; i < slowJet.sizeJet(); ++i) {
          eTjets2.fill( slowJet.pT(i) );
          etaJets2.fill( slowJet.y(i) );
          phiJets2.fill( slowJet.phi(i) );
        }
      }

      // Statistics and histogram on x_Pomeron and t.
      if ( info.isHardDiffractiveA() == 1) {
        ++nDiffA;
        xP1.fill( info.xPomeronB() );
        tP1.fill( info.tPomeronB() );
        if (info.nMPI() == 1) {
          ++nReducedDiffA;
          xP2.fill( info.xPomeronB() );
          tP2.fill( info.tPomeronB() );
        }
      }
      else if ( info.isHardDiffractiveB() == 1) {
        ++nDiffB;
        xP1.fill( info.xPomeronA() );
        tP1.fill( info.tPomeronA() );
        if (info.nMPI() == 1) {
          ++nReducedDiffB;
          xP2.fill( info.xPomeronA() );
          tP2.fill( info.tPomeronA() );
        }
      }
    }

  // End of event loop. Statistics on event generation.
  }
  pythia.stat();

  // Statistics on diffraction.
  cout << "Side A is MPI-unchecked diffractive : " << nDiffA << endl;
  cout << "Side A is MPI-checked diffractive   : " << nReducedDiffA << endl;
  cout << "Side B is MPI-unchecked diffractive : " << nDiffB << endl;
  cout << "Side B is MPI-checked diffractive   : " << nReducedDiffB << endl;
  cout << "Total MPI-unchecked diffractive events : " << fixed
       << setprecision(2) << (nDiffA + nDiffB) / double(maxEvent) * 100.
       << "%" << endl;
  cout << "Total MPI-checked diffractive events : "
       << (nReducedDiffA + nReducedDiffB) / double(maxEvent) * 100.
       << "%" << endl;

  // Histograms.
  cout << xP1 << xP2 << tP1 << tP2
       << nJets0 << nJets1 << nJets2 << eTjets0 << eTjets1 << eTjets2
       << etaJets0 << etaJets1 << etaJets2 << phiJets0 << phiJets1 << phiJets2;

  return 0;
}