Version: SMASH-3.2
smash::VtkOutput Class Reference

#include <vtkoutput.h>

SMASH output in a paraview format, intended for simple visualization.

Definition at line 30 of file vtkoutput.h.

Inheritance diagram for smash::VtkOutput:
smash::OutputInterface

Public Member Functions

 VtkOutput (const std::filesystem::path &path, const std::string &name, const OutputParameters &out_par)
 Create a new VTK output. More...
 
 ~VtkOutput ()
 
void at_eventstart (const Particles &particles, const EventLabel &event_label, const EventInfo &event) override
 Writes the initial particle information list of an event to the VTK output. More...
 
void at_eventend (const Particles &particles, const EventLabel &event_label, const EventInfo &event) override
 Writes the final particle information list of an event to the VTK output. More...
 
void at_intermediate_time (const Particles &particles, const std::unique_ptr< Clock > &clock, const DensityParameters &dens_param, const EventLabel &event_label, const EventInfo &event) override
 Writes out all current particles. More...
 
void thermodynamics_output (const ThermodynamicQuantity tq, const DensityType dt, RectangularLattice< DensityOnLattice > &lattice) override
 Prints the density lattice in VTK format on a grid. More...
 
void thermodynamics_output (const ThermodynamicQuantity tq, const DensityType dt, RectangularLattice< EnergyMomentumTensor > &lattice) override
 Prints the energy-momentum-tensor lattice in VTK format on a grid. More...
 
void thermodynamics_output (const GrandCanThermalizer &gct) override
 Printout of all thermodynamic quantities from the thermalizer class. More...
 
void fields_output (const std::string name1, const std::string name2, RectangularLattice< std::pair< ThreeVector, ThreeVector >> &lat) override
 Write fields in vtk output Fields are a pair of threevectors for example electric and magnetic field. 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_interaction (const Action &, const double)
 Called whenever an action modified one or more particles. 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_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...
 
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 write (const Particles &particles)
 Write the given particles to the output. More...
 
std::string make_filename (const std::string &description, int counter)
 Make a file name given a description and a counter. More...
 
std::string make_varname (const ThermodynamicQuantity tq, const DensityType dens_type)
 Make a variable name given quantity and density type. More...
 
template<typename T >
void write_vtk_header (std::ofstream &file, RectangularLattice< T > &lat, const std::string &description)
 Write the VTK header. More...
 
template<typename T , typename F >
void write_vtk_scalar (std::ofstream &file, RectangularLattice< T > &lat, const std::string &varname, F &&function)
 Write a VTK scalar. More...
 
template<typename T , typename F >
void write_vtk_vector (std::ofstream &file, RectangularLattice< T > &lat, const std::string &varname, F &&function)
 Write a VTK vector. More...
 
std::pair< int, int > counter_key ()
 Create the key to access the vtk_output_counter_ map. More...
 

Private Attributes

const std::filesystem::path base_path_
 filesystem path for output More...
 
int current_event_ = 0
 Event number. More...
 
int current_ensemble_ = 0
 Ensemble number. More...
 
std::map< std::pair< int, int >, int > vtk_output_counter_ {}
 Counters to keep track of time steps per event and per ensemble. More...
 
int vtk_density_output_counter_ = 0
 Number of density lattice vtk output in current event. More...
 
int vtk_tmn_output_counter_ = 0
 Number of energy-momentum tensor lattice vtk output in current event. More...
 
int vtk_tmn_landau_output_counter_ = 0
 Number of Landau frame energy-momentum tensor vtk output in current event. More...
 
int vtk_v_landau_output_counter_ = 0
 Number of Landau rest frame velocity vtk output in current event. More...
 
int vtk_fluidization_counter_ = 0
 Number of fluidization output. More...
 
int vtk_fields_output_counter_ = 0
 Number of fields output in current event. More...
 
bool is_thermodynamics_output_
 Is the VTK output a thermodynamics output. More...
 
bool is_fields_output_
 Is the VTK output an output for fields. More...
 

Additional Inherited Members

- 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

◆ VtkOutput()

smash::VtkOutput::VtkOutput ( const std::filesystem::path &  path,
const std::string &  name,
const OutputParameters out_par 
)

Create a new VTK output.

Parameters
pathPath to the output file.
nameName of the output.
out_parAdditional information on the configured output.

Definition at line 24 of file vtkoutput.cc.

26  : OutputInterface(name),
27  base_path_(std::move(path)),
28  is_thermodynamics_output_(name == "Thermodynamics"),
29  is_fields_output_(name == "Fields") {
30  if (out_par.part_extended) {
31  logg[LOutput].warn()
32  << "Creating VTK output: There is no extended VTK format.";
33  }
34 }
OutputInterface(std::string name)
Construct output interface.
bool is_fields_output_
Is the VTK output an output for fields.
Definition: vtkoutput.h:216
bool is_thermodynamics_output_
Is the VTK output a thermodynamics output.
Definition: vtkoutput.h:214
const std::filesystem::path base_path_
filesystem path for output
Definition: vtkoutput.h:188
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

◆ ~VtkOutput()

smash::VtkOutput::~VtkOutput ( )

Definition at line 36 of file vtkoutput.cc.

36 {}

Member Function Documentation

◆ at_eventstart()

void smash::VtkOutput::at_eventstart ( const Particles particles,
const EventLabel event_label,
const EventInfo event 
)
overridevirtual

Writes the initial particle information list of an event to the VTK output.

Parameters
particlesCurrent list of all particles.
event_labelNumbers of the current event and ensemble.
eventEvent info, see event_info

Reimplemented from smash::OutputInterface.

Definition at line 62 of file vtkoutput.cc.

64  {
70 
71  current_event_ = event_label.event_number;
72  current_ensemble_ = event_label.ensemble_number;
75  write(particles);
77  }
78 }
int vtk_density_output_counter_
Number of density lattice vtk output in current event.
Definition: vtkoutput.h:202
std::pair< int, int > counter_key()
Create the key to access the vtk_output_counter_ map.
Definition: vtkoutput.h:183
void write(const Particles &particles)
Write the given particles to the output.
Definition: vtkoutput.cc:97
int vtk_fluidization_counter_
Number of fluidization output.
Definition: vtkoutput.h:210
int current_event_
Event number.
Definition: vtkoutput.h:191
int current_ensemble_
Ensemble number.
Definition: vtkoutput.h:193
std::map< std::pair< int, int >, int > vtk_output_counter_
Counters to keep track of time steps per event and per ensemble.
Definition: vtkoutput.h:199
int vtk_tmn_landau_output_counter_
Number of Landau frame energy-momentum tensor vtk output in current event.
Definition: vtkoutput.h:206
int vtk_v_landau_output_counter_
Number of Landau rest frame velocity vtk output in current event.
Definition: vtkoutput.h:208
int vtk_tmn_output_counter_
Number of energy-momentum tensor lattice vtk output in current event.
Definition: vtkoutput.h:204

◆ at_eventend()

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

Writes the final particle information list of an event to the VTK output.

This currently does not do anything, because it is not required for the VTK output.

Parameters
particlesUnused, needed since inherited.
event_labelUnused, needed since inherited.
[in]eventEvent info, see event_info

Reimplemented from smash::OutputInterface.

Definition at line 80 of file vtkoutput.cc.

82  {}

◆ at_intermediate_time()

void smash::VtkOutput::at_intermediate_time ( const Particles particles,
const std::unique_ptr< Clock > &  clock,
const DensityParameters dens_param,
const EventLabel event_label,
const EventInfo event 
)
overridevirtual

Writes out all current particles.

Parameters
particlesCurrent list of particles.
clockUnused, needed since inherited.
dens_paramUnused, needed since inherited.
event_labelNumbers of the current event and ensemble.
eventEvent info, see event_info

Reimplemented from smash::OutputInterface.

Definition at line 84 of file vtkoutput.cc.

88  {
89  current_event_ = event_label.event_number;
90  current_ensemble_ = event_label.ensemble_number;
92  write(particles);
94  }
95 }

◆ thermodynamics_output() [1/3]

void smash::VtkOutput::thermodynamics_output ( const ThermodynamicQuantity  tq,
const DensityType  dt,
RectangularLattice< DensityOnLattice > &  lattice 
)
overridevirtual

Prints the density lattice in VTK format on a grid.

Parameters
tqThe quantity whose density should be written, see ThermodynamicQuantity.
dtThe type of the density, see DensityType.
latticeThe lattice from which the quantity is taken.

Reimplemented from smash::OutputInterface.

Definition at line 246 of file vtkoutput.cc.

248  {
250  return;
251  }
252  std::ofstream file;
253  const std::string varname = make_varname(tq, dens_type);
254  file.open(make_filename(varname, vtk_density_output_counter_), std::ios::out);
255  write_vtk_header(file, lattice, varname);
256  write_vtk_scalar(file, lattice, varname,
257  [&](DensityOnLattice &node) { return node.rho(); });
259 }
void write_vtk_scalar(std::ofstream &file, RectangularLattice< T > &lat, const std::string &varname, F &&function)
Write a VTK scalar.
Definition: vtkoutput.cc:202
void write_vtk_header(std::ofstream &file, RectangularLattice< T > &lat, const std::string &description)
Write the VTK header.
Definition: vtkoutput.cc:185
std::string make_varname(const ThermodynamicQuantity tq, const DensityType dens_type)
Make a variable name given quantity and density type.
Definition: vtkoutput.cc:240
std::string make_filename(const std::string &description, int counter)
Make a file name given a description and a counter.
Definition: vtkoutput.cc:233

◆ thermodynamics_output() [2/3]

void smash::VtkOutput::thermodynamics_output ( const ThermodynamicQuantity  tq,
const DensityType  dt,
RectangularLattice< EnergyMomentumTensor > &  lattice 
)
overridevirtual

Prints the energy-momentum-tensor lattice in VTK format on a grid.

Parameters
tqThe quantity whose density should be written, see ThermodynamicQuantity.
dtThe type of the density, see DensityType
latticeThe lattice from which the quantity is taken.

Reimplemented from smash::OutputInterface.

Definition at line 275 of file vtkoutput.cc.

277  {
279  return;
280  }
281  std::ofstream file;
282  const std::string varname = make_varname(tq, dens_type);
283 
284  if (tq == ThermodynamicQuantity::Tmn) {
285  file.open(make_filename(varname, vtk_tmn_output_counter_++), std::ios::out);
286  write_vtk_header(file, Tmn_lattice, varname);
287  for (int i = 0; i < 4; i++) {
288  for (int j = i; j < 4; j++) {
289  write_vtk_scalar(file, Tmn_lattice,
290  varname + std::to_string(i) + std::to_string(j),
291  [&](EnergyMomentumTensor &node) {
292  return node[EnergyMomentumTensor::tmn_index(i, j)];
293  });
294  }
295  }
296  } else if (tq == ThermodynamicQuantity::TmnLandau) {
297  file.open(make_filename(varname, vtk_tmn_landau_output_counter_++),
298  std::ios::out);
299  write_vtk_header(file, Tmn_lattice, varname);
300  for (int i = 0; i < 4; i++) {
301  for (int j = i; j < 4; j++) {
302  write_vtk_scalar(file, Tmn_lattice,
303  varname + std::to_string(i) + std::to_string(j),
304  [&](EnergyMomentumTensor &node) {
305  const FourVector u = node.landau_frame_4velocity();
306  const EnergyMomentumTensor Tmn_L = node.boosted(u);
307  return Tmn_L[EnergyMomentumTensor::tmn_index(i, j)];
308  });
309  }
310  }
311  } else {
312  file.open(make_filename(varname, vtk_v_landau_output_counter_++),
313  std::ios::out);
314  write_vtk_header(file, Tmn_lattice, varname);
315  write_vtk_vector(file, Tmn_lattice, varname,
316  [&](EnergyMomentumTensor &node) {
317  const FourVector u = node.landau_frame_4velocity();
318  return -u.velocity();
319  });
320  }
321 }
static std::int8_t tmn_index(std::int8_t mu, std::int8_t nu)
Access the index of component .
void write_vtk_vector(std::ofstream &file, RectangularLattice< T > &lat, const std::string &varname, F &&function)
Write a VTK vector.
Definition: vtkoutput.cc:220
@ Tmn
Energy-momentum tensor in lab frame.
@ TmnLandau
Energy-momentum tensor in Landau rest frame.

◆ thermodynamics_output() [3/3]

void smash::VtkOutput::thermodynamics_output ( const GrandCanThermalizer gct)
overridevirtual

Printout of all thermodynamic quantities from the thermalizer class.

Parameters
gctGrand-canonical thermalizer from which the quantities are taken.

Reimplemented from smash::OutputInterface.

Definition at line 344 of file vtkoutput.cc.

344  {
346  return;
347  }
348  std::ofstream file;
349  file.open(make_filename("fluidization_td", vtk_fluidization_counter_++),
350  std::ios::out);
351  write_vtk_header(file, gct.lattice(), "fluidization_td");
352  write_vtk_scalar(file, gct.lattice(), "e",
353  [&](ThermLatticeNode &node) { return node.e(); });
354  write_vtk_scalar(file, gct.lattice(), "p",
355  [&](ThermLatticeNode &node) { return node.p(); });
356  write_vtk_vector(file, gct.lattice(), "v",
357  [&](ThermLatticeNode &node) { return node.v(); });
358  write_vtk_scalar(file, gct.lattice(), "T",
359  [&](ThermLatticeNode &node) { return node.T(); });
360  write_vtk_scalar(file, gct.lattice(), "mub",
361  [&](ThermLatticeNode &node) { return node.mub(); });
362  write_vtk_scalar(file, gct.lattice(), "mus",
363  [&](ThermLatticeNode &node) { return node.mus(); });
364 }

◆ fields_output()

void smash::VtkOutput::fields_output ( const std::string  name1,
const std::string  name2,
RectangularLattice< std::pair< ThreeVector, ThreeVector >> &  lat 
)
overridevirtual

Write fields in vtk output Fields are a pair of threevectors for example electric and magnetic field.

Reimplemented from smash::OutputInterface.

Definition at line 323 of file vtkoutput.cc.

325  {
326  if (!is_fields_output_) {
327  return;
328  }
329  std::ofstream file1;
330  file1.open(make_filename(name1, vtk_fields_output_counter_), std::ios::out);
331  write_vtk_header(file1, lat, name1);
333  file1, lat, name1,
334  [&](std::pair<ThreeVector, ThreeVector> &node) { return node.first; });
335  std::ofstream file2;
336  file2.open(make_filename(name2, vtk_fields_output_counter_), std::ios::out);
337  write_vtk_header(file2, lat, name2);
339  file2, lat, name2,
340  [&](std::pair<ThreeVector, ThreeVector> &node) { return node.second; });
342 }
int vtk_fields_output_counter_
Number of fields output in current event.
Definition: vtkoutput.h:212

◆ write()

void smash::VtkOutput::write ( const Particles particles)
private

Write the given particles to the output.

Parameters
particlesThe particles.

Definition at line 97 of file vtkoutput.cc.

97  {
98  char filename[64];
99  snprintf(filename, sizeof(filename), "pos_ev%05i_ens%05i_tstep%05i.vtk",
102  FilePtr file_{std::fopen((base_path_ / filename).native().c_str(), "w")};
103 
104  /* Legacy VTK file format */
105  std::fprintf(file_.get(), "# vtk DataFile Version 2.0\n");
106  std::fprintf(file_.get(), "Generated from molecular-offset data %s\n",
107  SMASH_VERSION);
108  std::fprintf(file_.get(), "ASCII\n");
109 
110  /* Unstructured data sets are composed of points, lines, polygons, .. */
111  std::fprintf(file_.get(), "DATASET UNSTRUCTURED_GRID\n");
112  std::fprintf(file_.get(), "POINTS %zu double\n", particles.size());
113  for (const auto &p : particles) {
114  std::fprintf(file_.get(), "%g %g %g\n", p.position().x1(),
115  p.position().x2(), p.position().x3());
116  }
117  std::fprintf(file_.get(), "CELLS %zu %zu\n", particles.size(),
118  particles.size() * 2);
119  for (size_t point_index = 0; point_index < particles.size(); point_index++) {
120  std::fprintf(file_.get(), "1 %zu\n", point_index);
121  }
122  std::fprintf(file_.get(), "CELL_TYPES %zu\n", particles.size());
123  for (size_t point_index = 0; point_index < particles.size(); point_index++) {
124  std::fprintf(file_.get(), "1\n");
125  }
126  std::fprintf(file_.get(), "POINT_DATA %zu\n", particles.size());
127  std::fprintf(file_.get(), "SCALARS pdg_codes int 1\n");
128  std::fprintf(file_.get(), "LOOKUP_TABLE default\n");
129  for (const auto &p : particles) {
130  std::fprintf(file_.get(), "%s\n", p.pdgcode().string().c_str());
131  }
132  std::fprintf(file_.get(), "SCALARS is_formed int 1\n");
133  std::fprintf(file_.get(), "LOOKUP_TABLE default\n");
134  double current_time = particles.time();
135  for (const auto &p : particles) {
136  std::fprintf(file_.get(), "%s\n",
137  (p.formation_time() > current_time) ? "0" : "1");
138  }
139  std::fprintf(file_.get(), "SCALARS cross_section_scaling_factor double 1\n");
140  std::fprintf(file_.get(), "LOOKUP_TABLE default\n");
141  for (const auto &p : particles) {
142  std::fprintf(file_.get(), "%g\n", p.xsec_scaling_factor());
143  }
144  std::fprintf(file_.get(), "SCALARS mass double 1\n");
145  std::fprintf(file_.get(), "LOOKUP_TABLE default\n");
146  for (const auto &p : particles) {
147  std::fprintf(file_.get(), "%g\n", p.effective_mass());
148  }
149  std::fprintf(file_.get(), "SCALARS N_coll int 1\n");
150  std::fprintf(file_.get(), "LOOKUP_TABLE default\n");
151  for (const auto &p : particles) {
152  std::fprintf(file_.get(), "%i\n", p.get_history().collisions_per_particle);
153  }
154  std::fprintf(file_.get(), "SCALARS particle_ID int 1\n");
155  std::fprintf(file_.get(), "LOOKUP_TABLE default\n");
156  for (const auto &p : particles) {
157  std::fprintf(file_.get(), "%i\n", p.id());
158  }
159  std::fprintf(file_.get(), "SCALARS baryon_number int 1\n");
160  std::fprintf(file_.get(), "LOOKUP_TABLE default\n");
161  for (const auto &p : particles) {
162  std::fprintf(file_.get(), "%i\n", p.pdgcode().baryon_number());
163  }
164  std::fprintf(file_.get(), "SCALARS strangeness int 1\n");
165  std::fprintf(file_.get(), "LOOKUP_TABLE default\n");
166  for (const auto &p : particles) {
167  std::fprintf(file_.get(), "%i\n", p.pdgcode().strangeness());
168  }
169  std::fprintf(file_.get(), "VECTORS momentum double\n");
170  for (const auto &p : particles) {
171  std::fprintf(file_.get(), "%g %g %g\n", p.momentum().x1(),
172  p.momentum().x2(), p.momentum().x3());
173  }
174 }
constexpr int p
Proton.
std::unique_ptr< std::FILE, FileDeleter > FilePtr
A RAII type to replace std::FILE *.
Definition: file.h:61
FilePtr fopen(const std::filesystem::path &filename, const std::string &mode)
Open a file with given mode.
Definition: file.cc:14

◆ make_filename()

std::string smash::VtkOutput::make_filename ( const std::string &  description,
int  counter 
)
private

Make a file name given a description and a counter.

Parameters
descriptionThe description.
counterThe counter enumerating the outputs.

Definition at line 233 of file vtkoutput.cc.

233  {
234  char suffix[22];
235  snprintf(suffix, sizeof(suffix), "_%05i_tstep%05i.vtk", current_event_,
236  counter);
237  return base_path_.string() + std::string("/") + descr + std::string(suffix);
238 }

◆ make_varname()

std::string smash::VtkOutput::make_varname ( const ThermodynamicQuantity  tq,
const DensityType  dens_type 
)
private

Make a variable name given quantity and density type.

Parameters
tqThe quantity.
dens_typeThe density type.

Definition at line 240 of file vtkoutput.cc.

241  {
242  return std::string(to_string(dens_type)) + std::string("_") +
243  std::string(to_string(tq));
244 }
const char * to_string(const ThermodynamicQuantity tq)
Convert thermodynamic quantities to strings.

◆ write_vtk_header()

template<typename T >
void smash::VtkOutput::write_vtk_header ( std::ofstream &  file,
RectangularLattice< T > &  lat,
const std::string &  description 
)
private

Write the VTK header.

Parameters
fileOutput file.
latLattice corresponding to output.
descriptionDescription of the output.

Definition at line 185 of file vtkoutput.cc.

187  {
188  const auto dim = lattice.n_cells();
189  const auto cs = lattice.cell_sizes();
190  const auto orig = lattice.origin();
191  file << "# vtk DataFile Version 2.0\n"
192  << description << "\n"
193  << "ASCII\n"
194  << "DATASET STRUCTURED_POINTS\n"
195  << "DIMENSIONS " << dim[0] << " " << dim[1] << " " << dim[2] << "\n"
196  << "SPACING " << cs[0] << " " << cs[1] << " " << cs[2] << "\n"
197  << "ORIGIN " << orig[0] << " " << orig[1] << " " << orig[2] << "\n"
198  << "POINT_DATA " << lattice.size() << "\n";
199 }

◆ write_vtk_scalar()

template<typename T , typename F >
void smash::VtkOutput::write_vtk_scalar ( std::ofstream &  file,
RectangularLattice< T > &  lat,
const std::string &  varname,
F &&  function 
)
private

Write a VTK scalar.

Parameters
fileOutput file.
latLattice corresponding to output.
varnameName of the output variable.
functionFunction that gets the scalar given a lattice node.

Definition at line 202 of file vtkoutput.cc.

204  {
205  file << "SCALARS " << varname << " double 1\n"
206  << "LOOKUP_TABLE default\n";
207  file << std::setprecision(3);
208  file << std::fixed;
209  const auto dim = lattice.n_cells();
210  lattice.iterate_sublattice({0, 0, 0}, dim, [&](T &node, int ix, int, int) {
211  const double f_from_node = get_quantity(node);
212  file << f_from_node << " ";
213  if (ix == dim[0] - 1) {
214  file << "\n";
215  }
216  });
217 }

◆ write_vtk_vector()

template<typename T , typename F >
void smash::VtkOutput::write_vtk_vector ( std::ofstream &  file,
RectangularLattice< T > &  lat,
const std::string &  varname,
F &&  function 
)
private

Write a VTK vector.

Parameters
fileOutput file.
latLattice corresponding to output.
varnameName of the output variable.
functionFunction that gets the vector given a lattice node.

Definition at line 220 of file vtkoutput.cc.

222  {
223  file << "VECTORS " << varname << " double\n";
224  file << std::setprecision(3);
225  file << std::fixed;
226  const auto dim = lattice.n_cells();
227  lattice.iterate_sublattice({0, 0, 0}, dim, [&](T &node, int, int, int) {
228  const ThreeVector v = get_quantity(node);
229  file << v.x1() << " " << v.x2() << " " << v.x3() << "\n";
230  });
231 }

◆ counter_key()

std::pair<int, int> smash::VtkOutput::counter_key ( )
inlineprivate

Create the key to access the vtk_output_counter_ map.

Returns
std::pair<int, int> The key to access the map.

Definition at line 183 of file vtkoutput.h.

183  {
185  }

Member Data Documentation

◆ base_path_

const std::filesystem::path smash::VtkOutput::base_path_
private

filesystem path for output

Definition at line 188 of file vtkoutput.h.

◆ current_event_

int smash::VtkOutput::current_event_ = 0
private

Event number.

Definition at line 191 of file vtkoutput.h.

◆ current_ensemble_

int smash::VtkOutput::current_ensemble_ = 0
private

Ensemble number.

Definition at line 193 of file vtkoutput.h.

◆ vtk_output_counter_

std::map<std::pair<int, int>, int> smash::VtkOutput::vtk_output_counter_ {}
private

Counters to keep track of time steps per event and per ensemble.

The first pair index runs over events and the second one over ensembles, but this is encapsulated in the counter_key method which is used to change this map.

Definition at line 199 of file vtkoutput.h.

◆ vtk_density_output_counter_

int smash::VtkOutput::vtk_density_output_counter_ = 0
private

Number of density lattice vtk output in current event.

Definition at line 202 of file vtkoutput.h.

◆ vtk_tmn_output_counter_

int smash::VtkOutput::vtk_tmn_output_counter_ = 0
private

Number of energy-momentum tensor lattice vtk output in current event.

Definition at line 204 of file vtkoutput.h.

◆ vtk_tmn_landau_output_counter_

int smash::VtkOutput::vtk_tmn_landau_output_counter_ = 0
private

Number of Landau frame energy-momentum tensor vtk output in current event.

Definition at line 206 of file vtkoutput.h.

◆ vtk_v_landau_output_counter_

int smash::VtkOutput::vtk_v_landau_output_counter_ = 0
private

Number of Landau rest frame velocity vtk output in current event.

Definition at line 208 of file vtkoutput.h.

◆ vtk_fluidization_counter_

int smash::VtkOutput::vtk_fluidization_counter_ = 0
private

Number of fluidization output.

Definition at line 210 of file vtkoutput.h.

◆ vtk_fields_output_counter_

int smash::VtkOutput::vtk_fields_output_counter_ = 0
private

Number of fields output in current event.

Definition at line 212 of file vtkoutput.h.

◆ is_thermodynamics_output_

bool smash::VtkOutput::is_thermodynamics_output_
private

Is the VTK output a thermodynamics output.

Definition at line 214 of file vtkoutput.h.

◆ is_fields_output_

bool smash::VtkOutput::is_fields_output_
private

Is the VTK output an output for fields.

Definition at line 216 of file vtkoutput.h.


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