Version: SMASH-3.2
smash::RivetOutput Class Reference

#include <rivetoutput.h>

SMASH output to Rivet analyses.

This class passes HepMC events to Rivet for analysis. The event is kept in-memory which significantly speeds up processing (at last a factor 10) as compared to writing the HepMC event to disk or pipe and then decoding in Rivet.

More details of the output format can be found in the User Guide.

Definition at line 37 of file rivetoutput.h.

Inheritance diagram for smash::RivetOutput:
smash::HepMcInterface smash::OutputInterface

Classes

struct  Proxy
 A proxy object that wraps all Rivet::AnalysisHandler calls in an environment where FP errors are disabled. More...
 

Public Member Functions

 RivetOutput (const std::filesystem::path &path, std::string name, const bool full_event, const RivetOutputParameters &rivet_par)
 Create Rivet output. More...
 
 ~RivetOutput ()
 Destructor. More...
 
void at_eventend (const Particles &particles, const EventLabel &event_label, const EventInfo &event) override
 Add the final particles information of an event to the central vertex. More...
 
void add_analysis (const std::string &name)
 Add an analysis or analyses to Rivet. More...
 
void add_path (const std::string &path)
 Add a load path to the Rivet handler. More...
 
void add_preload (const std::string &file)
 Add preload to Rivet handler. More...
 
void set_ignore_beams (bool ignore=true)
 Do not insist on appropriate beams for analyses. More...
 
void set_log_level (const std::string &name, const std::string &level)
 Set log level in Rivet. More...
 
void set_cross_section (double xs, double xserr)
 Set X-section. More...
 
- Public Member Functions inherited from smash::HepMcInterface
 HepMcInterface (const std::string &name, const bool full_event)
 Create HepMC particle event in memory. More...
 
void at_eventstart (const Particles &particles, const EventLabel &event_label, const EventInfo &event) override
 Add the initial particles information of an event to the central vertex. More...
 
void at_interaction (const Action &action, const double density) override
 Writes collisions to event. More...
 
- Public Member Functions inherited from smash::OutputInterface
 OutputInterface (std::string name)
 Construct output interface. More...
 
virtual ~OutputInterface ()=0
 Pure virtual destructor to make class abstract and prevent its instantiation. More...
 
virtual void at_eventstart (const std::vector< Particles > &, int)
 Output launched at event start after initialization, when particles are generated but not yet propagated. More...
 
virtual void at_eventstart (const int, const ThermodynamicQuantity, const DensityType, RectangularLattice< DensityOnLattice >)
 Output launched at event start after initialization, when particles are generated but not yet propagated. More...
 
virtual void at_eventstart (const int, const ThermodynamicQuantity, const DensityType, RectangularLattice< EnergyMomentumTensor >)
 Output launched at event start after initialization, when particles are generated but not yet propagated. More...
 
virtual void at_eventend (const ThermodynamicQuantity)
 Output launched at event end. More...
 
virtual void at_eventend (const std::vector< Particles > &, const int)
 Output launched at event end. More...
 
virtual void at_intermediate_time (const Particles &, const std::unique_ptr< Clock > &, const DensityParameters &, const EventLabel &, const EventInfo &)
 Output launched after every N'th time-step. More...
 
virtual void at_intermediate_time (const std::vector< Particles > &, const std::unique_ptr< Clock > &, const DensityParameters &)
 Output launched after every N'th timestep. More...
 
virtual void thermodynamics_output (const ThermodynamicQuantity, const DensityType, RectangularLattice< DensityOnLattice > &)
 Output to write thermodynamics from the lattice. More...
 
virtual void thermodynamics_output (const ThermodynamicQuantity, const DensityType, RectangularLattice< EnergyMomentumTensor > &)
 Output to write energy-momentum tensor and related quantities from the lattice. More...
 
virtual void thermodynamics_lattice_output (RectangularLattice< DensityOnLattice > &, const double)
 Output to write thermodynamics from the lattice. More...
 
virtual void thermodynamics_lattice_output (RectangularLattice< DensityOnLattice > &, const double, const std::vector< Particles > &, const DensityParameters &)
 Output to write thermodynamics from the lattice. More...
 
virtual void thermodynamics_lattice_output (const ThermodynamicQuantity, RectangularLattice< EnergyMomentumTensor > &, const double)
 Output to write energy-momentum tensor and related quantities from the lattice. More...
 
virtual void thermodynamics_output (const GrandCanThermalizer &)
 Output to write energy-momentum tensor and related quantities from the thermalizer class. More...
 
virtual void fields_output (const std::string, const std::string, RectangularLattice< std::pair< ThreeVector, ThreeVector >> &)
 Write fields in vtk output Fields are a pair of threevectors for example electric and magnetic field. More...
 
bool is_dilepton_output () const
 Get, whether this is the dilepton output? More...
 
bool is_photon_output () const
 Get, whether this is the photon output? More...
 
bool is_IC_output () const
 Get, whether this is the IC output? More...
 
const char * to_string (const ThermodynamicQuantity tq)
 Convert thermodynamic quantities to strings. More...
 
const char * to_string (const DensityType dens_type)
 Convert density types to strings. More...
 

Private Member Functions

void setup (const RivetOutputParameters &params)
 Setup Rivet using SMASH configuration parameters. More...
 
Proxy analysis_handler_proxy ()
 Return a proxy that temporarily disables FP exceptions. More...
 

Private Attributes

std::shared_ptr< Rivet::AnalysisHandler > handler_
 Rivet analysis handler. More...
 
std::filesystem::path filename_
 Output file. More...
 
bool need_init_
 Whether we need initialisation. More...
 

Additional Inherited Members

- Public Types inherited from smash::HepMcInterface
using AZ = std::pair< int, int >
 Pair of Atomic weight and number. More...
 
- Protected Types inherited from smash::HepMcInterface
enum  Status { beam = 4 , fnal = 1 , dcy = 2 , off = 100 }
 HepMC status codes. More...
 
using IdMap = std::map< int, HepMC3::GenParticlePtr >
 Type of mapping from SMASH ID to HepMC ID. More...
 
using CollCounter = std::valarray< int >
 Counter of collitions per incoming particle. More...
 
- Protected Member Functions inherited from smash::HepMcInterface
void clear ()
 Clear before an event. More...
 
int get_status (const ProcessType &t) const
 Convert SMASH process type to HepMC status. More...
 
HepMC3::GenParticlePtr make_gen (int pid, int status, const smash::FourVector &mom, double mass=-1)
 Make an HepMC particle. More...
 
HepMC3::GenParticlePtr make_register (const ParticleData &p, int status=Status::fnal)
 Find particle in mapping or generate it. More...
 
HepMC3::GenParticlePtr find_or_make (const ParticleData &p, int status=Status::fnal, bool force_new=false)
 Find particle in mapping or generate it. More...
 
int ion_pdg (const AZ &az) const
 Encode ion PDG. More...
 
- Protected Attributes inherited from smash::HepMcInterface
HepMC3::GenEvent event_
 The event. More...
 
HepMC3::GenHeavyIonPtr ion_
 The heavy-ion structure. More...
 
HepMC3::GenCrossSectionPtr xs_
 Dummy cross-section. More...
 
HepMC3::GenVertexPtr ip_
 The interaction point. More...
 
IdMap map_
 Mapping from ID to particle. More...
 
CollCounter coll_
 Collision counter. More...
 
int ncoll_
 counter of binary collisions (e.g., where both incoming particles are from the beams. More...
 
int ncoll_hard_
 counter of hard binary collisions (e.g., where both incoming particles are from the beams. More...
 
bool full_event_
 Whether the full event or only final-state particles are in the output. More...
 
- Protected Attributes inherited from smash::OutputInterface
const bool is_dilepton_output_
 Is this the dilepton output? More...
 
const bool is_photon_output_
 Is this the photon output? More...
 
const bool is_IC_output_
 Is this the IC output? More...
 

Constructor & Destructor Documentation

◆ RivetOutput()

smash::RivetOutput::RivetOutput ( const std::filesystem::path &  path,
std::string  name,
const bool  full_event,
const RivetOutputParameters rivet_par 
)

Create Rivet output.

Parameters
[in]pathOutput path.
[in]nameName of the output.
[in]full_eventWhether the full event or only final-state particles are printed in the output
[in]rivet_parRivet parameters from SMASH configuration

Definition at line 96 of file rivetoutput.cc.

99  : HepMcInterface(name, full_event),
100  handler_(),
101  filename_(path / (name + ".yoda")),
102  need_init_(true) {
103  handler_ = std::make_shared<Rivet::AnalysisHandler>();
104  setup(rivet_par);
105 }
HepMcInterface(const std::string &name, const bool full_event)
Create HepMC particle event in memory.
std::filesystem::path filename_
Output file.
Definition: rivetoutput.h:127
std::shared_ptr< Rivet::AnalysisHandler > handler_
Rivet analysis handler.
Definition: rivetoutput.h:125
bool need_init_
Whether we need initialisation.
Definition: rivetoutput.h:129
void setup(const RivetOutputParameters &params)
Setup Rivet using SMASH configuration parameters.
Definition: rivetoutput.cc:173

◆ ~RivetOutput()

smash::RivetOutput::~RivetOutput ( )

Destructor.

Finalises the analzyses and writes out results to file

Definition at line 107 of file rivetoutput.cc.

107  {
108  logg[LOutput].debug() << "Writing Rivet results to " << filename_ << "\n";
109  analysis_handler_proxy()->finalize();
110  analysis_handler_proxy()->writeData(filename_.string());
111 }
Proxy analysis_handler_proxy()
Return a proxy that temporarily disables FP exceptions.
Definition: rivetoutput.h:122
std::array< einhard::Logger<>, std::tuple_size< LogArea::AreaTuple >::value > logg
An array that stores all pre-configured Logger objects.
Definition: logging.cc:40
static constexpr int LOutput

Member Function Documentation

◆ at_eventend()

void smash::RivetOutput::at_eventend ( const Particles particles,
const EventLabel event_label,
const EventInfo event 
)
overridevirtual

Add the final particles information of an event to the central vertex.

Store impact parameter and write event.

Parameters
[in]particlesCurrent list of particles.
[in]event_labelEvent/ensemble numbers
[in]eventEvent info, see event_info

Reimplemented from smash::HepMcInterface.

Definition at line 113 of file rivetoutput.cc.

115  {
116  HepMcInterface::at_eventend(particles, event_label, event);
117 
118  // Initialize Rivet on first event
119  if (need_init_) {
120  logg[LOutput].debug() << "Initialising Rivet\n";
121  need_init_ = false;
123  }
124 
125  logg[LOutput].debug() << "Analyzing event " << event_label.event_number
126  << "\n";
127  // Let Rivet analyse the event
128  analysis_handler_proxy()->analyze(event_);
129 }
void at_eventend(const Particles &particles, const EventLabel &event_label, const EventInfo &event) override
Add the final particles information of an event to the central vertex.
HepMC3::GenEvent event_
The event.

◆ add_analysis()

void smash::RivetOutput::add_analysis ( const std::string &  name)

Add an analysis or analyses to Rivet.

Parameters
[in]nameName of analysis

Definition at line 131 of file rivetoutput.cc.

131  {
132  analysis_handler_proxy()->addAnalysis(name);
133 }

◆ add_path()

void smash::RivetOutput::add_path ( const std::string &  path)

Add a load path to the Rivet handler.

Definition at line 135 of file rivetoutput.cc.

135  {
136  Rivet::addAnalysisLibPath(path);
137  Rivet::addAnalysisDataPath(path);
138 }

◆ add_preload()

void smash::RivetOutput::add_preload ( const std::string &  file)

Add preload to Rivet handler.

Definition at line 140 of file rivetoutput.cc.

140  {
141  analysis_handler_proxy()->readData(file);
142 }

◆ set_ignore_beams()

void smash::RivetOutput::set_ignore_beams ( bool  ignore = true)

Do not insist on appropriate beams for analyses.

Definition at line 144 of file rivetoutput.cc.

144  {
145  logg[LOutput].info() << "Ignore beams? " << (ignore ? "yes" : "no") << "\n";
146  analysis_handler_proxy()->setIgnoreBeams(ignore);
147 }

◆ set_log_level()

void smash::RivetOutput::set_log_level ( const std::string &  name,
const std::string &  level 
)

Set log level in Rivet.

Definition at line 149 of file rivetoutput.cc.

150  {
151  std::string fname(name);
152  if (fname.rfind("Rivet", 0) != 0) {
153  fname = "Rivet." + fname;
154  }
155 
156  auto upcase = [](const std::string& s) {
157  std::string out(s);
158  std::transform(out.begin(), out.end(), out.begin(),
159  [](char c) { return std::toupper(c); });
160  return out;
161  };
162 
163  try {
164  Rivet::Log::setLevel(fname, Rivet::Log::getLevelFromName(upcase(level)));
165  } catch (...) {
166  }
167 }

◆ set_cross_section()

void smash::RivetOutput::set_cross_section ( double  xs,
double  xserr 
)

Set X-section.

Parameters
[in]xsCross-section value in pb
[in]xserrUncertainty on cross-section in pb

Definition at line 169 of file rivetoutput.cc.

169  {
170  analysis_handler_proxy()->setCrossSection(xs, xserr, true);
171 }

◆ setup()

void smash::RivetOutput::setup ( const RivetOutputParameters params)
private

Setup Rivet using SMASH configuration parameters.

Parameters
[in]paramsThe SMASH parameters already extracted from the input configuration

Definition at line 173 of file rivetoutput.cc.

173  {
174  logg[LOutput].debug() << "Setting up Rivet output:\n";
175 
176  // Paths to analyses libraries and data
177  if (params.paths) {
178  logg[LOutput].info() << "Processing paths\n";
179  for (auto p : params.paths.value())
180  add_path(p);
181  }
182 
183  // Data files to pre-load e.g., for centrality configurations
184  if (params.preloads) {
185  logg[LOutput].info() << "Processing preloads\n";
186  for (auto p : params.preloads.value())
187  add_preload(p);
188  }
189 
190  // Analyses (including options) to add to run
191  if (params.analyses) {
192  logg[LOutput].info() << "Processing analyses\n";
193  for (auto p : params.analyses.value())
194  add_analysis(p);
195  }
196 
197  // Whether Rivet should ignore beams
198  set_ignore_beams(params.ignore_beams);
199 
200  // Cross sections
201  if (params.cross_sections) {
202  set_cross_section(params.cross_sections.value()[0],
203  params.cross_sections.value()[1]);
204  }
205 
206  // Logging in Rivet
207  if (params.logs) {
208  for (auto nl : params.logs.value())
209  set_log_level(nl.first, nl.second);
210  }
211 
212  // Treatment of event weights in Rivet
213  if (params.any_weight_parameter_was_given) {
214  // Do not care about multi weights
215  if (params.no_multi_weight) {
216  analysis_handler_proxy()->skipMultiWeights(
217  params.no_multi_weight.value());
218  }
219 
220  // Set nominal weight name
221  if (params.nominal_weight_name) {
222  analysis_handler_proxy()->setNominalWeightName(
223  params.nominal_weight_name.value());
224  }
225 
226  // Set cap (maximum) on weights
227  if (params.cap_on_weights) {
228  analysis_handler_proxy()->setWeightCap(params.cap_on_weights.value());
229  }
230 
231  // Whether to smear for NLO calculations
232  if (params.nlo_smearing) {
233  analysis_handler_proxy()->setNLOSmearing(params.nlo_smearing.value());
234  }
235 
236  // Select which weights to enable
237  if (params.to_be_enabled_weights) {
238  std::stringstream s;
239  int comma = 0;
240  for (auto w : params.to_be_enabled_weights.value())
241  s << (comma++ ? "," : "") << w;
242  analysis_handler_proxy()->selectMultiWeights(s.str());
243  }
244 
245  // Select weights to disable
246  if (params.to_be_disabled_weights) {
247  std::stringstream s;
248  int comma = 0;
249  for (auto w : params.to_be_disabled_weights.value())
250  s << (comma++ ? "," : "") << w;
251  analysis_handler_proxy()->deselectMultiWeights(s.str());
252  }
253  }
254  logg[LOutput].debug() << "Setup of Rivet output done.\n";
255 }
void add_path(const std::string &path)
Add a load path to the Rivet handler.
Definition: rivetoutput.cc:135
void add_analysis(const std::string &name)
Add an analysis or analyses to Rivet.
Definition: rivetoutput.cc:131
void set_cross_section(double xs, double xserr)
Set X-section.
Definition: rivetoutput.cc:169
void add_preload(const std::string &file)
Add preload to Rivet handler.
Definition: rivetoutput.cc:140
void set_log_level(const std::string &name, const std::string &level)
Set log level in Rivet.
Definition: rivetoutput.cc:149
void set_ignore_beams(bool ignore=true)
Do not insist on appropriate beams for analyses.
Definition: rivetoutput.cc:144
constexpr int p
Proton.

◆ analysis_handler_proxy()

Proxy smash::RivetOutput::analysis_handler_proxy ( )
inlineprivate

Return a proxy that temporarily disables FP exceptions.

Definition at line 122 of file rivetoutput.h.

122 { return Proxy(handler_); }

Member Data Documentation

◆ handler_

std::shared_ptr<Rivet::AnalysisHandler> smash::RivetOutput::handler_
private

Rivet analysis handler.

Definition at line 125 of file rivetoutput.h.

◆ filename_

std::filesystem::path smash::RivetOutput::filename_
private

Output file.

Definition at line 127 of file rivetoutput.h.

◆ need_init_

bool smash::RivetOutput::need_init_
private

Whether we need initialisation.

Definition at line 129 of file rivetoutput.h.


The documentation for this class was generated from the following files: