Version: SMASH-3.1
Logging Classes and Functions

The interfaces in this group are used for debug and informational console output.

SMASH uses the einhard logging library for debug and info/warn/error output to stdout. This library builds upon the C++ ostream classes and thus uses stream operators for converting objects into a text representation.

The einhard library supports named output streams (which simply means they automatically add the name to the prefix string). We use this feature to define log areas in SMASH that can be configured independently. The einhard::Logger class supports two options: colorization and verbosity. For colorization we stay with the default of auto-detecting a color-terminal. For verbosity we use a Configuration object to set the verbosity of each area independently. This way we have control over the amount of debug output at runtime and without the need to touch the code/recompile.

To output something from your code do the following:

logg[LAreaName].trace(source_location);
logg[LAreaName].debug("particle", p);
logg[LAreaName].warn("Something happened.");
std::array< einhard::Logger<>, std::tuple_size< LogArea::AreaTuple >::value > logg
An array that stores all pre-configured Logger objects.
Definition: logging.cc:39
constexpr int p
Proton.

Note that LAreaName needs to be declared within the smash namespace of the respective file in a form of (using PauliBlocking as an example area):

static constexpr int LPauliBlocking = LogArea::PauliBlocking::id;
static constexpr int LPauliBlocking
Definition: action.cc:27

The einhard::Logger class supports two ways of writing to an output stream: Use stream operators or pass the list of objects for output as parameters. Thus

log.debug("particle: ", p);

and

log.debug() << "particle: " << p;

are equivalent (except for a small optimization opportunity in the former variant, that could make it slightly more efficient). You can see, though, that the former variant is more concise and often much easier to type than the stream operators.

Classes

struct  smash::LogArea::Main
 Log area tag type. More...
 
struct  smash::LogArea::Experiment
 Log area tag type. More...
 
struct  smash::LogArea::Box
 Log area tag type. More...
 
struct  smash::LogArea::Collider
 Log area tag type. More...
 
struct  smash::LogArea::Sphere
 Log area tag type. More...
 
struct  smash::LogArea::Action
 Log area tag type. More...
 
struct  smash::LogArea::InputParser
 Log area tag type. More...
 
struct  smash::LogArea::ParticleType
 Log area tag type. More...
 
struct  smash::LogArea::FindScatter
 Log area tag type. More...
 
struct  smash::LogArea::Clock
 Log area tag type. More...
 
struct  smash::LogArea::DecayModes
 Log area tag type. More...
 
struct  smash::LogArea::Resonances
 Log area tag type. More...
 
struct  smash::LogArea::ScatterAction
 Log area tag type. More...
 
struct  smash::LogArea::Distributions
 Log area tag type. More...
 
struct  smash::LogArea::Propagation
 Log area tag type. More...
 
struct  smash::LogArea::Grid
 Log area tag type. More...
 
struct  smash::LogArea::List
 Log area tag type. More...
 
struct  smash::LogArea::Nucleus
 Log area tag type. More...
 
struct  smash::LogArea::Density
 Log area tag type. More...
 
struct  smash::LogArea::PauliBlocking
 Log area tag type. More...
 
struct  smash::LogArea::Tmn
 Log area tag type. More...
 
struct  smash::LogArea::Fpe
 Log area tag type. More...
 
struct  smash::LogArea::Lattice
 Log area tag type. More...
 
struct  smash::LogArea::Pythia
 Log area tag type. More...
 
struct  smash::LogArea::GrandcanThermalizer
 Log area tag type. More...
 
struct  smash::LogArea::CrossSections
 Log area tag type. More...
 
struct  smash::LogArea::Output
 Log area tag type. More...
 
struct  smash::LogArea::HyperSurfaceCrossing
 Log area tag type. More...
 
struct  smash::LogArea::InitialConditions
 Log area tag type. More...
 
struct  smash::LogArea::ScatterActionMulti
 Log area tag type. More...
 
struct  smash::LogArea::Configuration
 Log area tag type. More...
 
struct  smash::LogArea::Potentials
 Log area tag type. More...
 
struct  smash::LogArea::RootSolver
 Log area tag type. More...
 
struct  smash::FormattingHelper< T >
 
struct  YAML::convert< einhard::LogLevel >
 
struct  smash::PrintParticleListDetailed
 

Macros

#define DECLARE_LOGAREA(id__, name__)
 Declares the necessary interface to identify a new log area. More...
 
#define SMASH_SOURCE_LOCATION    __FILE__ ":" + std::to_string(__LINE__) + " (" + __func__ + ')'
 Hackery that is required to output the location in the source code where the log statement occurs. More...
 

Typedefs

using smash::LogArea::AreaTuple = std::tuple< Main, Experiment, Box, Collider, Sphere, Action, InputParser, ParticleType, FindScatter, Clock, DecayModes, Resonances, ScatterAction, Distributions, Propagation, Grid, List, Nucleus, Density, PauliBlocking, Tmn, Fpe, Lattice, Pythia, GrandcanThermalizer, CrossSections, Output, HyperSurfaceCrossing, InitialConditions, ScatterActionMulti, Configuration, Potentials, RootSolver >
 This type collects all existing log areas so they will be created with the correct log level automatically. More...
 

Functions

virtual void smash::Action::format_debug_output (std::ostream &out) const =0
 Writes information about this action to the out stream. More...
 
std::ostream & smash::operator<< (std::ostream &out, const ActionPtr &action)
 Convenience: dereferences the ActionPtr to Action. More...
 
std::ostream & smash::operator<< (std::ostream &out, const ActionList &actions)
 Writes multiple actions to the out stream. More...
 
std::ostream & smash::operator<< (std::ostream &out, const Angles &a)
 Creates output for an Angles object in the form "φ: 0.1294, cos ϑ: 0.423". More...
 
void smash::DecayAction::format_debug_output (std::ostream &out) const override
 Writes information about this decay action to the out stream. More...
 
std::ostream & smash::operator<< (std::ostream &out, const EnergyMomentumTensor &Tmn)
 Prints out 4x4 tensor to the output stream. More...
 
std::ostream & smash::operator<< (std::ostream &os, const FourVector &vec)
 Writes the four components of the vector to the output stream. More...
 
template<int w = 9, int p = w - 3, typename CharT , typename Traits >
std::basic_ostream< CharT, Traits > & smash::field (std::basic_ostream< CharT, Traits > &s)
 Stream modifier to align the next object to a specific width w. More...
 
void smash::create_all_loggers (Configuration config)
 Called from main() right after the Configuration object is fully set up to create all logger objects (as defined by LogArea::AreaTuple) with the correct area names and log levels. More...
 
einhard::LogLevel smash::default_loglevel ()
 
void smash::set_default_loglevel (einhard::LogLevel level)
 Set the default log level (what will be returned from subsequent default_loglevel calls). More...
 
template<typename T >
FormattingHelper< T > smash::format (const T &value, const char *unit, int width=-1, int precision=-1)
 Acts as a stream modifier for std::ostream to output an object with an optional suffix string and with a given field width and precision. More...
 
static Node YAML::convert< einhard::LogLevel >::encode (const einhard::LogLevel &x)
 Convert from einhard::LogLevel to YAML::Node. More...
 
static bool YAML::convert< einhard::LogLevel >::decode (const Node &node, einhard::LogLevel &x)
 Convert from YAML::Node to einhard::LogLevel. More...
 
std::ostream & smash::operator<< (std::ostream &s, const ParticleData &p)
 Writes the state of the particle to the output stream. More...
 
std::ostream & smash::operator<< (std::ostream &out, const ParticleList &particle_list)
 Writes a compact overview over the particles in the particle_list argument to the stream. More...
 
PrintParticleListDetailed smash::detailed (const ParticleList &list)
 Request the ParticleList to be printed in full detail (i.e. More...
 
std::ostream & smash::operator<< (std::ostream &out, const PrintParticleListDetailed &particle_list)
 Writes a detailed overview over the particles in the particle_list argument to the stream. More...
 
std::ostream & smash::operator<< (std::ostream &is, const PdgCode &code)
 Writes the textual representation of the PDG code to the output stream. More...
 
std::ostream & smash::operator<< (std::ostream &os, ProcessType process_type)
 Writes the textual representation of the process_type to the output stream os. More...
 
std::ostream & smash::operator<< (std::ostream &os, const CollisionBranch &cbranch)
 Writes the textual representation of the Collision Branch cbranch to the output stream os. More...
 
void smash::ScatterAction::format_debug_output (std::ostream &out) const override
 Writes information about this scatter action to the out stream. More...
 
std::ostream & smash::operator<< (std::ostream &, const ThreeVector &)
 Writes the three components of the vector to the output stream. More...
 

Variables

const T & smash::FormattingHelper< T >::value
 Value that is being formatted. More...
 
const int smash::FormattingHelper< T >::width
 Output width. More...
 
const int smash::FormattingHelper< T >::precision
 Precision that value is being formatted with. More...
 
const char *const smash::FormattingHelper< T >::unit
 Unit that is attached at the end of value. More...
 
std::array< einhard::Logger<>, std::tuple_size< LogArea::AreaTuple >::value > smash::logg
 An array that stores all pre-configured Logger objects. More...
 

Friends

std::ostream & smash::Action::operator<< (std::ostream &out, const Action &action)
 Dispatches formatting to the virtual Action::format_debug_output function. More...
 
std::ostream & smash::BoxModus::operator<< (std::ostream &out, const BoxModus &m)
 Console output on startup of box specific parameters; writes the initial state for the box to the output stream. More...
 
std::ostream & smash::ColliderModus::operator<< (std::ostream &, const ColliderModus &)
 Writes the initial state for the ColliderModus to the output stream. More...
 
std::ostream & smash::Experiment< Modus >::operator<< (std::ostream &out, const Experiment &e)
 Writes the initial state for the Experiment to the output stream. More...
 
std::ostream & smash::ListModus::operator<< (std::ostream &, const ListModus &)
 Writes the initial state for the List to the output stream. More...
 
std::ostream & smash::FormattingHelper< T >::operator<< (std::ostream &out, const FormattingHelper &h)
 Nicely formatted output. More...
 
std::ostream & smash::Nucleus::operator<< (std::ostream &, const Nucleus &)
 Writes the state of the Nucleus object to the output stream. More...
 
std::ostream & smash::Particles::operator<< (std::ostream &out, const Particles &particles)
 Print effective mass and type name for all particles to the stream. More...
 
std::ostream & smash::ParticleType::operator<< (std::ostream &out, const ParticleType &type)
 Writes all information about the particle type to the output stream. More...
 
std::ostream & smash::SphereModus::operator<< (std::ostream &out, const SphereModus &m)
 Writes the initial state for the Sphere to the output stream. More...
 

Macro Definition Documentation

◆ DECLARE_LOGAREA

#define DECLARE_LOGAREA (   id__,
  name__ 
)
Value:
struct name__ { \
static constexpr int id = id__; \
static constexpr const char *textual() { return #name__; } \
static constexpr int textual_length() { return sizeof(#name__) - 1; } \
}

Declares the necessary interface to identify a new log area.

Definition at line 75 of file logging.h.

◆ SMASH_SOURCE_LOCATION

#define SMASH_SOURCE_LOCATION    __FILE__ ":" + std::to_string(__LINE__) + " (" + __func__ + ')'

Hackery that is required to output the location in the source code where the log statement occurs.

Definition at line 153 of file logging.h.

Typedef Documentation

◆ AreaTuple

Function Documentation

◆ format_debug_output() [1/3]

virtual void smash::Action::format_debug_output ( std::ostream &  out) const
protectedpure virtual

Writes information about this action to the out stream.

Parameters
[out]outout stream to be written to

Implemented in smash::WallcrossingAction, smash::ThermalizationAction, smash::ScatterActionMulti, smash::ScatterAction, smash::HypersurfacecrossingAction, smash::FreeforallAction, and smash::DecayAction.

◆ operator<<() [1/12]

std::ostream& smash::operator<< ( std::ostream &  out,
const ActionPtr &  action 
)
inline

Convenience: dereferences the ActionPtr to Action.

Definition at line 547 of file action.h.

547  {
548  return out << *action;
549 }

◆ operator<<() [2/12]

std::ostream & smash::operator<< ( std::ostream &  out,
const ActionList &  actions 
)

Writes multiple actions to the out stream.

Definition at line 531 of file action.cc.

531  {
532  out << "ActionList {\n";
533  for (const auto &a : actions) {
534  out << "- " << a << '\n';
535  }
536  return out << '}';
537 }

◆ operator<<() [3/12]

std::ostream& smash::operator<< ( std::ostream &  out,
const Angles a 
)
inline

Creates output for an Angles object in the form "φ: 0.1294, cos ϑ: 0.423".

Definition at line 195 of file angles.h.

195  {
196  return out << "φ:" << field << a.phi() << ", cos ϑ:" << field << a.costheta();
197 }
std::basic_ostream< CharT, Traits > & field(std::basic_ostream< CharT, Traits > &s)
Stream modifier to align the next object to a specific width w.

◆ format_debug_output() [2/3]

void smash::DecayAction::format_debug_output ( std::ostream &  out) const
overrideprotectedvirtual

Writes information about this decay action to the out stream.

Implements smash::Action.

Definition at line 110 of file decayaction.cc.

110  {
111  out << "Decay of " << incoming_particles_ << " to " << outgoing_particles_
112  << ", sqrt(s)=" << format(sqrt_s(), "GeV", 11, 9);
113 }
ParticleList outgoing_particles_
Initially this stores only the PDG codes of final-state particles.
Definition: action.h:363
double sqrt_s() const
Determine the total energy in the center-of-mass frame [GeV].
Definition: action.h:271
ParticleList incoming_particles_
List with data of incoming particles.
Definition: action.h:355
FormattingHelper< T > format(const T &value, const char *unit, int width=-1, int precision=-1)
Acts as a stream modifier for std::ostream to output an object with an optional suffix string and wit...
Definition: logging.h:217

◆ operator<<() [4/12]

std::ostream & smash::operator<< ( std::ostream &  out,
const EnergyMomentumTensor Tmn 
)

Prints out 4x4 tensor to the output stream.

Parameters
[in]outLocation of output
[in]TmnEnergy-momentum tensor

Definition at line 160 of file energymomentumtensor.cc.

160  {
161  out.width(12);
162  for (size_t mu = 0; mu < 4; mu++) {
163  for (size_t nu = 0; nu < 4; nu++) {
164  out << std::setprecision(3) << std::setw(12) << std::fixed
165  << Tmn[EnergyMomentumTensor::tmn_index(mu, nu)];
166  }
167  out << std::endl;
168  }
169  return out;
170 }
@ Tmn
Energy-momentum tensor in lab frame.

◆ operator<<() [5/12]

std::ostream & smash::operator<< ( std::ostream &  os,
const FourVector vec 
)

Writes the four components of the vector to the output stream.

Parameters
[in]osThe ostream into which to output
[in]vecThe FourVector to write into os

Definition at line 37 of file fourvector.cc.

37  {
38  out.put('(');
39  out.fill(' ');
40  for (auto x : vec) {
41  out << field<8> << x;
42  }
43  return out << ')';
44 }

◆ field()

template<int w = 9, int p = w - 3, typename CharT , typename Traits >
std::basic_ostream<CharT, Traits>& smash::field ( std::basic_ostream< CharT, Traits > &  s)
inline

Stream modifier to align the next object to a specific width w.

Template Parameters
wThe number of characters the field should have in the output.
pThe floating precision.
CharTCharacter type of the output stream.
TraitsTraits of the output stream.
Parameters
[in,out]sThe output stream.
Returns
The output stream.

Definition at line 30 of file iomanipulators.h.

31  {
32  s.put(s.widen(' '));
33  s.setf(std::ios_base::fixed, std::ios_base::floatfield);
34  s.width(w);
35  s.precision(p);
36  return s;
37 }

◆ create_all_loggers()

void smash::create_all_loggers ( Configuration  config)

Called from main() right after the Configuration object is fully set up to create all logger objects (as defined by LogArea::AreaTuple) with the correct area names and log levels.

Parameters
configA configuration object with the log area names as toplevel keys.

Definition at line 119 of file logging.cc.

119  {
120  create_all_loggers_impl<std::tuple_size<LogArea::AreaTuple>::value>(config);
121 }

◆ default_loglevel()

einhard::LogLevel smash::default_loglevel ( )
Returns
The default log level to use if no specific level is configured.

Definition at line 22 of file logging.cc.

22 { return global_default_loglevel; }
static einhard::LogLevel global_default_loglevel
The default logging level is ALL.
Definition: logging.cc:20

◆ set_default_loglevel()

void smash::set_default_loglevel ( einhard::LogLevel  level)

Set the default log level (what will be returned from subsequent default_loglevel calls).

Parameters
levelThe new log level. See einhard::LogLevel.

Definition at line 24 of file logging.cc.

24  {
26 }

◆ format()

template<typename T >
FormattingHelper<T> smash::format ( const T &  value,
const char *  unit,
int  width = -1,
int  precision = -1 
)

Acts as a stream modifier for std::ostream to output an object with an optional suffix string and with a given field width and precision.

Template Parameters
TValue that is being formatted.
Parameters
valueThe object to be written to the stream.
unitAn optional suffix string, typically used for a unit. May be nullptr.
widthThe field width to use for value.
precisionThe precision to use for value.

Definition at line 217 of file logging.h.

218  {
219  return {value, width, precision, unit};
220 }

◆ encode()

static Node YAML::convert< einhard::LogLevel >::encode ( const einhard::LogLevel x)
inlinestatic

Convert from einhard::LogLevel to YAML::Node.

Parameters
xLog level.
Returns
Corresponding YAML node.

Definition at line 243 of file logging.h.

243  {
244  return Node{einhard::getLogLevelString(x)};
245  }
const char * getLogLevelString() noexcept
Retrieve a human readable representation of the given log level value.

◆ decode()

static bool YAML::convert< einhard::LogLevel >::decode ( const Node &  node,
einhard::LogLevel x 
)
inlinestatic

Convert from YAML::Node to einhard::LogLevel.

Parameters
[in]nodeYAML node.
[out]xWhere the corresponding log level will be stored if the conversion was successful.
Returns
Whether the conversion was successful.

Definition at line 255 of file logging.h.

255  {
256  if (!node.IsScalar()) {
257  return false;
258  } else {
259  x = einhard::getLogLevel(node.Scalar());
260  return true;
261  }
262  }
LogLevel getLogLevel(const std::string &level)
Compares the string level against the strings for LogLevel and returns the one it matches.

◆ operator<<() [6/12]

std::ostream & smash::operator<< ( std::ostream &  s,
const ParticleData p 
)

Writes the state of the particle to the output stream.

Definition at line 122 of file particledata.cc.

122  {
123  out.fill(' ');
124  return out << p.type().name() << " (" << std::setw(5) << p.type().pdgcode()
125  << ")" << std::right << "{id:" << field<6> << p.id()
126  << ", process:" << field<4> << p.id_process()
127  << ", pos [fm]:" << p.position() << ", mom [GeV]:" << p.momentum()
128  << ", formation time [fm]:" << p.formation_time()
129  << ", cross section scaling factor:" << p.xsec_scaling_factor()
130  << "}";
131 }

◆ operator<<() [7/12]

std::ostream & smash::operator<< ( std::ostream &  out,
const ParticleList &  particle_list 
)

Writes a compact overview over the particles in the particle_list argument to the stream.

Definition at line 133 of file particledata.cc.

133  {
134  auto column = out.tellp();
135  out << '[';
136  for (const auto &p : particle_list) {
137  if (out.tellp() - column >= 201) {
138  out << '\n';
139  column = out.tellp();
140  out << ' ';
141  }
142  out << std::setw(5) << std::setprecision(3) << p.momentum().abs3()
143  << p.type().name();
144  }
145  return out << ']';
146 }

◆ detailed()

PrintParticleListDetailed smash::detailed ( const ParticleList &  list)
inline

Request the ParticleList to be printed in full detail (i.e.

one full ParticleData printout per line).

Definition at line 500 of file particledata.h.

500  {
501  return {list};
502 }

◆ operator<<() [8/12]

std::ostream & smash::operator<< ( std::ostream &  out,
const PrintParticleListDetailed particle_list 
)

Writes a detailed overview over the particles in the particle_list argument to the stream.

This overload is selected via the function detailed.

Definition at line 148 of file particledata.cc.

149  {
150  bool first = true;
151  out << '[';
152  for (const auto &p : particle_list.list) {
153  if (first) {
154  first = false;
155  } else {
156  out << "\n ";
157  }
158  out << p;
159  }
160  return out << ']';
161 }

◆ operator<<() [9/12]

std::ostream & smash::operator<< ( std::ostream &  is,
const PdgCode code 
)

Writes the textual representation of the PDG code to the output stream.

Definition at line 88 of file pdgcode.cc.

88  {
89  return s << code.string();
90 }

◆ operator<<() [10/12]

std::ostream & smash::operator<< ( std::ostream &  os,
ProcessType  process_type 
)

Writes the textual representation of the process_type to the output stream os.

Definition at line 92 of file processbranch.cc.

92  {
93  switch (process_type) {
94  case ProcessType::None:
95  os << "None";
96  break;
98  os << "Elastic";
99  break;
100  case ProcessType::TwoToOne:
101  os << "TwoToOne";
102  break;
103  case ProcessType::TwoToTwo:
104  os << "TwoToTwo";
105  break;
106  case ProcessType::TwoToThree:
107  os << "TwoToThree";
108  break;
109  case ProcessType::TwoToFour:
110  os << "TwoToFour";
111  break;
112  case ProcessType::TwoToFive:
113  os << "TwoToFive";
114  break;
115  case ProcessType::StringSoftSingleDiffractiveAX:
116  case ProcessType::StringSoftSingleDiffractiveXB:
117  case ProcessType::StringSoftDoubleDiffractive:
118  case ProcessType::StringSoftAnnihilation:
119  case ProcessType::StringSoftNonDiffractive:
120  os << "Soft String Excitation";
121  break;
122  case ProcessType::StringHard:
123  os << "Hard String via Pythia";
124  break;
125  case ProcessType::Decay:
126  os << "Decay";
127  break;
128  case ProcessType::Wall:
129  os << "Wall";
130  break;
131  case ProcessType::Thermalization:
132  os << "Thermalization";
133  break;
134  case ProcessType::HyperSurfaceCrossing:
135  os << "Hypersurface crossing";
136  break;
137  case ProcessType::MultiParticleThreeMesonsToOne:
138  os << "ThreeMesonsToOne";
139  break;
140  case ProcessType::MultiParticleThreeToTwo:
141  os << "ThreeToTwo";
142  break;
143  case ProcessType::MultiParticleFourToTwo:
144  os << "FourToTwo";
145  break;
146  case ProcessType::MultiParticleFiveToTwo:
147  os << "FiveToTwo";
148  break;
149  case ProcessType::Freeforall:
150  os << "Freeforall";
151  break;
152  default:
153  os.setstate(std::ios_base::failbit);
154  }
155  return os;
156 }

◆ operator<<() [11/12]

std::ostream & smash::operator<< ( std::ostream &  os,
const CollisionBranch cbranch 
)

Writes the textual representation of the Collision Branch cbranch to the output stream os.

Definition at line 55 of file processbranch.cc.

55  {
56  ProcessType ptype = cbranch.get_type();
57  if (ptype == ProcessType::StringSoftSingleDiffractiveAX ||
58  ptype == ProcessType::StringSoftSingleDiffractiveXB) {
59  os << "1-diff";
60  } else if (ptype == ProcessType::StringSoftDoubleDiffractive) {
61  os << "2-diff";
62  } else if (ptype == ProcessType::StringSoftAnnihilation) {
63  os << "BBbar";
64  } else if (ptype == ProcessType::StringSoftNonDiffractive) {
65  os << "non-diff";
66  } else if (ptype == ProcessType::StringHard) {
67  os << "hard";
68  } else if (ptype == ProcessType::TwoToOne || ptype == ProcessType::TwoToTwo ||
69  ptype == ProcessType::TwoToThree ||
70  ptype == ProcessType::TwoToFour ||
71  ptype == ProcessType::TwoToFive || ptype == ProcessType::Elastic ||
72  ptype == ProcessType::Decay ||
73  ptype == ProcessType::MultiParticleThreeMesonsToOne ||
74  ptype == ProcessType::MultiParticleThreeToTwo ||
75  ptype == ProcessType::MultiParticleFourToTwo ||
76  ptype == ProcessType::MultiParticleFiveToTwo) {
77  ParticleTypePtrList ptype_list = cbranch.particle_types();
78  /* Sorting ensures unique name for every channel
79  * It avoids duplicates, such as Δ⁰Δ⁺⁺ and Δ⁺⁺Δ⁰,
80  * which actually occur in SMASH, because of the way channels are added:
81  * for example one channel can be added twice with halved cross-section. */
82  std::sort(ptype_list.begin(), ptype_list.end());
83  for (const auto& type : ptype_list) {
84  os << type->name();
85  }
86  } else {
87  os << ptype;
88  }
89  return os;
90 }
ProcessType
ProcessTypes are used to identify the type of the process.
Definition: processbranch.h:39

◆ format_debug_output() [3/3]

void smash::ScatterAction::format_debug_output ( std::ostream &  out) const
overrideprotectedvirtual

Writes information about this scatter action to the out stream.

Implements smash::Action.

Definition at line 745 of file scatteraction.cc.

745  {
746  out << "Scatter of " << incoming_particles_;
747  if (outgoing_particles_.empty()) {
748  out << " (not performed)";
749  } else {
750  out << " to " << outgoing_particles_;
751  }
752 }

◆ operator<<() [12/12]

std::ostream & smash::operator<< ( std::ostream &  out,
const ThreeVector v 
)

Writes the three components of the vector to the output stream.

Definition at line 16 of file threevector.cc.

16  {
17  out.put('(');
18  out.fill(' ');
19  for (auto x : v) {
20  out << field<8> << x;
21  }
22  return out << ')';
23 }

Variable Documentation

◆ value

template<typename T >
const T& smash::FormattingHelper< T >::value

Value that is being formatted.

Definition at line 177 of file logging.h.

◆ width

template<typename T >
const int smash::FormattingHelper< T >::width

Output width.

Definition at line 179 of file logging.h.

◆ precision

template<typename T >
const int smash::FormattingHelper< T >::precision

Precision that value is being formatted with.

Definition at line 181 of file logging.h.

◆ unit

template<typename T >
const char* const smash::FormattingHelper< T >::unit

Unit that is attached at the end of value.

Definition at line 183 of file logging.h.

◆ logg

std::array< einhard::Logger<>, std::tuple_size< LogArea::AreaTuple >::value > smash::logg

An array that stores all pre-configured Logger objects.

The objects can be accessed via the logger function.

To access its elements use logg[LAreaName] where AreaName is the respective areas name declared in loggin.h. Note that LAreaName needs to be declared within the smash namespace of the respective file in a form of (using PauliBlocking as an example area):

static constexpr int LPauliBlocking = LogArea::PauliBlocking::id;

For further documentation see logging.h.

Definition at line 39 of file logging.cc.

Friends

◆ operator<< [1/10]

std::ostream& operator<< ( std::ostream &  out,
const Action action 
)
friend

Dispatches formatting to the virtual Action::format_debug_output function.

Definition at line 497 of file action.h.

497  {
498  action.format_debug_output(out);
499  return out;
500  }

◆ operator<< [2/10]

std::ostream& operator<< ( std::ostream &  out,
const BoxModus m 
)
friend

Console output on startup of box specific parameters; writes the initial state for the box to the output stream.

Parameters
[in]outThe ostream into which to output
[in]mThe BoxModus object to write into out

Definition at line 32 of file boxmodus.cc.

32  {
33  out << "-- Box Modus:\nSize of the box: (" << m.length_ << " fm)³\n";
34  if (m.use_thermal_) {
35  out << "Thermal multiplicities "
36  << "(T = " << m.temperature_ << " GeV, muB = " << m.mub_
37  << " GeV, muS = " << m.mus_ << " GeV, muQ = " << m.muq_ << " GeV)\n";
38  } else {
39  for (const auto &p : m.init_multipl_) {
40  ParticleTypePtr ptype = &ParticleType::find(p.first);
41  out << ptype->name() << " initial multiplicity " << p.second << '\n';
42  }
43  }
44  switch (m.initial_condition_) {
46  out << "All initial momenta = 3T = " << 3 * m.temperature_ << " GeV\n";
47  break;
49  out << "Boltzmann momentum distribution with T = " << m.temperature_
50  << " GeV.\n";
51  break;
53  out << "Fermi/Bose momentum distribution with T = " << m.temperature_
54  << " GeV.\n";
55  break;
56  }
57  if (m.jet_pdg_) {
58  ParticleTypePtr ptype = &ParticleType::find(m.jet_pdg_.value());
59  out << "Adding a " << ptype->name() << " as a jet in the middle "
60  << "of the box with " << m.jet_mom_ << " GeV initial momentum.\n";
61  }
62  return out;
63 }
static const ParticleType & find(PdgCode pdgcode)
Returns the ParticleType object for the given pdgcode.
Definition: particletype.cc:99
@ ThermalMomentaBoltzmann
A thermalized ensemble is generated, with momenta sampled from a Maxwell-Boltzmann distribution.
@ ThermalMomentaQuantum
A thermalized ensemble is generated, with momenta of baryons(mesons) sampled from a Fermi(Bose) distr...
@ PeakedMomenta
All particles have the same momentum with T being the temperature.

◆ operator<< [3/10]

std::ostream& operator<< ( std::ostream &  out,
const ColliderModus m 
)
friend

Writes the initial state for the ColliderModus to the output stream.

Parameters
[in]outThe ostream into which to output
[in]mThe ColliderModus object to write into out

Definition at line 273 of file collidermodus.cc.

273  {
274  return out << "-- Collider Modus:\n"
275  << "sqrt(S) (nucleus-nucleus) = "
276  << format(std::sqrt(m.total_s_), "GeV\n")
277  << "sqrt(S) (nucleon-nucleon) = " << format(m.sqrt_s_NN_, "GeV\n")
278  << "Projectile:\n"
279  << *m.projectile_ << "\nTarget:\n"
280  << *m.target_;
281 }

◆ operator<< [4/10]

template<typename Modus >
std::ostream& operator<< ( std::ostream &  out,
const Experiment< Modus > &  e 
)
friend

Writes the initial state for the Experiment to the output stream.

It automatically appends the output of the current Modus.

Definition at line 713 of file experiment.h.

713  {
714  out << "End time: " << e.end_time_ << " fm\n";
715  out << e.modus_;
716  return out;
717 }

◆ operator<< [5/10]

std::ostream& operator<< ( std::ostream &  out,
const ListModus m 
)
friend

Writes the initial state for the List to the output stream.

Parameters
[in]outThe ostream into which to output
[in]mThe ListModus object to write into out

Definition at line 75 of file listmodus.cc.

75  {
76  out << "-- List Modus\nInput directory for external particle lists:\n"
77  << m.particle_list_file_directory_ << "\n";
78  return out;
79 }

◆ operator<< [6/10]

template<typename T >
std::ostream& operator<< ( std::ostream &  out,
const FormattingHelper< T > &  h 
)
friend

Nicely formatted output.

Parameters
outOutput stream
hFormattingHelper with given output parameters.

Definition at line 189 of file logging.h.

190  {
191  if (h.width > 0) {
192  out << std::setfill(' ') << std::setw(h.width);
193  }
194  if (h.precision >= 0) {
195  out << std::setprecision(h.precision);
196  }
197  out << h.value;
198  if (h.unit) {
199  out << ' ' << h.unit;
200  }
201  return out;
202  }

◆ operator<< [7/10]

std::ostream& operator<< ( std::ostream &  out,
const Nucleus n 
)
friend

Writes the state of the Nucleus object to the output stream.

Definition at line 512 of file nucleus.cc.

512  {
513  return out << " #particles #testparticles mass [GeV] "
514  "radius [fm] diffusiveness [fm]\n"
515  << format(n.number_of_particles(), nullptr, 12)
516  << format(n.size(), nullptr, 17) << format(n.mass(), nullptr, 13)
517  << format(n.get_nuclear_radius(), nullptr, 14)
518  << format(n.get_diffusiveness(), nullptr, 20);
519 }
constexpr int n
Neutron.

◆ operator<< [8/10]

std::ostream& operator<< ( std::ostream &  out,
const Particles particles 
)
friend

Print effective mass and type name for all particles to the stream.

Parameters
[in]outThe ostream into which to output
[in]particlesThe Particles object to write into out

Definition at line 148 of file particles.cc.

148  {
149  out << particles.size() << " Particles:\n";
150  for (unsigned i = 0; i < particles.data_size_; ++i) {
151  const auto &p = particles.data_[i];
152  if (p.id() < 0) {
153  out << "------ ";
154  } else {
155  out << std::setw(5) << std::setprecision(3) << p.momentum().abs3()
156  << p.type().name();
157  }
158  if ((i & 15) == 0) {
159  out << '\n';
160  }
161  }
162  return out;
163 }

◆ operator<< [9/10]

std::ostream& operator<< ( std::ostream &  out,
const ParticleType type 
)
friend

Writes all information about the particle type to the output stream.

Parameters
[out]outThe ostream into which to output
[in]typeThe ParticleType object to write into out

Definition at line 760 of file particletype.cc.

760  {
761  const PdgCode &pdg = type.pdgcode();
762  return out << type.name() << std::setfill(' ') << std::right
763  << "[ mass:" << field<6> << type.mass()
764  << ", width:" << field<6> << type.width_at_pole()
765  << ", PDG:" << field<6> << pdg
766  << ", charge:" << field<3> << pdg.charge()
767  << ", spin:" << field<2> << pdg.spin() << "/2 ]";
768 }

◆ operator<< [10/10]

std::ostream& operator<< ( std::ostream &  out,
const SphereModus m 
)
friend

Writes the initial state for the Sphere to the output stream.

Parameters
[in]outThe ostream into which to output
[in]mThe SphereModus object to write into out

Definition at line 72 of file spheremodus.cc.

72  {
73  out << "-- Sphere Modus:\nRadius of the sphere: " << m.radius_ << " fm\n";
74  if (m.use_thermal_) {
75  out << "Thermal multiplicities (T = " << m.sphere_temperature_
76  << " GeV, muB = " << m.mub_ << " GeV, muS = " << m.mus_
77  << " GeV, muQ = " << m.muq_ << " GeV)\n";
78  } else {
79  for (const auto &p : m.init_multipl_) {
80  ParticleTypePtr ptype = &ParticleType::find(p.first);
81  out << ptype->name() << " initial multiplicity " << p.second << '\n';
82  }
83  }
84  switch (m.init_distr_) {
86  out << "Boltzmann momentum distribution with T = "
87  << m.sphere_temperature_ << " GeV.\n";
88  break;
90  out << "Fermi/Bose momentum distribution with T = "
91  << m.sphere_temperature_ << " GeV.\n";
92  break;
94  out << "Sphere Initial Condition is IC_ES";
95  break;
97  out << "Sphere Initial Condition is IC_1M";
98  break;
100  out << "Sphere Initial Condition is IC_2M";
101  break;
103  out << "Sphere Initial Condition is IC_Massive";
104  break;
105  }
106  if (m.jet_pdg_) {
107  ParticleTypePtr ptype = &ParticleType::find(m.jet_pdg_.value());
108  out << "Adding a " << ptype->name() << " as a jet in the middle "
109  << "of the sphere with " << m.jet_mom_ << " GeV initial momentum.\n";
110  }
111  return out;
112 }
@ ThermalMomentaBoltzmann
A thermalized ensemble is generated, with momenta sampled from a Maxwell-Boltzmann distribution.
@ IC_ES
Off-equilibrium distribution used in massless comparisons of SMASH to the extended universe metric.
@ ThermalMomentaQuantum
A thermalized ensemble is generated, with momenta of baryons(mesons) sampled from a Fermi(Bose) distr...
@ IC_Massive
A generalization of IC_ES for the non-zero mass case; note that there is currently no analytical comp...
@ IC_2M
Off-equilibrium distribution used in massless comparisons of SMASH to the extended universe metric.
@ IC_1M
Off-equilibrium distribution used in massless comparisons of SMASH to the extended universe metric.