Multiparton Interactions

  1. Main variables
  2. Initialization speed-up
  3. Further variables
  4. Technical notes
The starting point for the multiparton interactions physics scenario in PYTHIA is provided by [Sjo87]. Recent developments have included a more careful study of flavour and colour correlations, junction topologies and the relationship to beam remnants [Sjo04], interleaving with initial-state radiation [Sjo05], making use of transverse-momentum-ordered initial- and final-state showers, with the extension to fully interleaved evolution covered in [Cor10a]. A framework to handle rescattering is described in [Cor09].

A big unsolved issue is how the colour of all these subsystems is correlated. For sure there is a correlation coming from the colour singlet nature of the incoming beams, but in addition final-state colour rearrangements may change the picture. Indeed such extra effects appear necessary to describe data, e.g. on <pT>(n_ch). A simple implementation of colour rearrangement is found as part of the beam remnants description.

Main variables

Matching to hard process

The maximum pT to be allowed for multiparton interactions is related to the nature of the hard process itself. It involves a delicate balance between not double-counting and not leaving any gaps in the coverage. The best procedure may depend on information only the user has: how the events were generated and mixed (e.g. with Les Houches Accord external input), and how they are intended to be used. Therefore a few options are available, with a sensible default behaviour.

mode  MultipartonInteractions:pTmaxMatch   (default = 0; minimum = 0; maximum = 3)
Way in which the maximum scale for multiparton interactions is set to match the scale of the hard process itself.
option 0 : (i) if the final state of the hard process (not counting subsequent resonance decays) contains only quarks (u, d, s, c, b), gluons and photons then pT_max is chosen to be the factorization scale for internal processes and the scale value for Les Houches input; (ii) if not, interactions are allowed to go all the way up to the kinematical limit. The reasoning is that the former kind of processes are generated by the multiparton-interactions machinery and so would double-count hard processes if allowed to overlap the same pT range, while no such danger exists in the latter case.
option 1 : always use the factorization scale for an internal process and the scale value for Les Houches input, i.e. the lower value. This should avoid double-counting, but may leave out some interactions that ought to have been simulated.
option 2 : always allow multiparton interactions up to the kinematical limit. This will simulate all possible event topologies, but may lead to double-counting.
option 3 : as option 0, but for case (i) the pT_max is chosen to be half the summed pT of the final-state particles. This may be more relevant than option 0 for multiparton final states, where the factorization scale could be associated with the lowest pT of any parton, as appropriate for parton showers, but not for MPI. The scale for no doublecounting and no gaps should rather be associated with the "core" 2 → 2 hard process, which here is approximated by sum pT / 2.
Note: If a "second hard" process is present, the two are analyzed separately for the default 0 option, and for 3. It is enough that one of them only consists of quarks, gluons and photons to restrict the pT range. The maximum for MPI is then set by the hard interaction with lowest scale.

Cross-section parameters

The rate of interactions is determined by

parm  MultipartonInteractions:alphaSvalue   (default = 0.130; minimum = 0.06; maximum = 0.25)
The value of alpha_strong at m_Z. Default value is picked equal to the one used in CTEQ 5L.

The actual value is then regulated by the running to the scale pT^2, at which it is evaluated

mode  MultipartonInteractions:alphaSorder   (default = 1; minimum = 0; maximum = 3)
The order at which alpha_strong runs at scales away from m_Z.
option 0 : zeroth order, i.e. alpha_strong is kept fixed.
option 1 : first order, which is the normal value.
option 2 : second order. Since other parts of the code do not go to second order there is no strong reason to use this option, but there is also nothing wrong with it.
option 3 : third order, with the same comment as for second order. The expression in the 2006 RPP is used here.

QED interactions are regulated by the alpha_electromagnetic value at the pT^2 scale of an interaction.

mode  MultipartonInteractions:alphaEMorder   (default = 1; minimum = -1; maximum = 1)
The running of alpha_em used in hard processes.
option 1 : first-order running, constrained to agree with StandardModel:alphaEMmZ at the Z^0 mass.
option 0 : zeroth order, i.e. alpha_em is kept fixed at its value at vanishing momentum transfer.
option -1 : zeroth order, i.e. alpha_em is kept fixed, but at StandardModel:alphaEMmZ, i.e. its value at the Z^0 mass.

Note that the choices of alpha_strong and alpha_em made here override the ones implemented in the normal process machinery, but only for the interactions generated by the MultipartonInteractions class.

In addition there is the possibility of a global rescaling of cross sections (which could not easily be accommodated by a changed alpha_strong, since alpha_strong runs)

parm  MultipartonInteractions:Kfactor   (default = 1.0; minimum = 0.5; maximum = 4.0)
Multiply all cross sections by this fix factor.

The processes used to generate multiparton interactions form a subset of the standard library of hard processes. The input is slightly different from the standard hard-process machinery, however, since incoming flavours, the alpha_strong value and most of the kinematics are already fixed when the process is called. It is possible to regulate the set of processes that are included in the multiparton-interactions framework.

mode  MultipartonInteractions:processLevel   (default = 3; minimum = 0; maximum = 3)
Set of processes included in the machinery.
option 0 : only the simplest 2 → 2 QCD processes between quarks and gluons, giving no new flavours, i.e. dominated by t-channel gluon exchange.
option 1 : also 2 → 2 QCD processes giving new flavours (including charm and bottom), i.e. proceeding through s-channel gluon exchange.
option 2 : also 2 → 2 processes involving one or two photons in the final state, s-channel gamma boson exchange and t-channel gamma/Z^0/W^+- boson exchange.
option 3 : also charmonium and bottomonium production, via colour singlet and colour octet channels.

Cross-section regularization

There are two complementary ways of regularizing the small-pT divergence, a sharp cutoff and a smooth dampening. These can be combined as desired, but it makes sense to coordinate with how the same issue is handled in spacelike showers. Actually, by default, the parameters defined here are used also for the spacelike showers, but this can be overridden.

Regularization of the divergence of the QCD cross section for pT → 0 is obtained by a factor pT^4 / (pT0^2 + pT^2)^2, and by using an alpha_s(pT0^2 + pT^2). An energy dependence of the pT0 choice is introduced by two further parameters, so that pT0Ref is the pT0 value for the reference CM energy, pT0Ref = pT0(ecmRef).
Warning: if a large pT0 is picked for multiparton interactions, such that the integrated interaction cross section is below the nondiffractive inelastic one, this pT0 will automatically be scaled down to cope.

The actual pT0 parameter used at a given CM energy scale, ecmNow, is obtained from a power law or a logarithmic parametrization. The former is default with hadron beams and the latter for photon-photon collisions.

mode  MultipartonInteractions:pT0parametrization   (default = 0; minimum = 0; maximum = 1)
Choice of pT0 parametrization.
option 0 : Power law dependence on ecmNow:
pT0 = pT0(ecmNow) = pT0Ref * (ecmNow / ecmRef)^ecmPow
option 1 : Logarithmic dependence on ecmNow:
pT0 = pT0(ecmNow) = pT0Ref + ecmPow * log (ecmNow / ecmRef)
where pT0Ref, ecmRef and ecmPow are the three parameters below. In case of photon-photon collisions the corresponding parameters are set in Photoproduction.

parm  MultipartonInteractions:pT0Ref   (default = 2.28; minimum = 0.5; maximum = 10.0)
The pT0Ref scale in the above formula.
Note: pT0Ref is one of the key parameters in a complete PYTHIA tune. Its value is intimately tied to a number of other choices, such as that of colour flow description, so unfortunately it is difficult to give an independent meaning to pT0Ref.

parm  MultipartonInteractions:ecmRef   (default = 7000.0; minimum = 1.)
The ecmRef reference energy scale introduced above.

parm  MultipartonInteractions:ecmPow   (default = 0.215; minimum = 0.0; maximum = 0.5)
The ecmPow energy rescaling pace introduced above.

Alternatively, or in combination, a sharp cut can be used.

parm  MultipartonInteractions:pTmin   (default = 0.2; minimum = 0.1; maximum = 10.0)
Lower cutoff in pT, below which no further interactions are allowed. Normally pT0 above would be used to provide the main regularization of the cross section for pT → 0, in which case pTmin is used mainly for technical reasons. It is possible, however, to set pT0Ref = 0 and use pTmin to provide a step-function regularization, or to combine them in intermediate approaches. Currently pTmin is taken to be energy-independent.

Gösta Gustafson has proposed (private communication, unpublished) that the amount of screening, as encapsulated in the pT0 parameter, fluctuates from one event to the next. Specifically, high-activity event are more likely to lead to interactions at large pT scales, but the high activity simultaneously leads to a larger screening of interactions at smaller pT. Such a scenario can approximately be simulated by scaling up the pT0 by a factor sqrt(n), where n is the number of interactions considered so far, including the current one. That is, for the first interaction the dampening factor is pT^4 / (pT0^2 + pT^2)^2, for the second pT^4 / (2 pT0^2 + pT^2)^2, for the third pT^4 / (3 pT0^2 + pT^2)^2, and so on. Optionally the scheme may also be applied to ISR emissions. For simplicity the same alpha_s(pT0^2 + pT^2) is used throughout. Note that, in this scenario the pT0 scale must be lower than in the normal case to begin with, since it later is increased back up. Also note that the idea with this scenario is to propose an alternative to colour reconnection to understand the rise of <pT>(n_ch), so that the amount of colour reconnection should be reduced.

mode  MultipartonInteractions:enhanceScreening   (default = 0; minimum = 0; maximum = 2)
Choice to activate the above screening scenario, i.e. an increasing effective pT0 for consecutive interactions.
option 0 : No activity-dependent screening, i.e. pT0 is fixed.
option 1 : The pT0 scale is increased as a function of the number of MPI's, as explained above. ISR is not affected, but note that, if SpaceShower:samePTasMPI is on, then MultipartonInteractions:pT0Ref is used also for ISR, which may or may not be desirable.
option 2 : Both MPI and ISR influence and are influenced by the screening. That is, the dampening is reduced based on the total number of MPI and ISR steps considered so far, including the current one. This dampening is implemented both for MPI and for ISR emissions, for the latter provided that SpaceShower:samePTasMPI is on (default).

Impact-parameter dependence

The choice of impact-parameter dependence is regulated by several parameters. The ones listed here refer to nondiffractive topologies only, while their equivalents for diffractive events are put in the Diffraction description. Note that there is currently no bProfile = 4 option for diffraction. Other parameters are assumed to agree between diffractive and nondiffractive topologies.

mode  MultipartonInteractions:bProfile   (default = 3; minimum = 0; maximum = 4)
Choice of impact parameter profile for the incoming hadron beams.
option 0 : no impact parameter dependence at all.
option 1 : a simple Gaussian matter distribution; no free parameters.
option 2 : a double Gaussian matter distribution, with the two free parameters coreRadius and coreFraction.
option 3 : an overlap function (i.e. the convolution of the matter distributions of the two incoming hadrons) of the form exp(- b^expPow), where expPow is a free parameter.
option 4 : a Gaussian matter distribution with a width that varies according to the selected x value of an interaction, 1. + a1 log (1 / x), where a1 is a free parameter. Note that once b has been selected for the hard process, it remains fixed for the remainder of the evolution. Also note that the machinery for a second hard process is not adapted to calculate the impact-parameter enhancement factor for this option.

parm  MultipartonInteractions:coreRadius   (default = 0.4; minimum = 0.1; maximum = 1.)
When assuming a double Gaussian matter profile, bProfile = 2, the inner core is assumed to have a radius that is a factor coreRadius smaller than the rest.

parm  MultipartonInteractions:coreFraction   (default = 0.5; minimum = 0.; maximum = 1.)
When assuming a double Gaussian matter profile, bProfile = 2, the inner core is assumed to have a fraction coreFraction of the matter content of the hadron.

parm  MultipartonInteractions:expPow   (default = 1.85; minimum = 0.4; maximum = 10.)
When bProfile = 3 it gives the power of the assumed overlap shape exp(- b^expPow). Since the convolution of two Gaussians is another Gaussian, the overlap shape obtained for expPow = 2 is the same as that obtained for a Gaussian matter distribution, bProfile = 1. The limit expPow → infinity corresponds to no impact parameter dependence at all, bProfile = 0. The overlap shape that would be obtained for an exponential matter distribution cannot be represented exactly on this form, but a similar variance (for fixed normalisation and average b) is obtained for expPow = 1.4. The double Gaussian matter profiles that are obtained for bProfile = 2 generally correspond to the range between expPow = 1 and expPow = 2, with the former representing scenarios with pronounced "hot spots" and consequently very significant fluctuations (high variance). Note that for small expPow the program becomes slow and unstable, so the min limit must be respected.

parm  MultipartonInteractions:a1   (default = 0.15; minimum = 0.; maximum = 2.)
When bProfile = 4, this gives the a1 constant in the Gaussian width. When a1 = 0., this reduces back to the single Gaussian case.

mode  MultipartonInteractions:bSelScale   (default = 1; minimum = 1; maximum = 3)
The selection of impact parameter is related to the scale of the hard process: the harder this scale is, the more central the collision. In practice this centrality saturates quickly, however, and beyond a scale of roughly 20 GeV very little changes. (The relevant quantity is that the QCD jet cross section above the scale should be a tiny fraction of the total cross section.) In 2 → 1 and 2 → 2 processes traditional scale choices work fine, but ambiguities arise for higher multiplicities, in particular when the scale is used for matching between the multiparton matrix elements and parton showers. Then the event scale may be chosen as that of a very low-pT parton, i.e. suggesting a peripheral collision, while the much harder other partons instead would favour a central collision. Therefore the default here is to override whatever scale value have been read in from an LHEF, say. Notice that the scale used here is decoupled from the maximum scale for MPIs (MultipartonInteractions:pTmaxMatch).
option 1 : Use the mass for a 2 → 1 process. For 2 → n, n > 1 processes order the particles in falling mmT = m + mT and then let the scale be (mmT_1 + mmT_2)/2 + mmT_3/3 + mmT_4/4 + ... + mmT_n/n. This is constructed always to be above m1, and to assign decreasing importance to softer particles that are less likely to be associated with the hard process.
option 2 : Use the scale parameter of the event.
option 3 : use the same scale as chosen by the rules for MultipartonInteractions:pTmaxMatch.

Rescattering

It is possible that a parton may rescatter, i.e. undergo a further interaction subsequent to the first one. The machinery to model this kind of physics has only recently become fully operational [Cor09], and is therefore not yet so well explored.

The rescattering framework has ties with other parts of the program, notably with the beam remnants.

flag  MultipartonInteractions:allowRescatter   (default = off)
Switch to allow rescattering of partons; on/off = true/false.
Note: the rescattering framework has not yet been implemented for the MultipartonInteractions:bProfile = 4 option, and can therefore not be switched on in that case. Warning: use with caution since machinery is still not so well tested.

flag  MultipartonInteractions:allowDoubleRescatter   (default = off)
Switch to allow rescattering of partons, where both incoming partons have already rescattered; on/off = true/false. Is only used if MultipartonInteractions:allowRescatter is switched on.
Warning: currently there is no complete implementation that combines it with shower evolution, so you must use PartonLevel:ISR = off and PartonLevel:FSR = off. If not, a warning will be issued and double rescattering will not be simulated. The rate also comes out to be much lower than for single rescattering, so to first approximation it can be neglected.

mode  MultipartonInteractions:rescatterMode   (default = 0; minimum = 0; maximum = 4)
Selection of which partons rescatter against unscattered partons from the incoming beams A and B, based on their rapidity value y in the collision rest frame. Here ySep is shorthand for MultipartonInteractions:ySepRescatter and deltaY for MultipartonInteractions:deltaYRescatter, defined below. The description is symmetric between the two beams, so only one case is described below.
option 0 : only scattered partons with y > 0 can collide with unscattered partons from beam B.
option 1 : only scattered partons with y > ySep can collide with unscattered partons from beam B.
option 2 : the probability for a scattered parton to be considered as a potential rescatterer against unscattered partons in beam B increases linearly from zero at y = ySep - deltaY to unity at y = ySep + deltaY.
option 3 : the probability for a scattered parton to be considered as a potential rescatterer against unscattered partons in beam B increases with y according to (1/2) * (1 + tanh( (y - ySep) / deltaY)).
option 4 : all partons are potential rescatterers against both beams.

parm  MultipartonInteractions:ySepRescatter   (default = 0.)
used for some of the MultipartonInteractions:rescatterMode options above, as the rapidity for which a scattered parton has a 50% probability to be considered as a potential rescatterer. A ySep > 0 generally implies that some central partons cannot rescatter at all, while a ySep < 0 instead allows central partons to scatter against either beam.

parm  MultipartonInteractions:deltaYRescatter   (default = 1.; minimum = 0.1)
used for some of the MultipartonInteractions:rescatterMode options above, as the width of the rapidity transition region, where the probability rises from zero to unity that a scattered parton is considered as a potential rescatterer.

Initialization speed-up

The initialization of the MPI framework is the most time-consuming part of the whole initialization step. This is because the jet cross section has to be integrated numerically for the given pT0 choice, and shown to be larger than the total cross section of the relevant event class (nondiffractive or diffractive). If not, the pT0 value has to be reduced. Sudakov factors also need to be tabulated for usage during the generation. If the collision energy is kept fixed and diffraction is not simulated, then the time usage is still hardly noticeable, at or below the order of a second. For diffraction, however, the diffractive masses vary between events, which requires a setup in a grid of masses for subsequent interpolation. This is similar for nondiffractive events, if the collision energy is allowed to vary. In total, this can give up to a hundred process+energy/mass points to consider, requiring tens of seconds. It can become problematic if additionally several different Pythia objects are required to handle many different beam-particle combinations, or if the Beams:allowIDAswitch is used to handle several beam-particle combinations inside a single Pythia object.

It is therefore possible to save the outcome of one initialization step on file, and then read it back in for subsequent runs. This can save a significant time, notably for short test runs. A warning is that all relevant settings must be the same in the two runs. It is up to the user to ensure that this is the case; it would be next-to-impossible to catch any possible conflict. The most obvious aspects that must agree are incoming beam particles and (maximum) collision energy, all MPI-related settings and PDFs. Aspects that could be different without causing problems include ISR and FSR, and all hadronization steps.

This trick also works for the initialization of several particles. Specifically, when the Beams:allowIDAswitch switch is on, some 20 different incoming beam particles are initialized in succession, and all of these can be saved and reused with the methods below. Since we now need a few hundred seconds to initialize all of them, the time savings can be considerable for repeated use.

mode  MultipartonInteractions:reuseInit   (default = 0; minimum = -2; maximum = 3)
Action taken with respect to using MPI initialization data as above.
option 0 : current run is self-contained.
option 1 : MPI initialization is done as usual, but afterwards the results of this initialization are saved on file.
option 2 : initialization data is read in from a file, saved from a previous initialization, thereby saving time. If the file is not found, initialization fails.
option 3 : as option 2, but if the file is not found, it will be generated and saved after normal initialization.
option -1 : Load initialization data from the Init:reuseMpiInit... settings if not empty. In any case write the data to Init:reuseMpiInit....
option -2 : Same as -1 but also read/write the setting from/to the file MultipartonInteractions:initFile.

word  MultipartonInteractions:initFile   (default = pp14000.mpi)
The file name used to store or read MPI initialization data. It is up to the user to pick a suitable name (including path if relevant) for the case at hand.

wvec  Init:reuseMPIiDiffSys0  
This is where the fitted parameters are stored for non-diffractive processes.

wvec  Init:reuseMPIiDiffSys1  
This is where the fitted parameters are stored for single diffractive (XB) processes.

wvec  Init:reuseMPIiDiffSys2  
This is where the fitted parameters are stored for single diffractive (AX) processes.

wvec  Init:reuseMPIiDiffSys3  
This is where the fitted parameters are stored for doubly diffractive (AXB) processes.

Another possible speed-up, in some contexts, is to symmetrize the description between particles and antiparticles, so that e.g. pi^+ p and pi^- p are handled identically in the MPI initialization, and thus could use the same initialization file. This is used for the Beams:allowIDAswitch = on option, to limit the number of options needed to cover, but can also be used in other contexts.

flag  MultipartonInteractions:setAntiSame   (default = off)
The cross sections for particle-particle and particle-antiparticle collisions are symmetrized at initialization. For the perturbative cross section this is achieved by symmetrizing the PDFs of one particle between quarks and antiquarks. For the nonperturbative cross sections this is done by averaging two separate calls. If either of the two particles is its own antiparticle the procedure can be skipped. In the actual event generation the proper PDFs are used for real parton-parton collisions, but combined with the symmetrized Sudakov factor table and nondiffractive cross section.

Further variables

These should normally not be touched. Their only function is for cross-checks.

mode  MultipartonInteractions:nQuarkIn   (default = 5; minimum = 0; maximum = 5)
Number of allowed incoming quark flavours in the beams; a change to 4 would thus exclude b and bbar as incoming partons, etc.

mode  MultipartonInteractions:nSample   (default = 100000; minimum = 100000)
The allowed pT range is split into NSUDPTS bins, by default 50, a number which is hardcoded in MultipartonInteractions.h. In each of these bins the interaction cross section is evaluated in nSample / NSUDPTS random phase space points. The pT bins are of uneven size, to obtain comparable integrated cross section in each bin. The full integral is used at initialization, and the differential one during the run as part of a "Sudakov form factor" for the choice of the hardest interaction. A larger sample number implies increased accuracy of the calculations.

Technical notes

Relative to the articles mentioned above, not much has happened. The main news is a technical one, that the phase space of the 2 → 2 (massless) QCD processes is now sampled in dy_3 dy_4 dpT^2, where y_3 and y_4 are the rapidities of the two produced partons. One can show that
(dx_1 / x_1) * (dx_2 / x_2) * d(tHat) = dy_3 * dy_4 * dpT^2
Furthermore, since cross sections are dominated by the "Rutherford" one of t-channel gluon exchange, which is enhanced by a factor of 9/4 for each incoming gluon, effective structure functions are defined as
F(x, pT2) = (9/4) * xg(x, pT2) + sum_i xq_i(x, pT2)
With this technical shift of factors 9/4 from cross sections to parton densities, a common upper estimate of
d(sigmaHat)/d(pT2) < pi * alpha_strong^2 / pT^4
is obtained.

In fact this estimate can be reduced by a factor of 1/2 for the following reason: for any configuration (y_3, y_4, pT2) also one with (y_4, y_3, pT2) lies in the phase space. Not both of those can enjoy being enhanced by the tHat → 0 singularity of
d(sigmaHat) propto 1/tHat^2.
Or if they are, which is possible with identical partons like q q → q q and g g → g g, each singularity comes with half the strength. So, when integrating/averaging over the two configurations, the estimated d(sigmaHat)/d(pT2) drops. Actually, it drops even further, since the naive estimate above is based on
(4 /9) * (1 + (uHat/sHat)^2) < 8/9 < 1
The 8/9 value would be approached for tHat → 0, which implies sHat >> pT2 and thus a heavy parton-distribution penalty, while parton distributions are largest for tHat = uHat = -sHat/2, where the above expression evaluates to 5/9. A fudge factor is therefore introduced to go the final step, so it can easily be modified when further non-Rutherford processes are added, or should parton distributions change significantly.

At initialization, it is assumed that
d(sigma)/d(pT2) < d(sigmaHat)/d(pT2) * F(x_T, pT2) * F(x_T, pT2) * (2 y_max(pT))^2
where the first factor is the upper estimate as above, the second two the parton density sum evaluated at y_3 = y_ 4 = 0 so that x_1 = x_2 = x_T = 2 pT / E_cm, where the product is expected to be maximal, and the final is the phase space for -y_max < y_{3,4} < y_max. The right-hand side expression is scanned logarithmically in y, and a N is determined such that it always is below N/pT^4.

To describe the dampening of the cross section at pT → 0 by colour screening, the actual cross section is multiplied by a regularization factor (pT^2 / (pT^2 + pT0^2))^2, and the alpha_s is evaluated at a scale pT^2 + pT0^2, where pT0 is a free parameter of the order of 2 - 4 GeV. Since pT0 can be energy-dependent, an ansatz
pT0(ecm) = pT0Ref * (ecm/ecmRef)^ecmPow
is used, where ecm is the current CM frame energy, ecmRef is an arbitrary reference energy where pT0Ref is defined, and ecmPow gives the energy rescaling pace. For technical reasons, also an absolute lower pT scale pTmin, by default 0.2 GeV, is introduced. In principle, it is possible to recover older scenarios with a sharp pT cutoff by setting pT0 = 0 and letting pTmin be a larger number.

The above scanning strategy is then slightly modified: instead of an upper estimate N/pT^4 one of the form N/(pT^2 + r * pT0^2)^2 is used. At first glance, r = 1 would seem to be fixed by the form of the regularization procedure, but this does not take into account the nontrivial dependence on alpha_s, parton distributions and phase space. A better Monte Carlo efficiency is obtained for r somewhat below unity, and currently r = 0.25 is hardcoded. In the generation a trial pT2 is then selected according to
d(Prob)/d(pT2) = (1/sigma_ND) * N/(pT^2 + r * pT0^2)^2 * ("Sudakov")
For the trial pT2, a y_3 and a y_4 are then selected, and incoming flavours according to the respective F(x_i, pT2), and then the cross section is evaluated for this flavour combination. The ratio of trial/upper estimate gives the probability of survival.

Actually, to profit from the factor 1/2 mentioned above, the cross section for the combination with y_3 and y_4 interchanged is also tried, which corresponds to exchanging tHat and uHat, and the average formed, while the final kinematics is given by the relative importance of the two.

Furthermore, since large y values are disfavoured by dropping PDF's, a factor
WT_y = (1 - (y_3/y_max)^2) * (1 - (y_4/y_max)^2)
is evaluated, and used as a survival probability before the more time-consuming PDF+ME evaluation, with surviving events given a compensating weight 1/WT_y.

An impact-parameter dependence is also allowed. Based on the hard pT scale of the first interaction, and enhancement/depletion factor is picked, which multiplies the rate of subsequent interactions.

Parton densities are rescaled and modified to take into account the energy-momentum and flavours kicked out by already-considered interactions.