PYTHIA  8.313
VinciaHistory.h
1 // VinciaHistory.h is a part of the PYTHIA event generator.
2 // Copyright (C) 2025 Torbjorn Sjostrand.
3 // PYTHIA is licenced under the GNU GPL v2 or later, see COPYING for details.
4 // Please respect the MCnet Guidelines, see GUIDELINES for details.
5 
6 // Authors: Helen Brooks, Christian T Preuss
7 // This file contains the VinciaHistory class.
8 
9 #ifndef VINCIA_History_H
10 #define VINCIA_History_H
11 
12 #include "Pythia8/History.h"
13 #include "Pythia8/Info.h"
14 #include "Pythia8/Vincia.h"
15 #include "Pythia8/VinciaAntennaFunctions.h"
16 #include "Pythia8/VinciaMergingHooks.h"
17 
18 namespace Pythia8 {
19 
20 //==========================================================================
21 
22 // Convenient shorthand for storing ordered list of chains.
23 
24 struct PseudoChain {
25  // Ordered list of concatenated chains.
26  vector<int> chainlist;
27  // Index unique up to chain content (not ordering).
28  int index;
29  // Charge Index.
30  int cindex;
31  // Does any of the chains contain an initial state parton.
32  bool hasInitial;
33  // Flavour at start of first and end of last.
34  int flavStart;
35  int flavEnd;
36  // Charge.
37  int charge;
38 };
39 
40 //==========================================================================
41 
42 // A class for associating disconnected colour chains with either
43 // resonances or the hard QCD scattering. Once fixed, the sector
44 // history is deterministic.
45 
46 class ColourFlow {
47 
48  public:
49 
50  // Constructor.
51  ColourFlow() : nChains(0), nBeamChainsMin(0), nBeamChainsMax(0), nRes(0) {
52  for(int i=0; i<4; i++) {countChainsByChargeIndex[i]=0;
53  countResByChargeIndex[i]=0;}}
54 
55  // Methods.
56 
57  // Add or assign chains.
58  void addChain(int charge, int flavStart, int flavEnd, bool hasInitialIn);
59  void selectResChains(int index,int iorder, int id);
60  void selectBeamChains(int index,int iorder);
61 
62  // Initialise from hard process information.
63  bool initHard(map<int, map<int,int> >& countRes,
64  shared_ptr<VinciaMergingHooks> vinMergingHooksPtr);
65 
66  // Get information about current status of (pseudo)chains.
67  bool checkChains(int cIndex);
68  bool checkChains();
69  int getNChainsLeft();
70  int maxLength();
71  int minLength();
72 
73  // Print information about (pseudo)chains.
74  void print(bool printpsch = false);
75 
76  // Members.
77 
78  // Chains that arise from the decay of a resonance.
79  map<int, vector<PseudoChain> > resChains;
80 
81  // Remaining list of ordered chains after resonances stripped off.
82  vector<PseudoChain> beamChains;
83 
84  // Maps to all viable combinations of chains (of each charge)
85  // from an index which depends on the identities of chains in it
86  // - will be empty when resChains and beamChains set.
87  map< int , vector< PseudoChain > > pseudochains;
88 
89  // Easy way to look up all pseudochains which contain a given chain.
90  // Map from chain number to pseudochain index.
91  map<int,vector<int> > chainToIndices;
92 
93  // Map from chain to the flavour at the start or end of that chain.
94  map<int,int> chainStartToFlav;
95  map<int,int> chainEndToFlav;
96  // Keep track of chains which contain an initial state parton.
97  map<int,bool> hasInitial;
98  // Keep track of charge information of chains.
99  map<int,int> chainToCharge;
100 
101  private:
102 
103  // Add or assign chains.
104  void addChain(int oldIndex, int chainsIndex, int iChain,
105  vector<int> & newIndices);
106  void selectPseudochain(vector<int> & psch);
107  void selectChain(int iChain);
108 
109  // Create empty vectors in resChains, and count each type.
110  void addResonances(vector<int>& idsIn, map<int, map<int,int> >& idCounter,
111  int charge, bool fc);
112 
113  // Convert charge information to an index.
114  int getChargeIndex(int charge, bool fc);
115 
116  // Convert pseudochain to unique ID.
117  int getID(PseudoChain& psc) {
118  int id = 0;
119  int iChains = psc.chainlist.size()-1;
120  for (int iPwr(iChains); iPwr>=0; --iPwr)
121  id += (psc.chainlist.at(iPwr)+1)*pow(10,iChains-iPwr);
122  return id;
123  }
124 
125  // List of found pseudochains to not double count.
126  vector<int> pseudochainIDs;
127 
128  // Counters.
129  int nChains;
130  int nBeamChainsMin, nBeamChainsMax, nRes;
131  map<int,int> countChainsByChargeIndex;
132  map<int,int> countResByChargeIndex;
133 
134 };
135 
136 //==========================================================================
137 
138 // Class for a single step in the history of a process.
139 
140 class HistoryNode {
141 
142  public:
143 
144  // Constructors.
146  HistoryNode(Event& stateIn, vector< vector<int> > chainsIn,
147  double scaleIn) : HistoryNode() {
148  state = stateIn;
149  clusterableChains = chainsIn;
150  qEvolNow = scaleIn;
151  hasRes = false;
152  iRes = 0;
153  idRes = 0;
154  isInitPtr=false;
155  };
156 
157  // Methods.
158  void initPtr(VinciaCommon* vinComPtrIn, Resolution* resPtrIn,
159  AntennaSetFSR* antSetPtrIn) {
160  resPtr = resPtrIn;
161  vinComPtr = vinComPtrIn;
162  antSetFSRptr = antSetPtrIn;
163  isInitPtr=true;
164  nMinQQbar = 0;
165  }
166 
167  // Set clusterList.
168  int getNClusterings(shared_ptr<VinciaMergingHooks> vinMergingHooksPtr,
169  Logger* loggerPtr, int verboseIn);
170  void setClusterList(shared_ptr<VinciaMergingHooks> vinMergingHooksPtr,
171  Logger* loggerPtr, int verboseIn);
172 
173  // Perform the clusterings according to the resolution criterion.
174  bool cluster(HistoryNode& nodeClus,
175  Logger* loggerPtr, int verboseIn);
176 
177  // Get energy fractions (used in PDF ratios).
178  double xA() const {return 2. * state[3].e() / state[0].e();}
179  double xB() const {return 2. * state[4].e() / state[0].e();}
180 
181  // Get flavours of beams (used in PDF ratios).
182  int idA() const {return state[3].id();}
183  int idB() const {return state[4].id();}
184 
185  // Get colour types of beams (used in PDF ratios).
186  int colTypeA() const {return state[3].colType();}
187  int colTypeB() const {return state[4].colType();}
188 
189  // Get evolution scale (used in trial shower).
190  double getEvolNow() const {return qEvolNow;}
191 
192  // Setter methods.
193  void setEvolScale(double scaleIn) {qEvolNow = scaleIn;}
194 
195  // Current state.
197 
198  // Resonance info.
199  bool hasRes;
200  int iRes;
201  int idRes;
202 
203  // Minimal number of qqbar pairs.
205 
206  // List of unclusterable lists of colour-connected partons.
207  vector<vector<int>> clusterableChains;
208 
209  // Information corresponding to the last clustering.
211 
212  private:
213 
214  // Perform a clustering.
215  bool doClustering(VinciaClustering& clus, Event& clusEvent,
216  vector<vector<int>>& clusChains, Logger* loggerPtr, int verboseIn);
217 
218  // Methods to calculate resolution and evolution scales.
219  double calcResolution(VinciaClustering& clusIn) {
220  return resPtr->q2sector(clusIn);}
221  double calcEvolScale(VinciaClustering& clusIn) {
222  return resPtr->q2evol(clusIn);}
223 
224  // Members.
225 
226  // Vincia pointers.
227  Resolution* resPtr;
228  VinciaCommon* vinComPtr;
229  AntennaSetFSR* antSetFSRptr;
230 
231  bool isInitPtr;
232 
233  // The value of the evolution scale.
234  double qEvolNow;
235 
236  // List of next possible clusterings.
237  // Map is from corresponding resolution criterion.
238  map<double, VinciaClustering> clusterList;
239 
240 };
241 typedef map<int, vector<HistoryNode> > HistoryNodes;
242 
243 //==========================================================================
244 
245 // History class for the Vincia shower.
246 
248 
249 public:
250 
251  // Constructor.
252  VinciaHistory(Event &stateIn,
253  BeamParticle* beamAPtrIn, BeamParticle* beamBPtrIn,
254  MergingHooksPtr mergingHooksPtrIn,
255  PartonLevel* trialPartonLevelPtrIn,
256  ParticleData* particleDataPtrIn,
257  Info* infoPtrIn);
258 
259  // Check if a valid history was found.
260  bool isValid() {return foundValidHistory;}
261 
262  // Check if history failed merging scale cut.
263  bool isBelowMS() {return failedMSCut;}
264 
265  // Perform a trial shower and get the CKKW-L weight
266  // (excluding last no-emission probability that is
267  // calculated in the main shower).
268  double getWeightCKKWL();
269 
270  // Find the first clustered state above the merging scale.
271  Event getFirstClusteredEventAboveTMS();
272 
273  // What was the multiplicity of this event?
274  int getNClusterSteps();
275 
276  // Get the shower starting scale.
277  double getRestartScale();
278 
279  // Should we overwrite the original event?
280  // E.g. if an MPI was generated.
281  bool hasNewProcess() {return hasNewProcessSav;}
282  Event getNewProcess() {return newProcess;}
283  bool doAbort() {return aborted;}
284 
285 private:
286 
287  // Loop over colPerms and set historyBest.
288  void findBestHistory();
289 
290  // Find all viable colour orderings and return number.
291  unsigned int countPerms();
292 
293  // Fetch the colour chains from the hard event.
294  bool getColChains();
295 
296  // Find all selections of chains for colour singlets.
297  bool assignResChains(map<int, map<int,int>>& idCounter,
298  vector<ColourFlow>& flowsSoFar);
299 
300  // Find all selections of chains for colour singlets.
301  bool assignResFromEvent(map<int, map<int,int>>& idCounter,
302  vector<ColourFlow>& flowsSoFar);
303 
304  // Find all selections of chains for everything that is
305  // not a colour singlet resonance.
306  bool assignBeamChains(vector<ColourFlow>& flowsSoFar);
307 
308  // Make a single selection in all possible ways.
309  bool assignNext(vector<ColourFlow>& flowsSoFar, bool isRes = false,
310  int id = 0, int cIndex = 0);
311 
312  // Make a specific selection for a resonance.
313  bool assignThis(vector<ColourFlow>& flowsSoFar, int id, int cIndex,
314  vector<int>& chains);
315 
316  // Is this (completed flow) compatible with the number of
317  // resonances of each type?
318  bool check(ColourFlow& flow);
319 
320  // Construct history for a given colour permutation.
321  tuple<bool, double, HistoryNodes> findHistoryPerm(ColourFlow& flow);
322 
323  // Check if history failed merging scale cut.
324  bool checkMergingCut(HistoryNodes& history);
325 
326  // Initialise history nodes for each system.
327  HistoryNodes initHistoryNodes(ColourFlow& flow );
328 
329  // Translate abstract book-keeping of colour ordering into
330  // systems of particles.
331  map<int, vector<vector<int>>> getSystems(ColourFlow& flow,
332  map<int, int>& sysToRes);
333 
334  // Decide if state is the Born topology.
335  bool isBorn(const HistoryNode& nodeIn, bool isRes);
336 
337  // Set up beams for given history node.
338  bool setupBeams(const HistoryNode* node, double scale2);
339 
340  // Calculate criterion for testing whether to keep history.
341  double calcME2guess(vector<HistoryNode>& history,bool isRes);
342  // Calculate ME for Born-level event.
343  double calcME2Born(const HistoryNode& bornNode, bool isRes);
344 
345  // Calculate the antenna function for a given clustering.
346  double calcAntFun(const VinciaClustering& clusNow);
347 
348  // Calculate PDF ratio to multiply CKKW-L weight.
349  double calcPDFRatio(const HistoryNode* nodeNow,
350  double pT2now, double pT2next);
351 
352  // Calculate alphaS ratio to multiply CKKW-L weight.
353  double calcAlphaSRatio(const HistoryNode& node);
354 
355  // Return the kinematic maximum for this event.
356  double getStartScale(Event& event, bool isRes);
357 
358  // Perform a trial branching and return scale.
359  double qNextTrial(double qStart, Event& evtIn);
360 
361  // Print colour chains.
362  void printChains();
363 
364  // Verbosity.
365  int verbose;
366 
367  // Beams -- for PDFs.
368  BeamParticle beamA, beamB;
369 
370  // MergingHooks.
371  shared_ptr<VinciaMergingHooks> vinMergingHooksPtr{};
372 
373  // PartonLevel pointer.
374  PartonLevel* trialPartonLevel{};
375 
376  // Particle data pointer.
377  ParticleData* particleDataPtr{};
378 
379  // Other Pythia pointers.
380  Info* infoPtr{};
381  Logger* loggerPtr{};
382 
383  // Vincia pointers.
384  shared_ptr<VinciaFSR> fsrShowerPtr{};
385  shared_ptr<VinciaISR> isrShowerPtr{};
386  MECs* mecsPtr{};
387  VinciaCommon* vinComPtr{};
388  Resolution* resPtr{};
389  AntennaSetFSR* antSetFSRptr{};
390 
391  // Check we found a valid history at all.
392  bool foundValidHistory;
393 
394  // Check we vetoed due failing the merging scale cut.
395  bool failedMSCut;
396 
397  // This is the best PS history so far.
398  HistoryNodes historyBest;
399 
400  // Criterion to minimise (best so far).
401  // Call calcME2guess(..) to evaluate.
402  double ME2guessBest;
403 
404  // Initial colour permutation, stored as
405  // list of sets of colour connected partons.
406  vector<vector<int>> colChainsSav;
407 
408  // Track if chain contains initial state quarks.
409  map<int, bool> chainHasInitial;
410 
411  // Keep track of resonances in the event record.
412  map<int, vector<int>> resIDToIndices;
413  map<int, vector<int>> resIndexToChains;
414 
415  // All colour flows compatible with Born process.
416  vector<ColourFlow> colPerms;
417 
418  // ME generated event.
419  Event state;
420 
421  // Number of quarks and gluon loops in event.
422  int nQSave, nGluonLoopsSave;
423 
424  // The merging scale and whether it is the evolution variable.
425  double qms;
426  bool msIsEvolVar;
427 
428  // The maximum multiplicity of our ME generator.
429  int nMax, nMaxRes;
430 
431  // Possible new hard process info (if MPI was generated).
432  bool hasNewProcessSav;
433  Event newProcess;
434  double newProcessScale;
435 
436  // Flag to signal if something went wrong.
437  bool aborted;
438 
439 };
440 
441 //==========================================================================
442 
443 } // end namespace Pythia8
444 
445 #endif // Pythia8_VinciaHistory_H
History class for the Vincia shower.
Definition: VinciaHistory.h:247
VinciaClustering lastClustering
Information corresponding to the last clustering.
Definition: VinciaHistory.h:210
void initPtr(VinciaCommon *vinComPtrIn, Resolution *resPtrIn, AntennaSetFSR *antSetPtrIn)
Methods.
Definition: VinciaHistory.h:158
Definition: Info.h:45
Event state
Current state.
Definition: VinciaHistory.h:196
The Event class holds all info on the generated event.
Definition: Event.h:408
Convenient shorthand for storing ordered list of chains.
Definition: VinciaHistory.h:24
Definition: BeamParticle.h:133
Simple struct to store information about a 3 -> 2 clustering.
Definition: VinciaCommon.h:278
bool hasRes
Resonance info.
Definition: VinciaHistory.h:199
vector< PseudoChain > beamChains
Remaining list of ordered chains after resonances stripped off.
Definition: VinciaHistory.h:82
map< int, int > chainStartToFlav
Map from chain to the flavour at the start or end of that chain.
Definition: VinciaHistory.h:94
int charge
Charge.
Definition: VinciaHistory.h:37
double xA() const
Get energy fractions (used in PDF ratios).
Definition: VinciaHistory.h:178
bool hasNewProcess()
Definition: VinciaHistory.h:281
bool isValid()
Check if a valid history was found.
Definition: VinciaHistory.h:260
Definition: Logger.h:23
map< int, vector< PseudoChain > > resChains
Members.
Definition: VinciaHistory.h:79
Definition: VinciaCommon.h:494
map< int, vector< int > > chainToIndices
Definition: VinciaHistory.h:91
Definition: PartonLevel.h:45
double getEvolNow() const
Get evolution scale (used in trial shower).
Definition: VinciaHistory.h:190
void setEvolScale(double scaleIn)
Setter methods.
Definition: VinciaHistory.h:193
int colTypeA() const
Get colour types of beams (used in PDF ratios).
Definition: VinciaHistory.h:186
bool isBelowMS()
Check if history failed merging scale cut.
Definition: VinciaHistory.h:263
ColourFlow()
Constructor.
Definition: VinciaHistory.h:51
Class for a single step in the history of a process.
Definition: VinciaHistory.h:140
Definition: VinciaHistory.h:46
A simple class for containing evolution variable definitions.
Definition: VinciaCommon.h:382
int cindex
Charge Index.
Definition: VinciaHistory.h:30
map< int, vector< PseudoChain > > pseudochains
Definition: VinciaHistory.h:87
int nMinQQbar
Minimal number of qqbar pairs.
Definition: VinciaHistory.h:204
The AntennaSetFSR class. Simple container of FF and RF antenna functions.
Definition: VinciaAntennaFunctions.h:1125
int idA() const
Get flavours of beams (used in PDF ratios).
Definition: VinciaHistory.h:182
Header for classes to set beam momentum and interaction vertex spread.
Definition: Analysis.h:20
vector< vector< int > > clusterableChains
List of unclusterable lists of colour-connected partons.
Definition: VinciaHistory.h:207
Definition: VinciaAntennaFunctions.h:1258
map< int, bool > hasInitial
Keep track of chains which contain an initial state parton.
Definition: VinciaHistory.h:97
HistoryNode()
Constructors.
Definition: VinciaHistory.h:145
bool hasInitial
Does any of the chains contain an initial state parton.
Definition: VinciaHistory.h:32
int flavStart
Flavour at start of first and end of last.
Definition: VinciaHistory.h:34
vector< int > chainlist
Ordered list of concatenated chains.
Definition: VinciaHistory.h:26
This class holds a map of all ParticleDataEntries.
Definition: ParticleData.h:422
map< int, int > chainToCharge
Keep track of charge information of chains.
Definition: VinciaHistory.h:99
int index
Index unique up to chain content (not ordering).
Definition: VinciaHistory.h:28