Main-Program Settings

Introduction

The main program is up to the user to write. However, sample main programs are provided. In one such class of programs, key settings of the run are read in from a "cards file". These commands may be of two types
(a) instructions directly to Pythia, like which processes to generate, and
(b) instructions to the main program for what it should do, like how many events to generate, i.e. how many times pythia.next() should be called.
In principle these two kinds could be kept completely separate. However, to make life simpler, a number of useful main-program settings are defined on this page, so that they are recognized by the Settings machinery. They can thus be put among the other cards without distinction. It is up to you to decide which ones, if any, you actually want to use when you write your main program. For convenience, some in the second section below can also be interpreted directly by Pythia, while the subsequent ones really have to be used in your main program.

Once you have used the pythia.readFile(fileName) method to read in the cards file, you can interrogate the Settings database to make the values available in your main program. A slight complication is that you need to use a different Settings method for each of the four possible return types that you want to extract. To save some typing the same method names are found directly in the Pythia class, and just send on to the Settings ones to do the job, e.g.

  bool   showCS = pythia.flag("Main:showChangedSettings");
  int    nEvent = pythia.mode("Main:numberOfEvents");
  double spare1 = pythia.parm("Main:spareParm1");
  string file   = pythia.word("Main:allSettingsFile"); 

Run settings

Here settings related to how many events to generate and whether to print some information on data used in run. These variables can be set in an input "cards" file, and thereafter read out an used in the user-written main program. Usage is purely optional, but may help you reduce the need to recompile your main program.

mode  Main:numberOfEvents   (default = 1000; minimum = 0)
The number of events to be generated.

mode  Main:numberToList   (default = 2; minimum = 0)
The number of events to list.

mode  Main:timesToShow   (default = 50; minimum = 0)
Print the number of events generated so far, this many times, i.e. once every numberOfEvents/numberToShow events.

mode  Main:timesAllowErrors   (default = 10)
Allow this many times that pythia.next() returns false, i.e. that an event is flawed, before aborting the run.

flag  Main:showChangedSettings   (default = on)
Print a list of the changed flag/mode/parameter/word settings.

flag  Main:showAllSettings   (default = off)
Print a list of all flag/mode/parameter/word settings. Warning: this will be a long list.

mode  Main:showOneParticleData   (default = 0; minimum = 0)
Print particle and decay data for the particle with this particular identity code. Default means that no particle is printed.

flag  Main:showChangedParticleData   (default = off)
Print a list of particle and decay data for those particles that were changed (one way or another).

flag  Main:showChangedResonanceData   (default = off)
In the previous listing also include the resonances that are initialized at the beginning of a run and thus get new particle data, even if these may well agree with the default ones. Warning: this will be a rather long list.

flag  Main:showAllParticleData   (default = off)
Print a list of all particle and decay data. Warning: this will be a long list.

flag  Main:writeChangedSettings   (default = off)
Write a file with the changed flag/mode/parameter/word settings, in a format appropriate to be read in at the beginning of a new run, using the pythia.readFile(fileName) method.

word  Main:changedSettingsFile   (default = currentSettings.cmnd)
The name of the file to which the changed flag/mode/parameter/word settings are written if Main:writeChangedSettings is on.

flag  Main:writeAllSettings   (default = off)
Write a file with all flag/mode/parameter/word settings, in a format appropriate to be read in at the beginning of a new run, using the pythia.readFile(fileName) method.

word  Main:allSettingsFile   (default = allSettings.cmnd)
The name of the file to which a flag/mode/parameter/word settings are written if Main:writeAllSettings is on.

flag  Main:showAllStatistics   (default = off)
Print all available statistics or only the minimal set at the end of the run.

Subruns

You can use subruns to carry out several tasks in the same run. In that case you will need repeated instances of the first setting below in your command file, and could additionally use the second and third as well.

mode  Main:subrun   (default = -999; minimum = 0)
The number of the current subrun, a non-negative integer, put as first line in a section of lines to be read for this particular subrun.

flag  Main:LHEFskipInit   (default = off)
If you read several Les Houches Event Files that you want to see considered as one single combined event sample you can set this flag on after the first subrun to skip (most of) the (re-)initialization step.

mode  Main:numberOfSubruns   (default = 0)
The number of subruns you intend to use in your current run. Unlike the two settings above, Pythia itself will not intepret this number, but you could e.g. have a loop in your main program to loop over subruns from 0 through numberOfSubruns - 1.

Spares

For currently unforeseen purposes, a few dummy settings are made available here. The user can set the desired value in a "cards file" and then use that value in the main program as desired.

flag  Main:spareFlag1   (default = off)

flag  Main:spareFlag2   (default = off)

flag  Main:spareFlag3   (default = off)

mode  Main:spareMode1   (default = 0)

mode  Main:spareMode2   (default = 0)

mode  Main:spareMode3   (default = 0)

parm  Main:spareParm1   (default = 0.)

parm  Main:spareParm2   (default = 0.)

parm  Main:spareParm3   (default = 0.)

word  Main:spareWord1   (default = void)

word  Main:spareWord2   (default = void)

word  Main:spareWord3   (default = void)