PYTHIA  8.313
Classes | Public Member Functions | List of all members
MiniStringFragmentation Class Reference

#include <MiniStringFragmentation.h>

Inheritance diagram for MiniStringFragmentation:
FragmentationModel PhysicsBase

Public Member Functions

 MiniStringFragmentation ()
 Constructor.
 
bool init (StringFlav *flavSelPtrIn=nullptr, StringPT *pTSelPtrIn=nullptr, StringZ *zSelPtrIn=nullptr, FragModPtr fragModPtrIn=nullptr) override
 Initialize and save pointers. More...
 
bool fragment (int iSub, ColConfig &colConfig, Event &event, bool isDiff=false, bool systemRecoil=true) override
 Do the fragmentation: driver routine. More...
 
- Public Member Functions inherited from FragmentationModel
 FragmentationModel ()=default
 Empty constructor.
 
virtual ~FragmentationModel ()
 Empty virtual destructor.
 
- Public Member Functions inherited from PhysicsBase
void initInfoPtr (Info &infoPtrIn)
 This function is called from above for physics objects used in a run. More...
 
virtual ~PhysicsBase ()
 Empty virtual destructor.
 
bool flag (string key) const
 Shorthand to read settings values.
 
int mode (string key) const
 
double parm (string key) const
 
string word (string key) const
 
vector< bool > fvec (string key) const
 
vector< int > mvec (string key) const
 
vector< double > pvec (string key) const
 
vector< string > wvec (string key) const
 

Additional Inherited Members

- Public Types inherited from PhysicsBase
enum  Status {
  INCOMPLETE = -1, COMPLETE = 0, CONSTRUCTOR_FAILED, INIT_FAILED,
  LHEF_END, LOWENERGY_FAILED, PROCESSLEVEL_FAILED, PROCESSLEVEL_USERVETO,
  MERGING_FAILED, PARTONLEVEL_FAILED, PARTONLEVEL_USERVETO, HADRONLEVEL_FAILED,
  CHECK_FAILED, OTHER_UNPHYSICAL, HEAVYION_FAILED, HADRONLEVEL_USERVETO
}
 Enumerate the different status codes the event generation can have.
 
- Protected Member Functions inherited from PhysicsBase
 PhysicsBase ()
 Default constructor.
 
virtual void onInitInfoPtr ()
 
virtual void onBeginEvent ()
 This function is called in the very beginning of each Pythia::next call.
 
virtual void onEndEvent (Status)
 
virtual void onStat ()
 This function is called from the Pythia::stat() call.
 
void registerSubObject (PhysicsBase &pb)
 Register a sub object that should have its information in sync with this.
 
- Protected Attributes inherited from FragmentationModel
StringFlavflavSelPtr {}
 Pointers to classes for flavour, pT and z generation.
 
StringPTpTSelPtr {}
 
StringZzSelPtr {}
 
- Protected Attributes inherited from PhysicsBase
InfoinfoPtr = {}
 
SettingssettingsPtr = {}
 Pointer to the settings database.
 
ParticleDataparticleDataPtr = {}
 Pointer to the particle data table.
 
LoggerloggerPtr = {}
 Pointer to logger.
 
HadronWidthshadronWidthsPtr = {}
 Pointer to the hadron widths data table.
 
RndmrndmPtr = {}
 Pointer to the random number generator.
 
CoupSMcoupSMPtr = {}
 Pointers to SM and SUSY couplings.
 
CoupSUSYcoupSUSYPtr = {}
 
BeamSetupbeamSetupPtr = {}
 
BeamParticlebeamAPtr = {}
 
BeamParticlebeamBPtr = {}
 
BeamParticlebeamPomAPtr = {}
 
BeamParticlebeamPomBPtr = {}
 
BeamParticlebeamGamAPtr = {}
 
BeamParticlebeamGamBPtr = {}
 
BeamParticlebeamVMDAPtr = {}
 
BeamParticlebeamVMDBPtr = {}
 
PartonSystemspartonSystemsPtr = {}
 Pointer to information on subcollision parton locations.
 
SigmaTotalsigmaTotPtr = {}
 Pointers to the total/elastic/diffractive cross sections.
 
SigmaCombinedsigmaCmbPtr = {}
 
set< PhysicsBase * > subObjects
 
UserHooksPtr userHooksPtr
 

Detailed Description

The MiniStringFragmentation class contains the routines to fragment occasional low-mass colour singlet partonic systems, where the string approach is not directly applicable (for technical reasons).

Member Function Documentation

bool fragment ( int  iSub,
ColConfig colConfig,
Event event,
bool  isDiff = false,
bool  systemRecoil = true 
)
overridevirtual

Do the fragmentation: driver routine.

Check for junction topologies

First check if iParton is a junction system.

If so, then save some information and reduce the junction to a simple junction by absorbing any gluon momenta into the (di)quarks.

Then save some more information.

If all the ends are quarks, simply join two of them into a diquark and continue with the normal ministring machinery.

If a diquark is involved we need to create two hadrons.

Read in info on system to be treated.

Do not want diffractive systems to easily collapse to one particle.

First try to produce two hadrons from the system.

If this fails, then form one hadron and shuffle momentum.

If also this fails, try to produce two hadrons with lower mass.

If also this fails, try to form a hadron with lower mass.

For low-energy systems may also search for a single hadron recoiler.

Else complete failure.

Implements FragmentationModel.

bool init ( StringFlav flavSelPtrIn = nullptr,
StringPT pTSelPtrIn = nullptr,
StringZ zSelPtrIn = nullptr,
FragModPtr  fragModPtrIn = nullptr 
)
overridevirtual

Initialize and save pointers.

Save pointers.

Calculation and definition of hadron space-time production vertices.

Charm and bottom quark masses used for space-time offset.

Initialize the MiniStringFragmentation class proper.

Initialize the b parameter of the z spectrum, used when joining jets.

Return.

Implements FragmentationModel.


The documentation for this class was generated from the following files: