9 #include <generators/modules/TouschekTURTLEInputModule.h> 
   11 #include <framework/datastore/StoreArray.h> 
   13 #include <framework/gearbox/Gearbox.h> 
   14 #include <framework/gearbox/GearDir.h> 
   15 #include <framework/gearbox/Unit.h> 
   16 #include <framework/utilities/FileSystem.h> 
   18 #include <generators/touschek/TouschekReaderTURTLE.h> 
   34 TouschekTURTLEInputModule::TouschekTURTLEInputModule() : 
Module()
 
   37   setDescription(
"Reads the Touschek data from a TURTLE file and stores it into the MCParticle collection.");
 
   43   addParam(
"ReadHER", 
m_readHER, 
"Set to false to skip reading the HER data.", 
true);
 
   44   addParam(
"ReadLER", 
m_readLER, 
"Set to false to skip reading the LER data.", 
true);
 
   46            "Indicates the z-coordinate of the TURTLE particles in the file. (default is 50cm, 400cm is also implemented.)", 50.0);
 
   48            "The maximum number of particles per event that should be read. -1 means all of the particles are read.", -1);
 
   69     B2FATAL(
"The Touschek Turtle input module requires a valid Gearbox. Please make sure you have the Gearbox module added to your path.");
 
   78     B2ERROR(
"Parameter <FilenameHER>: Could not open the file. The filename " << 
m_filenameHER << 
" does not exist !");
 
   82     B2ERROR(
"Parameter <FilenameLER>: Could not open the file. The filename " << 
m_filenameLER << 
" does not exist !");
 
   88   double angleher = irDir.
getAngle(
"AngleHER");
 
   89   double angleler = irDir.
getAngle(
"AngleLER");
 
   98     int readHERParticles = 0;
 
   99     int readLERParticles = 0;
 
  106     if ((readHERParticles > 0) || (readLERParticles > 0)) {
 
  110       B2INFO(
"Read " << readHERParticles << 
" e- particles (HER).");
 
  111       B2INFO(
"Read " << readLERParticles << 
" e+ particles (LER).");
 
  113   } 
catch (runtime_error& exc) {
 
static bool fileExists(const std::string &filename)
Check if the file with given filename exists.
GearDir is the basic class used for accessing the parameter store.
Class to build, validate and sort a particle decay chain.
@ c_checkCyclic
Check for cyclic dependencies.
@ c_setDecayInfo
Set decay time and vertex.
void generateList(const std::string &name="", int options=c_setNothing)
Generates the MCParticle list and stores it in the StoreArray with the given name.
void setDescription(const std::string &description)
Sets the description of the module.
void setPropertyFlags(unsigned int propertyFlags)
Sets the flags for the module properties.
@ c_Input
This module is an input module (reads data).
bool registerInDataStore(DataStore::EStoreFlags storeFlags=DataStore::c_WriteOut)
Register the object/array in the DataStore.
Class to read Touschek files and store their content in a MCParticle graph.
void open(const std::string &filename)
Opens an ascii file and prepares it for reading.
int getParticles(int number, MCParticleGraph &graph)
Reads the specified number of particles from the file and stores the result in the given MCParticle g...
static const double deg
degree to radians
double getAngle(const std::string &path="") const noexcept(false)
Get the parameter path as a double converted to the standard angle unit.
static Gearbox & getInstance()
Return reference to the Gearbox instance.
void addParam(const std::string &name, T ¶mVariable, const std::string &description, const T &defaultValue)
Adds a new parameter to the module.
GearDir getDetectorComponent(const std::string &component)
Return GearDir representing a given DetectorComponent.
#define REG_MODULE(moduleName)
Register the given module (without 'Module' suffix) with the framework.
Abstract base class for different kinds of events.