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.