7 #ifndef Pythia8_LHAHDF5v2_H 8 #define Pythia8_LHAHDF5v2_H 11 #include "Pythia8Plugins/LHEH5v2.h" 14 #include "Pythia8/Pythia.h" 28 LHAupH5v2(HighFive::File* h5fileIn,
size_t firstEventIn,
size_t readSizeIn,
30 lhefPtr(new
LHEH5::LHEFile()), readSizeSav(readSizeIn),
31 nReadSav(0), nTrialsSav(0) {
34 lhefPtr->ReadHeader(*h5fileIn);
35 lhefPtr->ReadEvents(*h5fileIn, firstEventIn, readSizeIn);
38 _weightnames = lhefPtr->WeightNames();
39 if (normalize) lhefPtr->Scale(readSizeIn/lhefPtr->SumTrials());
40 std::vector<double> info;
41 h5fileIn->getDataSet(
"init").read(info);
42 setBeamA(info[0],info[2],info[4],info[6]);
43 setBeamB(info[1],info[3],info[5],info[7]);
45 int numProcesses = info[9];
46 vector<int> procId(numProcesses);
47 vector<double> xSection(numProcesses);
48 vector<double> error(numProcesses);
49 vector<double> unitWeight(numProcesses);
50 for (
int i = 0; i<numProcesses; ++i) {
53 xSection[i] = pi.xsec;
55 unitWeight[i] = pi.unitwgt;
57 for (
int np = 0; np<numProcesses; ++np) {
58 addProcess(procId[np], xSection[np], error[np], unitWeight[np]);
59 xSecSumSave += xSection[np];
60 xErrSumSave +=
pow2(error[np]);
67 bool setEvent(
int idProc=0)
override;
68 void forceStrategy(
int strategyIn) {
setStrategy(strategyIn);}
69 size_t nTrials() {
return nTrialsSav;}
70 size_t nRead() {
return nReadSav;}
78 size_t readSizeSav, nReadSav, nTrialsSav;
81 vector<double> _eventweightvalues;
82 vector<string> _weightnames;
96 if (nReadSav >= readSizeSav)
return false;
101 while (evt.size() == 0) {
103 nTrialsSav += evt.trials;
104 if (nReadSav >= readSizeSav)
return false;
105 evt = lhefPtr->GetEvent(nReadSav);
108 if (evt.size()>0 && evt[0].pz<0 && evt[1].pz>0)
109 swap<LHEH5::Particle>(evt[0], evt[1]);
111 setProcess(evt.pinfo.pid, evt.wgts[0], evt.mur, evt.aqed, evt.aqcd);
113 idprupSave = evt.pinfo.pid;
114 xwgtupSave = evt.wgts[0];
115 scalupSave = evt.mur;
116 aqedupSave = evt.aqed;
117 aqcdupSave = evt.aqcd;
118 double scalein = -1.;
121 _eventweightvalues=evt.wgts;
125 for (
unsigned int ip=0; ip<evt.size(); ++ip) {
128 p.cl1, p.cl2, p.px, p.py, p.pz, p.e, p.m,
129 p.lt, p.sp, scalein);
131 p.cl1, p.cl2, p.px, p.py, p.pz, p.e, p.m,
132 p.lt, p.sp, scalein);
137 scalesNow.
muf = evt.muf;
138 scalesNow.
mur = evt.mur;
139 scalesNow.
mups = evt.muq;
146 nTrialsSav += evt.trials;
void setBeamA(int idIn, double eIn, int pdfGroupIn=0, int pdfSetIn=0)
Input beam info.
Definition: LesHouches.h:222
void addProcess(int idProcIn, double xSecIn=1., double xErrIn=0., double xMaxIn=1.)
Input process info.
Definition: LesHouches.h:233
constexpr double pow2(const double &x)
Powers of small integers - for balance speed/code clarity.
Definition: PythiaStdlib.h:182
void setStrategy(int strategyIn)
Input process weight strategy.
Definition: LesHouches.h:230
vector< double > * weights_compressed
The weights associated with this event, as given by the LHAweights tags.
Definition: Info.h:398
double mups
Definition: LHEF3.h:308
Collect different scales relevant for an event.
Definition: LHEF3.h:281
Process info struct.
Definition: LHEH5v2.h:67
void setEventAttribute(string key, string value, bool doOverwrite=true)
Externally set event tag auxiliary information.
Definition: Info.h:437
Definition: LesHouches.h:78
LHAscales * scales
Contents of the LHAscales tag.
Definition: Info.h:401
void addParticle(LHAParticle particleIn)
Input particle info, one particle at the time.
Definition: LesHouches.h:252
void setProcess(int idProcIn=0, double weightIn=1., double scaleIn=0., double alphaQEDIn=0.0073, double alphaQCDIn=0.12)
Input info on the selected process.
Definition: LesHouches.h:243
Definition: LHAHDF5v2.h:24
LHEFile class.
Definition: LHEH5v2.h:172
double muf
The factorization scale used for this event.
Definition: LHEF3.h:301
void clear()
Function to reset this object.
Definition: LHEF3.h:294
int nupSave
Event properties from LHEF files, for repeated use.
Definition: LesHouches.h:298
bool setInit() override
Definition: LHAHDF5v2.h:66
double mur
The renormalization scale used for this event.
Definition: LHEF3.h:304
Header for classes to set beam momentum and interaction vertex spread.
Definition: Analysis.h:20
Info * infoPtr
Pointer to various information on the generation.
Definition: LesHouches.h:218
bool setEvent(int idProc=0) override
Read an event.
Definition: LHAHDF5v2.h:93
Event struct.
Definition: LHEH5v2.h:121
LHAupH5v2(HighFive::File *h5fileIn, size_t firstEventIn, size_t readSizeIn, bool normalize)
Definition: LHAHDF5v2.h:28
Particle struct.
Definition: LHEH5.h:65