Belle II Software
release-08-01-10
|
Class to read LHE files and store the content in a MCParticle graph. More...
#include <LHEReader.h>
Public Member Functions | |
BELLE2_DEFINE_EXCEPTION (LHECouldNotOpenFileError, "Could not open file %1% !") | |
Exception is thrown if the LHE file could not be opened. | |
BELLE2_DEFINE_EXCEPTION (LHEInvalidDaughterIndicesError, "Line %1%: Invalid daughter indices d1=%2%, d2=%3%, N=%4% (0<=d1<=d2<=N required)") | |
Exception is thrown if the given indices of the daughters are not valid. | |
BELLE2_DEFINE_EXCEPTION (LHEHeaderNotValidError, "Line %1%: Event header not understood: %2%") | |
Exception is thrown if the header specifying the event header could not be parsed. | |
BELLE2_DEFINE_EXCEPTION (LHEConvertFieldError, "Line %1%: Could not convert field %2%: %3%") | |
Exception is thrown if a field in the LHE file could not be converted to a number. | |
BELLE2_DEFINE_EXCEPTION (LHEParticleFormatError, "Line %1%: Particle format not understood, got %2% fields !") | |
Exception is thrown if the format of a line of the LHE file could not be parsed. | |
BELLE2_DEFINE_EXCEPTION (LHEEmptyEventError, "Line %1%: Number of particles in event is %2% ! (This could mean EOF is reached.) ") | |
Exception is thrown if the number of particles for this event is 0 or less. More... | |
LHEReader () | |
Constructor. | |
~LHEReader () | |
Destructor. | |
void | open (const std::string &filename) |
Opens an ascii file and prepares it for reading. More... | |
void | closeCurrentInputFile () |
Closes the current input file to allow opening the next one. | |
int | getEvent (MCParticleGraph &graph, double &weight) |
Reads the next event and stores the result in the given MCParticle graph. More... | |
bool | skipEvents (int n) |
Skips a given number of events. More... | |
void | setInitialIndex (int index) |
Set the maximum index of particles in each event that must be set as c_Initial (1-based). More... | |
void | setVirtualIndex (int index) |
Set the maximum index of particles in each event that must be set as c_IsVirtual (1-based). More... | |
Public Attributes | |
bool | m_wrongSignPz |
Bool to indicate that HER and LER were swapped. | |
double | m_meanDecayLength = 0. |
Mean lifetime*c of displaced particle. | |
double | m_Rmin = 0. |
Minimum of vertex distance to IP. | |
double | m_Rmax = 0. |
Maximum of vertex distance to IP. | |
int | m_pdgDisplaced = 0 |
PDG code of the displaced particle being studied. | |
Protected Types | |
typedef boost::tokenizer< boost::char_separator< char > > | tokenizer |
Just a typedef for simple use of the boost::tokenizer to split the lines. | |
Protected Member Functions | |
std::string | getLine () |
Returns the current line from the LHE ascii file. More... | |
int | readEventHeader (double &eventWeight) |
Reads the event header from the hepevt file. More... | |
int | readParticle (MCParticleGraph::GraphParticle &particle) |
Reads the information for a single particle from the LHE file. More... | |
Protected Attributes | |
int | m_lineNr |
The current line number within the ascii file. | |
std::ifstream | m_input |
The input stream of the ascii file. | |
int | m_indexInitial |
Maximum index of particles in each event that must be set as c_Initial (1-based). | |
int | m_indexVirtual |
Maximum index of particles in each event that must be set as c_IsVirtual (1-based). | |
Static Protected Attributes | |
static const boost::char_separator< char > | sep |
The characters at which to split, defaults to ",; \t". | |
Class to read LHE files and store the content in a MCParticle graph.
The class is very similar to the HepEvt Reader
The events are read sequentially with the option of skipping a certain number of events. Random access of events is not possible.
Definition at line 31 of file LHEReader.h.
BELLE2_DEFINE_EXCEPTION | ( | LHEEmptyEventError | , |
"Line %1%: Number of particles in event is %2% ! (This could mean EOF is reached.) " | |||
) |
Exception is thrown if the number of particles for this event is 0 or less.
int getEvent | ( | MCParticleGraph & | graph, |
double & | weight | ||
) |
Reads the next event and stores the result in the given MCParticle graph.
graph | Reference to the graph which should be filled with the information from the LHE file. |
weight | Reference to the event weight which can be filled from the file. |
Definition at line 36 of file LHEReader.cc.
|
protected |
Returns the current line from the LHE ascii file.
Definition at line 130 of file LHEReader.cc.
void open | ( | const std::string & | filename | ) |
Opens an ascii file and prepares it for reading.
filename | The filename of the LHE ascii file which should be read. |
Definition at line 28 of file LHEReader.cc.
|
protected |
Reads the event header from the hepevt file.
eventWeight | reference to the eventWeight which can both be read from the file. |
Definition at line 149 of file LHEReader.cc.
|
protected |
Reads the information for a single particle from the LHE file.
particle | Reference to the particle which will be filled with the information from the LHE file. |
Definition at line 196 of file LHEReader.cc.
|
inline |
Set the maximum index of particles in each event that must be set as c_Initial (1-based).
[in] | index | Maximum index for c_Initial. |
Definition at line 94 of file LHEReader.h.
|
inline |
Set the maximum index of particles in each event that must be set as c_IsVirtual (1-based).
[in] | index | Maximum index for c_IsVirtual. |
Definition at line 100 of file LHEReader.h.
bool skipEvents | ( | int | n | ) |
Skips a given number of events.
n | The number of events which should be skipped. |
Definition at line 112 of file LHEReader.cc.