9 #include <generators/hepmc/HepMCReader.h> 
   10 #include <framework/gearbox/Unit.h> 
   11 #include <framework/gearbox/Const.h> 
   12 #include <framework/logging/Logger.h> 
   14 #include <HepMC/IO_GenEvent.h> 
   16 #include <Math/Vector4D.h> 
   22 void HepMCReader::open(
const string& filename)
 
   24   B2INFO(
"Reading HEPMC inputfile at " << filename);
 
   25   m_input.open(filename.c_str());
 
   26   if (!m_input) { 
throw (HepMCCouldNotOpenFileError() << filename); }
 
   29 int HepMCReader::nextValidEvent(HepMC::GenEvent& evt)
 
   32   int eventID = evt.event_number();
 
   34   if (eventID < m_minEvent) {
 
   35     while (!(eventID >= m_minEvent)) {
 
   37       eventID = evt.event_number();
 
   40   if (eventID >= m_maxEvent) { 
return -999; } 
 
   50   eventID = nextValidEvent(evt); 
 
   51   if (eventID == -999) { 
throw HepMCInvalidEventError(); }
 
   54   const int nparticles = evt.particles_size();
 
   56   B2DEBUG(20, 
"Found eventID " << eventID << 
" with " << nparticles << 
" particles.");
 
   58   if (nparticles <= 0) {
 
   59     throw (HepMCInvalidEventError());
 
   61   const int event_offset = graph.
size(); 
 
   63   for (
int i = 0; i < nparticles; i++) {
 
   67   std::unordered_map<int, int> hash_index_map;
 
   68   HepMC::GenEvent::particle_iterator tmp_particle = evt.particles_begin();
 
   69   for (
int i = 0; i < nparticles; ++i) {
 
   71     const int hash = (*tmp_particle)->barcode();
 
   72     hash_index_map[hash] = i;
 
   75   const double len_conv = HepMC::Units::conversion_factor(evt.length_unit(), HepMC::Units::CM); 
 
   76   const double mom_conv = HepMC::Units::conversion_factor(evt.momentum_unit(), HepMC::Units::GEV); 
 
   77   auto read_particle = evt.particles_begin();
 
   79   for (
int i = 0; i < nparticles; ++i) {
 
   80     auto* decay_vertex = (*read_particle)->end_vertex();
 
   81     auto* production_vertex = (*read_particle)->production_vertex();
 
   85     const int status = (*read_particle)->status();
 
   86     const bool isFinalstate =  !decay_vertex && status == 1;
 
   87     const bool isVirtual  = (status == 4) || (status == 21) || (status == 22) || (status == 23) || (status == 51) || (status == 52)
 
   89     const int pdg_code = (*read_particle)->pdg_id() ;
 
   90     const double mass = (*read_particle)->generated_mass() * mom_conv;
 
   91     auto const mom_tmp = (*read_particle)->momentum();
 
   93     const HepMC::FourVector momentum(
 
   94       mom_tmp.x()*mom_conv * Unit::GeV,
 
   95       mom_tmp.y()*mom_conv * Unit::GeV,
 
   96       mom_tmp.z()*mom_conv * Unit::GeV,
 
   97       mom_tmp.t()*mom_conv * Unit::GeV
 
  100     B2DEBUG(20, 
"Read particle: status " << status << 
" isFinal " << isFinalstate << 
" isVirtual " << isVirtual << 
" pdg " << pdg_code
 
  101             << 
" mass " << mass << 
" px " << momentum.x() << 
" py " << momentum.y() << 
" px " << momentum.z() << 
" E " << momentum.t());
 
  102     p.addStatus(MCParticle::c_PrimaryParticle);  
 
  104     p.setMomentum(ROOT::Math::XYZVector(momentum.x(), momentum.y(), momentum.z()));
 
  105     p.setEnergy(momentum.t());
 
  107     if (production_vertex) {
 
  108       const auto pos = production_vertex->position();
 
  109       p.setProductionVertex(ROOT::Math::XYZVector(pos.x(), pos.y(), pos.z()) * len_conv * Unit::cm);
 
  110       p.setProductionTime(pos.t() * len_conv * Unit::cm / Const::speedOfLight);
 
  111       p.setValidVertex(
true);
 
  120     if (production_vertex) {
 
  121       if (production_vertex->particles_in_const_begin() != production_vertex->particles_in_const_end()) {
 
  122         auto parent = production_vertex->particles_begin(HepMC::parents);
 
  123         const int parent_index_in_graph = hash_index_map[(*parent)->barcode()];
 
  124         p.comesFrom(graph[event_offset + parent_index_in_graph]);
 
  129       ROOT::Math::PxPyPzEVector p4 = p.get4Vector();
 
  130       p4.SetPz(-1.0 * p4.Pz());
 
  136     if (i < m_nVirtual || isVirtual) {
 
  142   B2DEBUG(20, 
"Returning event id " << eventID);
 
  146 void HepMCReader::readNextEvent(HepMC::GenEvent& evt)
 
  151     if (evt.is_valid()) {
 
  152       const int nparticles = evt.particles_size();
 
  153       B2DEBUG(20, 
"Found valid event.i N particles " << nparticles);
 
  156       B2DEBUG(20, 
"The next event was invalid. Will stop reading now.");
 
  162 int HepMCReader::countEvents(
const std::string& filename)
 
  165   HepMC::IO_GenEvent ascii_in(filename.c_str(), std::ios::in);
 
  167   HepMC::GenEvent* evt = ascii_in.read_next_event();
 
  169     evt = ascii_in.read_next_event();
 
  172   B2INFO(
"Counted " << count  << 
" events in  " << filename << 
".");
 
Class to represent Particle data in graph.
Class to build, validate and sort a particle decay chain.
size_t size() const
Return the number of particles in the graph.
GraphParticle & addParticle()
Add new particle to the graph.
Abstract base class for different kinds of events.