// GammaKinematics.h is a part of the PYTHIA event generator. // Copyright (C) 2017 Torbjorn Sjostrand. // PYTHIA is licenced under the GNU GPL version 2, see COPYING for details. // Please respect the MCnet Guidelines, see GUIDELINES for details. // Header file for kinematics selection of photons from lepton beams. #ifndef Pythia8_GammaKinematics_H #define Pythia8_GammaKinematics_H #include "Pythia8/Basics.h" #include "Pythia8/BeamParticle.h" #include "Pythia8/Info.h" #include "Pythia8/Settings.h" namespace Pythia8 { //========================================================================== // Class to sample the virtuality and transverse momentum of emitted photons. class GammaKinematics { public: // Constructor. GammaKinematics() {} // Sample the trial or final event kinematics. bool init(Info* infoPtrIn, Settings* settingsPtrIn, Rndm* rndmPtrIn, BeamParticle* beamAPtrIn, BeamParticle* beamBPtrIn); bool sampleKTgamma(); bool sampleKin(double xGamma, double m2beam, double eCM2); bool finalize(); // Calculate and return rescaled sHat according to the process. double calcNewSHat( double sHatOld); // Methods to pass along the sampled values. double getQ2gamma1() const {return Q2gamma1;} double getQ2gamma2() const {return Q2gamma2;} double getQ2min1() const {return Q2min1;} double getQ2min2() const {return Q2min2;} double getPhi1() const {return phi1;} double getPhi2() const {return phi2;} double getKT1() const {return kT1;} double getKT2() const {return kT2;} double eCMsub() const {return mGmGm;} private: // Pointer to various information on the generation. Info* infoPtr; // Pointer to the settings database. Settings* settingsPtr; // Pointer to the random number generator. Rndm* rndmPtr; // Pointers to incoming beams. BeamParticle* beamAPtr; BeamParticle* beamBPtr; // Kinematics variables. double Q2maxGamma, Wmin, Wmax, eCM, sCM, m2BeamA, m2BeamB, Q2min1, Q2min2, xGamma1, xGamma2, Q2gamma1, Q2gamma2, phi1, phi2, kT1, kT2, kz1, kz2, mGmGm, m2GmGm, theta1, theta2, theta1Max, theta2Max, eCM2A, eCM2B, sHatNew, Q2min, Q2gamma, kT, kz, phi, theta; // Direct or resolved processes. int gammaMode; // Sample one or two photon kinematics. bool sample1Gamma, sample2Gamma, sideGammaA; }; //========================================================================== } // end namespace Pythia8 #endif // Pythia8_GammaKinematics_H