9 #ifndef Pythia8_TimeShower_H 10 #define Pythia8_TimeShower_H 12 #include "Pythia8/Basics.h" 13 #include "Pythia8/BeamParticle.h" 14 #include "Pythia8/Event.h" 15 #include "Pythia8/Info.h" 16 #include "Pythia8/ParticleData.h" 17 #include "Pythia8/PartonSystems.h" 18 #include "Pythia8/PhysicsBase.h" 19 #include "Pythia8/PythiaStdlib.h" 20 #include "Pythia8/PartonVertex.h" 21 #include "Pythia8/Settings.h" 22 #include "Pythia8/StandardModel.h" 23 #include "Pythia8/UserHooks.h" 24 #include "Pythia8/MergingHooks.h" 25 #include "Pythia8/Weights.h" 45 void initPtrs(MergingHooksPtr mergingHooksPtrIn,
46 PartonVertexPtr partonVertexPtrIn,
51 weightContainerPtr = weightContainerPtrIn;
56 int beamOffsetIn = 0) {beamAPtr = beamAPtrIn; beamBPtr = beamBPtrIn;
69 virtual int shower(
int ,
int ,
Event& ,
double ,
int = 0) {
return 0;}
106 virtual double pTnext(
Event& ,
double ,
double ,
bool =
false,
bool =
false)
168 int ,
string ) {
return map<string,double>();}
178 {
return vector<string>();}
184 virtual bool allowedSplitting(
const Event& ,
int ,
int)
186 virtual vector<int> getRecoilers(
const Event&,
int,
int,
string)
187 {
return vector<int>(); }
189 virtual double enhanceFactor(
const string& name) {
190 unordered_map<string, double>::iterator it = enhanceFSR.find(name);
191 if ( it == enhanceFSR.end() )
return 1.;
199 double,
double) {
return 1.; }
216 noResVariations{}, noProcVariations{};
217 int nUncertaintyVariations{}, nVarQCD{}, uVarNflavQ{};
218 double dASmax{}, cNSpTmin{}, uVarpTmin2{}, overFactor{}, overFactorEnhance{};
219 map<int,double> varG2GGmuRfac, varQ2QGmuRfac, varG2QQmuRfac, varX2XGmuRfac,
220 varG2GGcNS, varQ2QGcNS, varG2QQcNS, varX2XGcNS;
221 map<int,double>* varPDFplus;
222 map<int,double>* varPDFminus;
223 map<int,double>* varPDFmember;
224 unordered_map<string,double> enhanceFSR;
virtual bool isTimelike(const Event &, int, int, int, string)
Definition: TimeShower.h:172
virtual bool resonanceShower(Event &, Event &, vector< int > &, double=0.)
Definition: TimeShower.h:123
virtual double getSplittingProb(const Event &, int, int, int, string)
Definition: TimeShower.h:182
Definition: PhysicsBase.h:27
virtual bool initUncertainties()
Initialize data members for calculation of uncertainty bands.
Definition: TimeShower.h:130
virtual map< string, double > getStateVariables(const Event &, int, int, int, string)
Definition: TimeShower.h:167
The Event class holds all info on the generated event.
Definition: Event.h:408
The TimeShower class does timelike showers.
Definition: TimeShower.h:33
Definition: BeamParticle.h:133
Definition: Weights.h:433
virtual void init(BeamParticle *=0, BeamParticle *=0)
Definition: TimeShower.h:61
CoupSM * coupSMPtr
Pointers to Standard Model and Beyond SM couplings.
Definition: Info.h:95
virtual int shower(int, int, Event &, double, int=0)
Definition: TimeShower.h:69
virtual void prepareGlobal(Event &)
Definition: TimeShower.h:90
TimeShower()=default
Constructor.
virtual int system() const
Tell which system was the last processed one.
Definition: TimeShower.h:139
virtual ~TimeShower()
Destructor.
Definition: TimeShower.h:41
MergingHooksPtr mergingHooksPtr
Pointer to MergingHooks object for NLO merging.
Definition: TimeShower.h:202
virtual void update(int, Event &, bool=false)
Definition: TimeShower.h:102
void initPtrs(MergingHooksPtr mergingHooksPtrIn, PartonVertexPtr partonVertexPtrIn, WeightContainer *weightContainerPtrIn)
Definition: TimeShower.h:45
virtual bool limitPTmax(Event &, double=0., double=0.)
Definition: TimeShower.h:65
int beamOffset
Beam location offset in event.
Definition: TimeShower.h:209
virtual bool getHasWeaklyRadiated()
Tell whether FSR has done a weak emission.
Definition: TimeShower.h:136
virtual Event clustered(const Event &, int, int, int, string)
Return clustering kinematics - as needed for merging.
Definition: TimeShower.h:156
virtual void rescatterUpdate(int, Event &)
Definition: TimeShower.h:98
void reassignBeamPtrs(BeamParticle *beamAPtrIn, BeamParticle *beamBPtrIn, int beamOffsetIn=0)
New beams possible for handling of hard diffraction. (Not virtual.)
Definition: TimeShower.h:55
virtual vector< string > getSplittingName(const Event &, int, int, int)
Definition: TimeShower.h:177
virtual void prepareProcess(Event &, Event &, vector< int > &)
Definition: TimeShower.h:86
virtual double noEmissionProbability(double, double, double, int, int, double, double)
Definition: TimeShower.h:198
virtual bool initEnhancements()
Initialize data members for application of enhancements.
Definition: TimeShower.h:133
CoupSM * coupSMPtr
Pointers to SM and SUSY couplings.
Definition: PhysicsBase.h:96
virtual bool branch(Event &, bool=false)
Definition: TimeShower.h:114
virtual int showerQEDafterDecays(int, int, Event &)
Definition: TimeShower.h:81
Header for classes to set beam momentum and interaction vertex spread.
Definition: Analysis.h:20
PartonVertexPtr partonVertexPtr
Pointer to assign space-time vertices during parton evolution.
Definition: TimeShower.h:212
Info * infoPtr
Definition: PhysicsBase.h:78
virtual void prepare(int, Event &, bool=true)
Definition: TimeShower.h:94
virtual int showerQED(int, int, Event &, double=-1.)
Definition: TimeShower.h:73
virtual void list() const
Print dipole list; for debug mainly.
Definition: TimeShower.h:127
virtual double pTLastInShower()
Provide the pT scale of the last branching in the above shower.
Definition: TimeShower.h:145
virtual double pTnext(Event &, double, double, bool=false, bool=false)
Definition: TimeShower.h:106
virtual double pTnextResDec()
Select next pT for interleaved resonance decays.
Definition: TimeShower.h:110
bool doUncertainties
Store uncertainty variations relevant to TimeShower.
Definition: TimeShower.h:215
virtual int showerQEDafterRemnants(Event &)
Definition: TimeShower.h:77
virtual double enhancePTmax()
Potential enhancement factor of pTmax scale for hardest emission.
Definition: TimeShower.h:142