Something went wrong on our end
-
Marc Pelizaeus authoredd3454515
JpsiGamKsKlKKReader.cc 1.75 KiB
#include "Examples/JpsiGamKsKlKK/JpsiGamKsKlKKReader.hh"
#include "Event/EventList.hh"
#include "Event/Event.hh"
#include "ErrLogger/ErrLogger.hh"
JpsiGamKsKlKKReader::JpsiGamKsKlKKReader()
{}
JpsiGamKsKlKKReader::JpsiGamKsKlKKReader(const std::vector<std::string>& files, int particles, int skip):
numParticles(particles),
linesToSkip(skip),
_useMassRange(false),
_massRange(std::make_pair(0.,10.) )
{
if (0 == files.size()) {
Alert << "empty list of event files" ; // << endmsg;
exit(1);
}
std::vector<std::string>::const_iterator iter = files.begin();
for (; iter != files.end(); ++iter)
fileNames.push_back(*iter);
currentFile = fileNames.begin();
}
JpsiGamKsKlKKReader::~JpsiGamKsKlKKReader()
{}
bool JpsiGamKsKlKKReader::fillAll(EventList& evtList)
{
while (currentFile != fileNames.end()) {
currentStream.open(currentFile->c_str());
if (!currentStream) {
Alert << "can not open " << *currentFile ; // << endmsg;
exit(1);
}
while (!currentStream.eof()) {
double e,px,py,pz;
Event* newEvent = new Event();
int parts;
Vector4<double> fv2Phi(0,0,0,0); //phi phi four-vector
for (parts = 0; parts < numParticles; parts++) {
currentStream >> px >> py >> pz >> e;
newEvent->addParticle(e,px,py,pz);
Vector4<double> tmp = newEvent->p4(parts);
if(parts>0) fv2Phi= fv2Phi+tmp;
}
if(_useMassRange){
if(fv2Phi.Mass()<_massRange.first || fv2Phi.Mass()>_massRange.second ) continue;
}
if (!currentStream.fail()) {
evtList.add(newEvent);
for (parts = 0; parts < linesToSkip; parts++)
currentStream >> px >> py >> pz >> e;
}
}
currentStream.close();
++currentFile;
}
evtList.rewind();
return true; // success
}