10 #ifndef Pythia8_DireSpace_H 11 #define Pythia8_DireSpace_H 13 #define DIRE_SPACE_VERSION "2.002" 15 #include "Pythia8/Basics.h" 16 #include "Pythia8/SpaceShower.h" 17 #include "Pythia8/BeamParticle.h" 18 #include "Pythia8/Event.h" 19 #include "Pythia8/Info.h" 20 #include "Pythia8/ParticleData.h" 21 #include "Pythia8/PartonSystems.h" 22 #include "Pythia8/PythiaStdlib.h" 23 #include "Pythia8/Settings.h" 24 #include "Pythia8/StandardModel.h" 25 #include "Pythia8/UserHooks.h" 26 #include "Pythia8/MergingHooks.h" 27 #include "Pythia8/SimpleWeakShowerMEs.h" 28 #include "Pythia8/DireBasics.h" 29 #include "Pythia8/DireSplittingLibrary.h" 30 #include "Pythia8/DireWeightContainer.h" 43 DireSpaceEnd(
int systemIn = 0,
int sideIn = 0,
int iRadiatorIn = 0,
44 int iRecoilerIn = 0,
double pTmaxIn = 0.,
int colTypeIn = 0,
45 int chgTypeIn = 0,
int weakTypeIn = 0,
int MEtypeIn = 0,
46 bool normalRecoilIn =
true,
int weakPolIn = 0,
48 vector<int> iSpectatorIn = vector<int>(),
49 vector<double> massIn = vector<double>(),
50 vector<int> allowedIn = vector<int>() ) :
51 system(systemIn), side(sideIn), iRadiator(iRadiatorIn),
52 iRecoiler(iRecoilerIn), pTmax(pTmaxIn), colType(colTypeIn),
53 chgType(chgTypeIn), weakType(weakTypeIn), MEtype(MEtypeIn),
54 normalRecoil(normalRecoilIn), weakPol(weakPolIn),
nBranch(0),
56 allowedEmissions(allowedIn), iSiblings(iSiblingsIn) {
57 idDaughter = idMother = idSister = iFinPol = 0;
58 x1 = x2 = m2Dip = pT2 = z = xMo = Q2 = mSister = m2Sister = pT2corr
59 = pT2Old = zOld = asymPol =
sa1 = xa = pT2start = pT2stop = 0.;
60 mRad = m2Rad = mRec = m2Rec = mDip = 0.;
66 :
system(dip.
system), side(dip.side), iRadiator(dip.iRadiator),
67 iRecoiler(dip.iRecoiler), pTmax(dip.pTmax), colType(dip.colType),
68 chgType(dip.chgType), weakType(dip.weakType), MEtype(dip.MEtype),
69 normalRecoil(dip.normalRecoil), weakPol(dip.weakPol),
70 nBranch(dip.
nBranch), idDaughter(dip.idDaughter), idMother(dip.idMother),
71 idSister(dip.idSister), iFinPol(dip.iFinPol), x1(dip.x1), x2(dip.x2),
72 m2Dip(dip.m2Dip), pT2(dip.pT2), z(dip.z), xMo(dip.xMo), Q2(dip.Q2),
73 mSister(dip.mSister), m2Sister(dip.m2Sister), pT2corr(dip.pT2corr),
74 pT2Old(dip.pT2Old), zOld(dip.zOld), asymPol(dip.asymPol), phi(dip.phi),
75 pT2start(dip.pT2start), pT2stop(dip.pT2stop),
76 mRad(dip.mRad), m2Rad(dip.m2Rad), mRec(dip.mRec), m2Rec(dip.m2Rec),
77 mDip(dip.mDip),
sa1(dip.
sa1), xa(dip.xa),
79 allowedEmissions(dip.allowedEmissions), iSiblings(dip.iSiblings) {}
83 {
system = s.
system; side = s.side; iRadiator = s.iRadiator;
84 iRecoiler = s.iRecoiler; pTmax = s.pTmax; colType = s.colType;
85 chgType = s.chgType; weakType = s.weakType; MEtype = s.MEtype;
86 normalRecoil = s.normalRecoil; weakPol = s.weakPol;
87 nBranch = s.
nBranch; idDaughter = s.idDaughter; idMother = s.idMother;
88 idSister = s.idSister; iFinPol = s.iFinPol; x1 = s.x1; x2 = s.x2;
89 m2Dip = s.m2Dip; pT2 = s.pT2; z = s.z; xMo = s.xMo; Q2 = s.Q2;
90 mSister = s.mSister; m2Sister = s.m2Sister; pT2corr = s.pT2corr;
91 pT2Old = s.pT2Old; zOld = s.zOld; asymPol = s.asymPol; phi = s.phi;
92 pT2start = s.pT2start; pT2stop = s.pT2stop;
93 mRad = s.mRad; m2Rad = s.m2Rad; mRec = s.mRec; m2Rec = s.m2Rec;
94 mDip = s.mDip;
sa1 = s.
sa1; xa = s.xa; phia1 = s.phia1;
mass = s.
mass;
96 iSiblings = s.iSiblings;}
return *
this; }
99 void store(
int idDaughterIn,
int idMotherIn,
int idSisterIn,
100 double x1In,
double x2In,
double m2DipIn,
double pT2In,
double zIn,
101 double sa1In,
double xaIn,
double xMoIn,
double Q2In,
double mSisterIn,
102 double m2SisterIn,
double pT2corrIn,
double phiIn = -1.,
103 double phia1In = 1.) {
104 idDaughter = idDaughterIn; idMother = idMotherIn;
105 idSister = idSisterIn; x1 = x1In; x2 = x2In; m2Dip = m2DipIn;
106 pT2 = pT2In; z = zIn;
sa1 = sa1In; xa = xaIn; xMo = xMoIn; Q2 = Q2In;
107 mSister = mSisterIn; m2Sister = m2SisterIn; pT2corr = pT2corrIn;
108 mRad = m2Rad = mRec = m2Rec = mDip = 0.;
109 phi = phiIn; phia1 = phia1In; }
114 int colType, chgType, weakType, MEtype;
119 int nBranch, idDaughter, idMother, idSister, iFinPol;
120 double x1, x2, m2Dip, pT2, z, xMo, Q2, mSister, m2Sister, pT2corr,
121 pT2Old, zOld, asymPol, phi, pT2start, pT2stop,
122 mRad, m2Rad, mRec, m2Rec, mDip;
133 vector<int> allowedEmissions;
138 if ( find(allowedEmissions.begin(), allowedEmissions.end(), id)
139 == allowedEmissions.end() ) { allowedEmissions.push_back(
id);}
141 void clearAllowedEmt() { allowedEmissions.resize(0); }
142 bool canEmit() {
return int(allowedEmissions.size() > 0); }
144 void init(
const Event& state) {
145 mRad = state[iRadiator].m();
146 mRec = state[iRecoiler].m();
147 mDip = sqrt( abs(2. * state[iRadiator].p() * state[iRecoiler].p()));
155 cout <<
"\n -------- DireSpaceEnd Listing -------------- \n" 156 <<
"\n syst side rad rec pTmax col chg ME rec \n" 157 << fixed << setprecision(3);
158 cout << setw(6) << system
159 << setw(6) << side << setw(6) << iRadiator
160 << setw(6) << iRecoiler << setw(12) << pTmax
161 << setw(5) << colType << setw(5) << chgType
162 << setw(5) << MEtype << setw(4)
164 << setw(12) << m2Dip;
165 for (
int j = 0; j < int(allowedEmissions.size()); ++j)
166 cout << setw(5) << allowedEmissions[j] <<
" ";
169 cout <<
"\n -------- End DireSpaceEnd Listing ------------" 170 <<
"-------------------------------------------------------" << endl;
175 void clearSiblings() { iSiblings.clear(); }
191 mergingHooksPtr =
nullptr;
192 splittingsPtr =
nullptr;
194 direInfoPtr =
nullptr;
195 beamAPtr = beamBPtr =
nullptr;
200 usePDFalphas =
false;
203 suppressLargeMECs =
false;
206 DireSpace( MergingHooksPtr mergingHooksPtrIn, PartonVertexPtr ) :
207 pTdampFudge(0.), mc(0.), mb(0.), m2c(0.), m2b(0.), m2cPhys(0.),
208 m2bPhys(0.), renormMultFac(0.), factorMultFac(0.), fixedFacScale2(0.),
209 alphaSvalue(0.), alphaS2pi(0.), Lambda3flav(0.), Lambda4flav(0.),
210 Lambda5flav(0.), Lambda3flav2(0.), Lambda4flav2(0.), Lambda5flav2(0.),
211 pT0Ref(0.), ecmRef(0.), ecmPow(0.), pTmin(0.), sCM(0.), eCM(0.), pT0(0.),
212 pT20(0.), pT2min(0.), m2min(0.), mTolErr(0.), pTmaxFudgeMPI(0.),
213 strengthIntAsym(0.), pT2minVariations(0.), pT2minEnhance(0.),
214 pT2minMECs(0.), Q2minMECs(0.),
215 alphaS2piOverestimate(0.), usePDFalphas(
false), usePDFmasses(
false),
216 useSummedPDF(
false), usePDF(
true), useSystems(
true),
217 useGlobalMapIF(
false), forceMassiveMap(
false), useMassiveBeams(
false),
218 suppressLargeMECs(
false) {
219 mergingHooksPtr = mergingHooksPtrIn;
222 splittingsPtr =
nullptr;
224 direInfoPtr =
nullptr;
240 if (splittingsPtr) splits = splittingsPtr->getSplittings();
241 return (splits.size() > 0);
250 particleDataPtr = infoPtr->particleDataPtr;
251 rndmPtr = infoPtr->rndmPtr;
252 partonSystemsPtr = infoPtr->partonSystemsPtr;
253 userHooksPtr = infoPtr->userHooksPtr;
254 mergingHooksPtr = mergingHooksPtrIn;
255 splittingsPtr = splittingsPtrIn;
256 direInfoPtr = direInfoPtrIn;
259 void initVariations();
265 weights = weightsIn;}
268 virtual bool limitPTmax(
Event& event,
double Q2Fac = 0.,
276 virtual void prepare(
int iSys,
Event& event,
bool limitPTmaxIn =
true);
280 virtual void update(
int ,
Event&,
bool =
false);
283 void updateAfterII(
int iSysSelNow,
int sideNow,
int iDipSelNow,
284 int eventSizeOldNow,
int systemSizeOldNow,
Event& event,
int iDaughter,
285 int iMother,
int iSister,
int iNewRecoiler,
double pT2,
double xNew);
288 void updateAfterIF(
int iSysSelNow,
int sideNow,
int iDipSelNow,
289 int eventSizeOldNow,
int systemSizeOldNow,
Event& event,
int iDaughter,
290 int iRecoiler,
int iMother,
int iSister,
int iNewRecoiler,
int iNewOther,
291 double pT2,
double xNew);
294 virtual double pTnext(
Event& event,
double pTbegAll,
double pTendAll,
295 int nRadIn = -1,
bool =
false);
296 double newPoint(
const Event& event);
300 double pTnext( vector<DireSpaceEnd> dipEnds,
Event event,
double pTbegAll,
301 double pTendAll,
double m2dip,
int type,
double s = -1.,
double x = -1.);
302 double noEmissionProbability(
double pTbegAll,
double pTendAll,
double m2dip,
303 int id,
int type,
double s = -1.,
double x = -1.);
306 virtual bool branch(
Event& event);
308 bool branch_II(
Event& event,
bool =
false,
310 bool branch_IF(
Event& event,
bool =
false,
316 pair <Event, pair<int,int> > reclus
317 = clustered_internal(state, iRad, iEmt, iRecAft, name);
318 if (reclus.first.size() > 0)
319 reclus.first[0].mothers(reclus.second.first,reclus.second.second);
322 pair <Event, pair<int,int> > clustered_internal(
const Event& state,
323 int iRad,
int iEmt,
int iRecAft,
string name);
324 bool cluster_II(
const Event& state,
int iRad,
326 Event& partialState);
327 bool cluster_IF(
const Event& state,
int iRad,
329 Event& partialState);
335 if (rec.isFinal())
return pT2_IF(rad,emt,rec);
336 return pT2_II(rad,emt,rec);
348 if (rec.isFinal())
return z_IF(rad,emt,rec);
349 return z_II(rad,emt,rec);
359 if (rec.isFinal())
return m2dip_IF(rad,emt,rec);
360 return m2dip_II(rad,emt,rec);
381 virtual map<string, double> getStateVariables (
const Event& state,
382 int rad,
int emt,
int rec,
string name);
389 {
return !state[iRad].isFinal(); }
395 int iEmt,
int) {
return splittingsPtr->getSplittingName(state,iRad,iEmt); }
400 virtual double getSplittingProb(
const Event& state,
int iRad,
401 int iEmt,
int iRecAft,
string);
403 virtual bool allowedSplitting(
const Event& state,
int iRad,
int iEmt);
405 virtual vector<int> getRecoilers(
const Event& state,
int iRad,
int iEmt,
408 virtual double getCoupling(
double mu2Ren,
string name) {
409 if (splits.find(name) != splits.end())
410 return splits[name]->coupling(-1.,mu2Ren, 0., 1.);
415 if (splits.find(name) != splits.end())
416 return splits[name]->isSymmetric(rad,emt);
422 int FindParticle(
const Particle& particle,
const Event& event,
423 bool checkStatus =
true );
426 virtual void list()
const;
428 Event makeHardEvent(
int iSys,
const Event& state,
bool isProcess =
false );
431 bool validMomentum(
const Vec4& p,
int id,
int status);
437 bool validMotherDaughter(
const Event& state );
440 int FindCol(
int col, vector<int> iExc,
const Event& event,
int type,
452 double alphasNow(
double pT2,
double renormMultFacNow = 1.,
int iSys = 0 );
454 bool isInit() {
return isInitSave; }
458 if ( state[dipEnd[iDip].iRecoiler].isFinal()
459 && state[dipEnd[iDip].iRadiator].isFinal())
460 return dipEnd[iDip].m2Dip;
461 int iSys = dipEnd[iDip].system;
462 int inA = partonSystemsPtr->getInA(iSys);
463 int inB = partonSystemsPtr->getInB(iSys);
465 int iRad(dipEnd[iDip].iRadiator), iRecNow(dipEnd[iDip].iRecoiler);
466 if (hasPDF(state[iRad].
id()) && iRad == inA)
467 x *= state[inA].pPos() / state[0].m();
468 if (hasPDF(state[iRad].
id()) && iRad == inB)
469 x *= state[inB].pNeg() / state[0].m();
470 if (hasPDF(state[iRecNow].
id()) && iRecNow == inA)
471 x *= state[inA].pPos() / state[0].m();
472 if (hasPDF(state[iRecNow].
id()) && iRecNow == inB)
473 x *= state[inB].pNeg() / state[0].m();
474 return dipEnd[iDip].m2Dip/x;
484 static const int TIMESTOPRINT;
487 static const double CONVERTMB2PB;
491 double CA, CF, TR, NC;
494 int idASave, idBSave;
505 static const int MAXLOOPTINYPDF;
506 static const double MCMIN, MBMIN, CTHRESHOLD, BTHRESHOLD, EVALPDFSTEP,
507 TINYPDF, TINYKERNELPDF, TINYPT2, HEAVYPT2EVOL, HEAVYXEVOL,
508 EXTRASPACEQ, LAMBDA3MARGIN, PT2MINWARN, LEPTONXMIN, LEPTONXMAX,
509 LEPTONPT2MIN, LEPTONFUDGE, HEADROOMQ2Q, HEADROOMQ2G,
510 HEADROOMG2G, HEADROOMG2Q, TINYMASS,
511 PT2_INCREASE_OVERESTIMATE, KERNEL_HEADROOM;
512 static const double DPHI_II, DPHI_IF;
513 static const double G2QQPDFPOW1, G2QQPDFPOW2;
516 bool isInitSave, doQCDshower, doQEDshowerByQ, doQEDshowerByL,
517 useSamePTasMPI, doMEcorrections, doMEafterFirst, doPhiPolAsym,
518 doPhiIntAsym, doRapidityOrder, useFixedFacScale, doSecondHard,
519 canVetoEmission, hasUserHooks, alphaSuseCMW, printBanner, doTrialNow;
520 int pTmaxMatch, pTdampMatch, alphaSorder, alphaSnfmax,
521 nQuarkIn, enhanceScreening, nFinalMax, nFinalMaxMECs, kernelOrder,
522 kernelOrderMPI, nWeightsSave, nMPI, asScheme;
523 double pTdampFudge, mc, mb, m2c, m2b, m2cPhys, m2bPhys, renormMultFac,
524 factorMultFac, fixedFacScale2, alphaSvalue, alphaS2pi, Lambda3flav,
525 Lambda4flav, Lambda5flav, Lambda3flav2, Lambda4flav2, Lambda5flav2,
526 pT0Ref, ecmRef, ecmPow, pTmin, sCM, eCM, pT0, pT20,
527 pT2min, m2min, mTolErr, pTmaxFudgeMPI, strengthIntAsym,
528 pT2minVariations, pT2minEnhance, pT2minMECs, Q2minMECs;
529 double alphaS2piOverestimate;
530 bool usePDFalphas, usePDFmasses, useSummedPDF, usePDF, useSystems,
531 useGlobalMapIF, forceMassiveMap, useMassiveBeams, suppressLargeMECs;
533 unordered_map<int,double> pT2cutSave;
534 double pT2cut(
int id) {
535 if (pT2cutSave.find(
id) != pT2cutSave.end())
return pT2cutSave[
id];
538 for ( unordered_map<int,double>::iterator it = pT2cutSave.begin();
539 it != pT2cutSave.end(); ++it ) ret = max(ret, it->second);
544 for (
int i=0; i < int(dip->allowedEmissions.size()); ++i)
545 ret = max( ret, pT2cut(dip->allowedEmissions[i]));
550 for (
int i=0; i < int(dip->allowedEmissions.size()); ++i)
551 ret = min( ret, pT2cut(dip->allowedEmissions[i]));
555 bool doDecaysAsShower;
561 bool sideA, dopTlimit1, dopTlimit2, dopTdamp;
562 int iNow, iRec, idDaughter, nRad, idResFirst, idResSecond;
563 double xDaughter, x1Now, x2Now, m2Dip, m2Rec, pT2damp, pTbegRef, pdfScale2;
566 vector<int> nRadA,nRadB;
569 vector<DireSpaceEnd> dipEnd;
572 int iDipNow, iSysNow;
578 unordered_map<string,double> kernelSel, kernelNow;
579 double auxSel, overSel, boostSel, auxNow, overNow, boostNow;
581 void setupQCDdip(
int iSys,
int side,
int colTag,
int colSign,
582 const Event& event,
int MEtype,
bool limitPTmaxIn);
584 void getGenDip(
int iSys,
int side,
const Event& event,
585 bool limitPTmaxIn, vector<DireSpaceEnd>& dipEnds );
587 void getQCDdip(
int iRad,
int colTag,
int colSign,
588 const Event& event, vector<DireSpaceEnd>& dipEnds);
591 bool appendDipole(
const Event& state,
int sys,
int side,
592 int iRad,
int iRecNow,
double pTmax,
int colType,
593 int chgType,
int weakType,
int MEtype,
bool normalRecoil,
594 int weakPolIn, vector<int> iSpectatorIn, vector<double> massIn,
595 vector<DireSpaceEnd>& dipEnds);
600 void saveSiblings(
const Event& state,
int iSys = -1);
601 void updateDipoles(
const Event& state,
int iSys = -1);
606 bool doRestart()
const {
return false;}
608 bool wasGamma2qqbar() {
return false; }
610 bool getHasWeaklyRadiated() {
return false;}
611 int system()
const {
return iSysSel;}
614 void pT2nextQCD(
double pT2begDip,
double pT2endDip,
616 double pT2freeze = 0.,
bool forceBranching =
false);
617 bool pT2nextQCD_II(
double pT2begDip,
double pT2endDip,
619 double pT2freeze = 0.,
bool forceBranching =
false);
620 bool pT2nextQCD_IF(
double pT2begDip,
double pT2endDip,
622 double pT2freeze = 0.,
bool forceBranching =
false);
625 double tOld,
double tMin,
double tFreeze=0.,
int algoType = 0);
626 bool zCollNextQCD(
DireSpaceEnd* dip,
double zMin,
double zMax,
627 double tMin = 0.,
double tMax = 0.);
628 bool virtNextQCD(
DireSpaceEnd* dip,
double tMin,
double tMax,
629 double zMin =-1.,
double zMax =-1.);
633 double evalpdfstep(
int idRad,
double pT2,
double m2cp = -1.,
636 if (m2cp < 0.) m2cp = particleDataPtr->m0(4);
637 if (m2bp < 0.) m2bp = particleDataPtr->m0(5);
639 if ( abs(idRad) == 4 && pT2 < 1.2*m2cp && pT2 > m2cp) ret = 1.0;
640 if ( abs(idRad) == 5 && pT2 < 1.2*m2bp && pT2 > m2bp) ret = 1.0;
644 double tinypdf(
double x) {
646 return TINYPDF*log(1-x)/log(1-xref);
650 bool hasPDF (
int id) {
651 if ( !usePDF )
return false;
652 if ( particleDataPtr->colType(
id) != 0)
return true;
653 if ( particleDataPtr->isLepton(
id)
654 && settingsPtr->flag(
"PDF:lepton"))
return true;
659 double getXPDF(
int id,
double x,
double t,
int iSys = 0,
660 BeamParticle* beam =
nullptr,
bool finalRec =
false,
double z = 0.,
663 if (!hasPDF(
id))
return 1.0;
667 if (beamAPtr !=
nullptr || beamBPtr !=
nullptr) {
668 b = (beamAPtr !=
nullptr && particleDataPtr->isHadron(beamAPtr->id()))
670 : (beamBPtr !=
nullptr && particleDataPtr->isHadron(beamBPtr->id()))
671 ? beamBPtr :
nullptr;
673 if (b ==
nullptr && beamAPtr !=
nullptr) b = beamAPtr;
674 if (b ==
nullptr && beamBPtr !=
nullptr) b = beamBPtr;
678 if (asScheme == 2 && z != 0) {
680 double xcs = (z * (1.-z) - t/m2dip) / (1.-z);
681 double vcs = t/m2dip / (1.-z);
682 double sab = m2dip/xcs;
683 double saj = vcs*sab;
684 double sjb = sab-saj-m2dip;
685 scale2= abs(saj*sjb/sab);
688 double ucs = t/m2dip / (1.-z);
689 scale2 = (1-xcs)/xcs*ucs/(1-ucs)*m2dip;
693 double ret = (useSummedPDF) ? b->
xf(
id, x, scale2)
694 : b->xfISR(iSys,
id, x, scale2);
700 int getInA (
int sys,
const Event& state =
Event() ) {
701 if (useSystems)
return partonSystemsPtr->getInA(sys);
703 for (
int i=0; i < state.
size(); ++i)
704 if (state[i].mother1() == 1) {inA = i;
break; }
707 int getInB (
int sys,
const Event& state =
Event() ) {
708 if (useSystems)
return partonSystemsPtr->getInB(sys);
710 for (
int i=0; i < state.
size(); ++i)
711 if (state[i].mother1() == 2) {inB = i;
break; }
719 unordered_map<int,int> nProposedPT;
722 double overheadFactors(
string,
int,
bool,
double,
double);
723 double enhanceOverestimateFurther(
string,
int,
double );
727 double,
double,
double, multimap<double,string>& );
730 double getPDFOverestimates(
int,
double,
double,
string,
bool,
double,
int&,
734 void addNewOverestimates( multimap<double,string>,
double&);
737 void alphasReweight(
double t,
double talpha,
int iSys,
bool forceFixedAs,
738 double& weight,
double& fullWeight,
double& overWeight,
739 double renormMultFacNow);
743 double,
double,
int,
string,
bool,
int&,
int&,
double&,
double&,
744 unordered_map<string,double>&,
double&);
746 pair<bool, pair<double,double> > getMEC (
const Event& state,
749 vector<Event> auxEvent = vector<Event>() );
752 double getMass(
int id,
int strategy,
double mass = 0.) {
753 BeamParticle& beam = ( particleDataPtr->isHadron(beamAPtr->id()) )
754 ? *beamAPtr : *beamBPtr;
755 bool usePDFmass = usePDFmasses
756 && (
toLower(settingsPtr->word(
"PDF:pSet")).find(
"lhapdf")
760 if ( particleDataPtr->colType(
id) != 0) {
761 if (strategy == 1) mRet = particleDataPtr->m0(
id);
762 if (strategy == 2 && usePDFmass) mRet = beam.
mQuarkPDF(
id);
763 if (strategy == 2 && !usePDFmass) mRet = particleDataPtr->m0(
id);
764 if (strategy == 3) mRet =
mass;
765 if (mRet < TINYMASS) mRet = 0.;
768 mRet = particleDataPtr->m0(
id);
769 if (strategy == 3) mRet =
mass;
770 if (mRet < TINYMASS) mRet = 0.;
772 return pow2(max(0.,mRet));
776 bool inAllowedPhasespace(
int kinType,
double z,
double pT2,
double m2dip,
777 double xOld,
int splitType = 0,
double m2RadBef = 0.,
778 double m2r = 0.,
double m2s = 0.,
double m2e = 0.,
779 vector<double> aux = vector<double>());
783 double getNF(
double pT2);
786 double beta0 (
double NF)
787 {
return 11./6.*CA - 2./3.*NF*TR; }
788 double beta1 (
double NF)
789 {
return 17./6.*
pow2(CA) - (5./3.*CA+CF)*NF*TR; }
790 double beta2 (
double NF)
791 {
return 2857./432.*pow(CA,3)
792 + (-1415./216.*
pow2(CA) - 205./72.*CA*CF +
pow2(CF)/4.) *TR*NF
793 + ( 79.*CA + 66.*CF)/108.*
pow2(TR*NF); }
796 string splittingNowName, splittingSelName;
799 unordered_map<string, map<double,double> > acceptProbability;
800 unordered_map<string, multimap<double,double> > rejectProbability;
807 unordered_map<string, DireSplitting* >
splits;
814 unordered_map<string, double > overhead;
815 void scaleOverheadFactor(
string name,
double scale) {
816 overhead[name] *= scale;
819 void resetOverheadFactors() {
820 for ( unordered_map<string,double>::iterator it = overhead.begin();
821 it != overhead.end(); ++it )
827 unordered_map<string,bool> bool_settings;
constexpr double pow2(const double &x)
Powers of small integers - for balance speed/code clarity.
Definition: PythiaStdlib.h:182
CoupSM * getCoupSM()
Pointer to Standard Model couplings.
Definition: DireSpace.h:448
virtual vector< string > getSplittingName(const Event &state, int iRad, int iEmt, int)
Definition: DireSpace.h:394
Definition: StandardModel.h:23
BeamParticle * getBeamA()
Pointers to the two incoming beams.
Definition: DireSpace.h:444
void appendAllowedEmt(int id)
Definition: DireSpace.h:137
Data on radiating dipole ends, only used inside DireSpace.
Definition: DireSpace.h:38
The Event class holds all info on the generated event.
Definition: Event.h:408
Definition: BeamParticle.h:133
vector< int > iSpectator
Extended list of recoilers.
Definition: DireSpace.h:131
int system
Basic properties related to evolution and matrix element corrections.
Definition: DireSpace.h:112
virtual Event clustered(const Event &state, int iRad, int iEmt, int iRecAft, string name)
Setup clustering kinematics.
Definition: DireSpace.h:314
virtual double enhancePTmax() const
Potential enhancement factor of pTmax scale for hardest emission.
Definition: DireSpace.h:272
DireSpaceEnd(const DireSpaceEnd &dip)
Explicit copy constructor.
Definition: DireSpace.h:65
Definition: DireBasics.h:374
string toLower(const string &name, bool trim=true)
Definition: PythiaStdlib.cc:17
double pT2Space(const Particle &rad, const Particle &emt, const Particle &rec)
Definition: DireSpace.h:333
The DireSpace class does spacelike showers.
Definition: DireSpace.h:183
vector< double > mass
Stored masses.
Definition: DireSpace.h:128
DireSpace()
Constructor.
Definition: DireSpace.h:188
DireSpaceEnd(int systemIn=0, int sideIn=0, int iRadiatorIn=0, int iRecoilerIn=0, double pTmaxIn=0., int colTypeIn=0, int chgTypeIn=0, int weakTypeIn=0, int MEtypeIn=0, bool normalRecoilIn=true, int weakPolIn=0, DireSingleColChain iSiblingsIn=DireSingleColChain(), vector< int > iSpectatorIn=vector< int >(), vector< double > massIn=vector< double >(), vector< int > allowedIn=vector< int >())
Constructor.
Definition: DireSpace.h:43
void reinitPtr(Info *infoPtrIn, MergingHooksPtr mergingHooksPtrIn, DireSplittingLibrary *splittingsPtrIn, DireInfo *direInfoPtrIn)
Definition: DireSpace.h:246
int iSysSel
Store properties to be returned by methods.
Definition: DireSpace.h:499
Definition: DireSplittings.h:53
double sa1
Properties of 1->3 splitting.
Definition: DireSpace.h:125
Definition of color chains.
Definition: DireSplitInfo.h:28
void store(int idDaughterIn, int idMotherIn, int idSisterIn, double x1In, double x2In, double m2DipIn, double pT2In, double zIn, double sa1In, double xaIn, double xMoIn, double Q2In, double mSisterIn, double m2SisterIn, double pT2corrIn, double phiIn=-1., double phia1In=1.)
Store values for trial emission.
Definition: DireSpace.h:99
double xf(int idIn, double x, double Q2)
Standard parton distributions.
Definition: BeamParticle.h:240
unordered_map< string, DireSplitting * > splits
List of splitting kernels.
Definition: DireSpace.h:807
double mQuarkPDF(int idIn)
Return quark masses used in the PDF fit (LHAPDF6 only).
Definition: BeamParticle.h:270
Container for all shower weights, including handling.
Definition: DireWeightContainer.h:82
virtual ~DireSpace()
Destructor.
Definition: DireSpace.h:234
Definition: StandardModel.h:135
int size() const
Event record size.
Definition: Event.h:459
DireSpaceEnd & operator=(const DireSpaceEnd &s)
Assignment operator.
Definition: DireSpace.h:82
int nBranch
Properties specific to current trial emission.
Definition: DireSpace.h:119
double m2Max(int iDip, const Event &state)
Function to calculate the absolute phase-sace boundary for emissions.
Definition: DireSpace.h:457
virtual bool isSpacelike(const Event &state, int iRad, int, int, string)
Definition: DireSpace.h:388
double zSpace(const Particle &rad, const Particle &emt, const Particle &rec)
Definition: DireSpace.h:346
Header for classes to set beam momentum and interaction vertex spread.
Definition: Analysis.h:20
Definition: DireSplitInfo.h:212
Definition: DireSplittingLibrary.h:35
The SpaceShower class does spacelike showers.
Definition: SpaceShower.h:33
const double CA
Colour factors in Vincia normalization.
Definition: VinciaCommon.h:40
bool validEvent(const Event &event)
The Merging class.
Definition: DireMerging.cc:24
The DireTimes class does timelike showers.
Definition: DireTimes.h:209
Settings * settingsPtr
Pointer to the settings database.
Definition: Info.h:80
void list() const
Definition: DireSpace.h:153