Newer
Older
Markus Frank
committed
//==========================================================================
Markus Frank
committed
//--------------------------------------------------------------------------
// Copyright (C) Organisation europeenne pour la Recherche nucleaire (CERN)
Markus Frank
committed
// All rights reserved.
Markus Frank
committed
// For the licensing terms see $DD4hepINSTALL/LICENSE.
// For the list of contributors see $DD4hepINSTALL/doc/CREDITS.
//
// Author : M.Frank
//
//==========================================================================
#ifndef DD4HEP_DDG4_LCIOFILEREADER_H
#define DD4HEP_DDG4_LCIOFILEREADER_H
#include "LCIOEventReader.h"
#include "lcio.h"
using namespace lcio ;
// Forward declarations
namespace IO { class LCReader; }
/// Namespace for the AIDA detector description toolkit
namespace DD4hep {
/// Namespace for the Geant4 based simulation part of the AIDA detector description toolkit
namespace Simulation {
/// Base class to read lcio event files
/**
* \author P.Kostka (main author)
* \author M.Frank (code reshuffeling into new DDG4 scheme)
* \version 1.0
* \ingroup DD4HEP_SIMULATION
class LCIOFileReader : public LCIOEventReader {
protected:
/// Reference to reader object
IO::LCReader* m_reader;
LCIOFileReader(const std::string& nam);
virtual ~LCIOFileReader();
/// Read an event and fill a vector of MCParticles.
Markus Frank
committed
virtual EventReaderStatus readParticleCollection(int event_number, EVENT::LCCollection** particles);
#endif // DD4HEP_DDG4_LCIOFILEREADER_H
#include "DDG4/Factories.h"
#include "UTIL/ILDConf.h"
using namespace DD4hep::Simulation;
DECLARE_GEANT4_EVENT_READER_NS(DD4hep::Simulation,LCIOFileReader)
Markus Frank
committed
DD4hep::Simulation::LCIOFileReader::LCIOFileReader(const std::string& nam)
: LCIOEventReader(nam), m_nEvt(0)
m_reader = ::lcio::LCFactory::getInstance()->createLCReader(LCReader::directAccess);
printout(INFO,"LCIOFileReader","Created file reader. Try to open input %s",nam.c_str());
m_directAccess = false;
DD4hep::Simulation::LCIOFileReader::~LCIOFileReader() {
DD4hep::deletePtr(m_reader);
/// Read an event and fill a vector of MCParticles.
Geant4EventReader::EventReaderStatus
DD4hep::Simulation::LCIOFileReader::readParticleCollection(int event_number, EVENT::LCCollection** particles) {
// ::lcio::LCEvent* evt = m_reader->readEvent(/*runNumber*/ 0, event_number);
// fg: direct access does not work if run number is different from 0 and/or event numbers are not stored consequutively
if( m_nEvt == 0 && event_number != 0 ) {
m_reader->skipNEvents( event_number ) ;
printout(INFO,"LCIOFileReader","Skipping the first %d events ", event_number );
}
::lcio::LCEvent* evt = m_reader->readNextEvent(); // simply read the events sequentially
++m_nEvt ;
*particles = evt->getCollection(LCIO::MCPARTICLE);
if ( *particles ) {
printout(INFO,"LCIOFileReader","read collection %s from event %d in run %d ",
LCIO::MCPARTICLE, evt->getEventNumber(), evt->getRunNumber());
return EVENT_READER_OK;
}
return EVENT_READER_ERROR;