Flow123d  JS_before_hm-1804-gf2ad740aa
balance.hh
Go to the documentation of this file.
1 /*!
2  *
3  * Copyright (C) 2015 Technical University of Liberec. All rights reserved.
4  *
5  * This program is free software; you can redistribute it and/or modify it under
6  * the terms of the GNU General Public License version 3 as published by the
7  * Free Software Foundation. (http://www.gnu.org/licenses/gpl-3.0.en.html)
8  *
9  * This program is distributed in the hope that it will be useful, but WITHOUT
10  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
11  * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
12  *
13  *
14  * @file balance.hh
15  * @brief
16  */
17 
18 #ifndef BALANCE_HH_
19 #define BALANCE_HH_
20 
21 
22 #include <fstream> // for ofstream
23 #include <string> // for string
24 #include <vector> // for vector
25 #include <unordered_map> // for unordered_map
26 #include "mesh/accessors.hh" // for SideIter
27 #include "tools/unit_si.hh" // for UnitSI
28 #include "input/accessors.hh" // for Record
29 #include "petscmat.h" // for Mat, _p_Mat
30 #include "petscvec.h" // for Vec, _p_Vec
31 #include "system/file_path.hh" // for FilePath
32 #include "tools/time_marks.hh" // for TimeMark, TimeMark::Type
33 #include "system/index_types.hh" // for LongIdx
34 
35 class Mesh;
36 class TimeGovernor;
37 class DOFHandlerMultiDim;
38 class DHCellSide;
39 class DHCellAccessor;
40 namespace Input {
41  namespace Type {
42  class Record;
43  class Selection;
44  }
45 }
46 
47 
48 
49 
50 
51 /**
52  * Design of balance class - serves as storage and writer.
53  * Equations themselves call methods of Balance that add/modify mass, source and flux
54  * of various quantities and generate output.
55  *
56  * One instance of Balance can handle several conservative quantities of the same type
57  * (e.g. mass of several substances or their phases).
58  *
59  * The mass, flux and source are calculated as follows:
60  *
61  * m(q,r) = ( M'(q) * solution + mv(q) )[r]
62  * f(q,r) = -( R' * ( F(q) * solution + fv(q) ) )[r]
63  * s(q,r) = ( S'(q) * solution + sv(q) )[r]
64  *
65  * where M' stands for matrix transpose,
66  *
67  * m(q,r)...mass of q-th substance in region r
68  * f(q,r)...incoming flux of q-th substance in region r
69  * s(q,r)...source of q-th substance in region r
70  *
71  * and
72  *
73  * M(q)...region_mass_matrix_ n_dofs x n_bulk_regions
74  * F(q)...be_flux_matrix_ n_boundary_edges x n_dofs
75  * S(q)...region_source_matrix_ n_dofs x n_bulk_regions
76  * SV(q)..region_source_rhs_ n_dofs x n_bulk_regions
77  * mv(q)..region_mass_vec_ n_bulk_regions
78  * fv(q)..be_flux_vec_ n_boundary_edges
79  * sv(q)..region_source_vec_ n_bulk_regions
80  * R......region_be_matrix_ n_boundary_edges x n_boundary_regions
81  *
82  * Remark: Matrix F and the vector fv are such that F*solution+fv produces _outcoming_ fluxes per boundary edge.
83  * However we write to output _incoming_ flux due to users' convention and consistently with input interface.
84  *
85  * Note that it holds:
86  *
87  * sv(q) = column sum of SV(q)
88  *
89  * Except for that, we also provide information on positive/negative flux and source:
90  *
91  * fp(q,r) = ( R' * EFP(q) )[r], EFP(q)[e] = max{ 0, ( F(q) * solution + fv(q) )[e] }
92  * fn(q,r) = ( R' * EFN(q) )[r], EFN(q)[e] = min{ 0, ( F(q) * solution + fv(q) )[e] }
93  * sp(q,r) = sum_{i in DOFS } max{ 0, ( S(q)[i,r] * solution[i] + SV(q)[i,r] ) }
94  * sn(q,r) = sum_{i in DOFS } min{ 0, ( S(q)[i,r] * solution[i] + SV(q)[i,r] ) }
95  *
96  * where
97  *
98  * fp(q,r)...positive (inward) flux of q-th quantity in region r
99  * fn(q,r)...negative (outward) flux of q-th quantity in region r
100  * sp(q,r)...positive source (spring) of q-th quantity in region r
101  * sn(q,r)...negative source (sink) of q-th quantity in region r
102  *
103  * Remark: The matrix R is needed only for calculation of signed fluxes.
104  * The reason is that to determine sign, we decompose flux to sum of local contributions
105  * per each boundary element and check its sign. It is not possible to decompose flux
106  * using shape functions, since their normal derivatives may have any sign.
107  *
108  *
109  *
110  * Output values (if not relevant, zero is supplied):
111  *
112  * #time bulk_region quantity 0 0 0 mass source source_in source_out 0 0 0
113  * #time boundary_region quantity flux flux_in flux_out 0 0 0 0 0 0 0
114  * #time ALL quantity flux flux_in flux_out mass source source_in source_out integrated_flux integrated_source error
115  *
116  * error = current_mass - (initial_mass + integrated_source - integrated_flux)
117  *
118  */
119 class Balance {
120 public:
121 
122  /**
123  * Class for storing internal data about conservative quantities handled by the Balance object.
124  * In the future we may store additional data or support definition of derived quantities
125  * (e.g. linear combinations of quantities).
126  */
127  class Quantity {
128  public:
129 
130  Quantity(const unsigned int index, const string &name)
131  : name_(name),
132  index_(index)
133  {}
134 
135  /// Name of quantity (for output).
136  string name_;
137 
138  /// Internal index within list of quantities.
139  const unsigned int index_;
140 
141  };
142 
143  /**
144  * Possible formats of output file.
145  */
147  {
148  legacy,//!< legacy
149  txt, //!< csv
150  gnuplot//!< gnuplot
151  };
152 
153  /// Main balance input record type.
154  static const Input::Type::Record & get_input_type();
155 
156  /// Input selection for file format.
158 
159  /// Set global variable to output balance files into YAML format (in addition to the table format).
160  static void set_yaml_output();
161 
162  /**
163  * Constructor.
164  * @param file_prefix Prefix of output file name.
165  * @param mesh Mesh.
166  */
167  Balance(const std::string &file_prefix, const Mesh *mesh);
168 
169  /**
170  * Destructor.
171  */
172  ~Balance();
173 
174 
175  /**
176  * Initialize the balance object according to the input.
177  * The balance output time marks are set according to the already existing output time marks of the same equation.
178  * So, this method must be called after Output::
179  *
180  * @param in_rec Input record of balance.
181  * @param tg TimeGovernor of the equation. We need just equation mark type.
182  *
183  */
184  void init_from_input(const Input::Record &in_rec, TimeGovernor &tg);
185 
186  /// Setter for units of conserved quantities.
187  void units(const UnitSI &unit);
188 
189  /// Getter for cumulative_.
190  inline bool cumulative() const { return cumulative_; }
191 
192 
193  /**
194  * Define a single conservative quantity.
195  * @param name Name of the quantity.
196  * @return Quantity's internal index.
197  */
198  unsigned int add_quantity(const string &name);
199 
200  /**
201  * Define a set of conservative quantities.
202  * @param names List of quantities' names.
203  * @return List of quantities' indices.
204  */
206 
207  /**
208  * Allocates matrices and vectors for balance based on DofHandler.
209  * @param dh DofHandler of the corresponding linear system (and solution).
210  * @param max_dofs_per_boundary Number of dofs contributing to one boundary edge.
211  */
212  void allocate(const std::shared_ptr<DOFHandlerMultiDim>& dh,
213  unsigned int max_dofs_per_boundary);
214 
215  /**
216  * Allocates matrices and vectors for balance.
217  * @param n_loc_dofs Number of solution dofs on the local process.
218  * @param max_dofs_per_boundary Number of dofs contributing to one boundary edge.
219  */
220  void allocate(unsigned int n_loc_dofs,
221  unsigned int max_dofs_per_boundary);
222 
223  /// Returns true if the current time step is marked for the balance output.
224  bool is_current();
225 
226  /**
227  * This method must be called before assembling the matrix for computing mass.
228  * It actually erases the matrix.
229  */
230  void start_mass_assembly(unsigned int quantity_idx);
231 
232  /// Variant of the start_mass_assembly() method for a set of quantities.
234  {
235  for (auto idx : q_idx_vec)
236  start_mass_assembly(idx);
237  }
238 
239  /**
240  * This method must be called before assembling the matrix and vector for fluxes.
241  * It actually erases the matrix and vector.
242  */
243  void start_flux_assembly(unsigned int quantity_idx);
244 
245  /// Variant of the start_flux_assembly() method for a set of quantities.
247  {
248  for (auto idx : q_idx_vec)
249  start_flux_assembly(idx);
250  }
251 
252  /**
253  * This method must be called before assembling the matrix and vectors for sources.
254  * It actually erases the matrix and vectors.
255  */
256  void start_source_assembly(unsigned int quantity_idx);
257 
258  /// Variant of the start_source_assembly() method for a set of quantities.
260  {
261  for (auto idx : q_idx_vec)
263  }
264 
265 
266  /**
267  * Adds elements into matrix for computing mass.
268  * The mass matrix M is in format [n_dofs x n_bulk_regions] for each quantity.
269  * The mass vector mv is in format [n_bulk_regions] for each quantity.
270  * The region mass is later computed using transpose multiplication (M'*u + mv)[r].
271  * See class @p Balance description above for details.
272  * @param quantity_idx Index of quantity.
273  * @param dh_cell Dofhandler cell accessor.
274  * @param loc_dof_indices Local dof indices (to the solution vector) to be added.
275  * @param mat_values Values to be added into matrix M.
276  * @param vec_value Value to be added into vector mv.
277  */
278  void add_mass_values(unsigned int quantity_idx,
279  const DHCellAccessor &dh_cell,
280  const LocDofVec &loc_dof_indices,
281  const std::vector<double> &mat_values,
282  double vec_value);
283 
284  /**
285  * Adds elements into matrix for computing (outgoing) flux.
286  * The flux matrix F is in format [n_boundary_edges x n_dofs] for each quantity.
287  * The flux vector fv is in format [n_boundary_edges] for each quantity.
288  * See class @p Balance description above for details.
289  * @param quantity_idx Index of quantity.
290  * @param side DHCellSide iterator.
291  * @param loc_dof_indices Local dof indices (to the solution vector) to be added.
292  * @param mat_values Values to be added into matrix F.
293  * @param vec_value Value to be added into vector fv.
294  */
295  void add_flux_values(unsigned int quantity_idx,
296  const DHCellSide &side,
297  const LocDofVec &loc_dof_indices,
298  const std::vector<double> &mat_values,
299  double vec_value);
300 
301  /**
302  * Adds elements into matrix and vector for computing source.
303  * The source region matrix S is in format [n_dofs x n_bulk_regions] for each quantity (multiplies solution).
304  * The source region rhs matrix SV is in format [n_dofs x n_bulk_regions] for each quantity (addition).
305  * The region source is then computed as (S'(q) * solution + sv(q))[r], while sv(q) being column sum of SV(q).
306  * The source term for a specific region and quantity is then
307  * @param quantity_idx Index of quantity.
308  * @param region_idx Index of bulk region.
309  * @param loc_dof_indices Local dof indices (to the solution vector) to be added.
310  * @param mult_mat_values Values to be added into matrix S.
311  * @param add_mat_values Values to be added into matrix SV.
312  */
313  void add_source_values(unsigned int quantity_idx,
314  unsigned int region_idx,
315  const LocDofVec &loc_dof_indices,
316  const std::vector<double> &mult_mat_values,
317  const std::vector<double> &add_mat_values);
318 
319 
320  /// This method must be called after assembling the matrix for computing mass.
321  void finish_mass_assembly(unsigned int quantity_idx);
322 
323  /// Variant of the finish_mass_assembly() method for a set of quantities.
325  {
326  for (auto idx : q_idx_vec)
328  }
329 
330  /// This method must be called after assembling the matrix and vector for computing flux.
331  void finish_flux_assembly(unsigned int quantity_idx);
332 
333  /// Variant of the finish_flux_assembly() method for a set of quantities.
335  {
336  for (auto idx : q_idx_vec)
338  }
339 
340  /// This method must be called after assembling the matrix and vectors for computing source.
341  void finish_source_assembly(unsigned int quantity_idx);
342 
343  /// Variant of the finish_source_assembly() method for a set of quantities.
345  {
346  for (auto idx : q_idx_vec)
348  }
349 
350  /**
351  * Updates cumulative quantities for balance.
352  * This method can be called in substeps even if no output is generated.
353  * It calculates the sum of source and sum of (incoming) flux over time interval.
354  * @param quantity_idx Index of quantity.
355  * @param solution Solution vector.
356  */
357  void calculate_cumulative(unsigned int quantity_idx,
358  const Vec &solution);
359 
360  /**
361  * Calculates actual mass and save it to given vector.
362  * @param quantity_idx Index of quantity.
363  * @param solution Solution vector.
364  * @param output_array Vector of output masses per region.
365  */
366  void calculate_mass(unsigned int quantity_idx,
367  const Vec &solution,
368  vector<double> &output_array);
369 
370  /**
371  * Calculates actual mass, incoming flux and source.
372  * @param quantity_idx Index of quantity.
373  * @param solution Solution vector.
374  */
375  void calculate_instant(unsigned int quantity_idx,
376  const Vec &solution);
377 
378  /**
379  * Adds provided values to the cumulative sources.
380  * @param quantity_idx Index of quantity.
381  * @param sources Sources per region.
382  * @param dt Actual time step.
383  */
384  void add_cumulative_source(unsigned int quantity_idx, double source);
385 
386  /// Perform output to file for given time instant.
387  void output();
388 
389 private:
390  /// Size of column in output (used if delimiter is space)
391  static const unsigned int output_column_width = 20;
392  /**
393  * Postponed allocation and initialization to allow calling setters in arbitrary order.
394  * In particular we need to perform adding of output times after the output time marks are set.
395  * On the other hand we need to read the input before we make the allocation.
396  *
397  * The initialization is done during the first call of any start_*_assembly method.
398  */
399  void lazy_initialize();
400 
401  /// Perform output in old format (for compatibility)
402  void output_legacy(double time);
403 
404  /// Perform output in csv format
405  void output_csv(double time, char delimiter, const std::string& comment_string, unsigned int repeat = 0);
406 
407  /// Perform output in yaml format
408  void output_yaml(double time);
409 
410  /// Return part of output represented by zero values. Count of zero values is given by cnt parameter.
411  std::string csv_zero_vals(unsigned int cnt, char delimiter);
412 
413  /// Print output header
414  void format_csv_output_header(char delimiter, const std::string& comment_string);
415 
416  /// Format string value of csv output. Wrap string into quotes and if delimiter is space, align text to column.
417  std::string format_csv_val(std::string val, char delimiter, bool initial = false);
418 
419  /// Format double value of csv output. If delimiter is space, align text to column.
420  std::string format_csv_val(double val, char delimiter, bool initial = false);
421 
422  /** Computes unique id of local boundary edge from local element index and element side index
423  *
424  * @param side is a side of locally owned element
425  */
427  { return 4*side->elem_idx() + side->side_idx();} // 4 is maximum of sides per element
428 
429  //**********************************************
430 
431  static bool do_yaml_output_;
432 
433  /// Allocation parameters. Set by the allocate method used in the lazy_initialize.
434  unsigned int n_loc_dofs_par_;
435  unsigned int n_loc_dofs_seq_;
437 
438 
439  /// Save prefix passed in in constructor.
440  std::string file_prefix_;
441 
442  /// File path for output_ stream.
444 
445  /// Handle for file for output in given OutputFormat of balance and total fluxes over individual regions and region sets.
446  std::ofstream output_;
447 
448  // The same as the previous case, but for output in YAML format.
449  std::ofstream output_yaml_;
450 
451  /// Format of output file.
453 
454  /// Names of conserved quantities.
456 
457  const Mesh *mesh_;
458 
459  /// Units of conserved quantities.
461 
462 
463  /// Matrices for calculation of mass (n_dofs x n_bulk_regions).
465 
466  /// Matrices for calculation of flux (n_boundary_edges x n_dofs).
468 
469  /// Matrices for calculation of source (n_dofs x n_bulk_regions).
471 
472  /// Matrices for calculation of signed source (n_dofs x n_bulk_regions).
474 
475  /// Vectors for calculation of flux (n_boundary_edges).
477 
478  /// Vectors for calculation of mass (n_bulk_regions).
480 
481  /** Maps unique identifier of (local bulk element idx, side idx) returned by @p get_boundary_edge_uid(side)
482  * to local boundary edge.
483  * Example usage:
484  * be_id = be_id_map_[get_boundary_edge_uid(side)]
485  */
486  std::unordered_map<LongIdx, unsigned int> be_id_map_;
487 
488  /// Maps local boundary edge to its region boundary index.
490 
491  /// Offset for local part of vector of boundary edges.
493 
494 
495  // Vectors storing mass and balances of fluxes and volumes.
496  // substance, phase, region
503 
504  // Sums of the above vectors over phases and regions
513 
514  // time integrated quantities
519 
520  /// time of last calculated balance
521  double last_time_;
522 
523  /// TimeMark type for balance output of particular equation.
525 
526  /// TimeMark type for output of particular equation.
528 
529  /// true before calculating the mass at initial time, otherwise false
530  bool initial_;
531 
532  /// if true then cumulative balance is computed
534 
535  /// true before allocating necessary internal structures (Petsc matrices etc.)
537 
538  /// If the balance is on. Balance is off in the case of no balance output time marks.
540 
541  /// Add output time marks to balance output time marks.
543 
544 
545  /// MPI rank.
546  int rank_;
547 
548  /// hold count of line printed into output_
549  unsigned int output_line_counter_;
550 
551  /// marks whether YAML output has printed header
553 
554  /// Record for current balance
556 
558 
559 
560 };
561 
562 
563 
564 
565 
566 #endif // BALANCE_HH_
Balance::mesh_
const Mesh * mesh_
Definition: balance.hh:457
LocDofVec
arma::Col< IntIdx > LocDofVec
Definition: index_types.hh:28
Balance::calculate_instant
void calculate_instant(unsigned int quantity_idx, const Vec &solution)
Definition: balance.cc:633
Balance::allocate
void allocate(const std::shared_ptr< DOFHandlerMultiDim > &dh, unsigned int max_dofs_per_boundary)
Definition: balance.cc:191
Balance::Quantity
Definition: balance.hh:127
Balance::output_column_width
static const unsigned int output_column_width
Size of column in output (used if delimiter is space)
Definition: balance.hh:391
Balance::start_flux_assembly
void start_flux_assembly(std::vector< unsigned int > q_idx_vec)
Variant of the start_flux_assembly() method for a set of quantities.
Definition: balance.hh:246
Balance::be_regions_
std::vector< unsigned int > be_regions_
Maps local boundary edge to its region boundary index.
Definition: balance.hh:489
Balance::lazy_initialize
void lazy_initialize()
Definition: balance.cc:202
Balance::n_loc_dofs_seq_
unsigned int n_loc_dofs_seq_
Definition: balance.hh:435
Balance::sum_fluxes_out_
std::vector< double > sum_fluxes_out_
Definition: balance.hh:507
Balance::Balance
Balance(const std::string &file_prefix, const Mesh *mesh)
Definition: balance.cc:86
Balance::units_
UnitSI units_
Units of conserved quantities.
Definition: balance.hh:460
Balance::time_
const TimeGovernor * time_
Definition: balance.hh:557
Input
Abstract linear system class.
Definition: balance.hh:40
Balance::start_mass_assembly
void start_mass_assembly(std::vector< unsigned int > q_idx_vec)
Variant of the start_mass_assembly() method for a set of quantities.
Definition: balance.hh:233
Balance::csv_zero_vals
std::string csv_zero_vals(unsigned int cnt, char delimiter)
Return part of output represented by zero values. Count of zero values is given by cnt parameter.
Definition: balance.cc:999
Balance::Quantity::index_
const unsigned int index_
Internal index within list of quantities.
Definition: balance.hh:139
Balance::txt
@ txt
csv
Definition: balance.hh:149
Balance
Definition: balance.hh:119
Balance::balance_output_type_
TimeMark::Type balance_output_type_
TimeMark type for balance output of particular equation.
Definition: balance.hh:524
Balance::add_quantity
unsigned int add_quantity(const string &name)
Definition: balance.cc:162
file_path.hh
Balance::integrated_sources_
std::vector< double > integrated_sources_
Definition: balance.hh:515
Balance::format_csv_output_header
void format_csv_output_header(char delimiter, const std::string &comment_string)
Print output header.
Definition: balance.cc:1088
Balance::sum_sources_
std::vector< double > sum_sources_
Definition: balance.hh:509
Balance::finish_source_assembly
void finish_source_assembly(unsigned int quantity_idx)
This method must be called after assembling the matrix and vectors for computing source.
Definition: balance.cc:433
Balance::rank_
int rank_
MPI rank.
Definition: balance.hh:546
FilePath
Dedicated class for storing path to input and output files.
Definition: file_path.hh:54
Balance::output_yaml_header_
bool output_yaml_header_
marks whether YAML output has printed header
Definition: balance.hh:552
Balance::start_flux_assembly
void start_flux_assembly(unsigned int quantity_idx)
Definition: balance.cc:393
std::vector< unsigned int >
Balance::increment_fluxes_
std::vector< double > increment_fluxes_
Definition: balance.hh:517
Side::elem_idx
unsigned int elem_idx() const
Returns index of element in Mesh::element_vec_.
Definition: accessors.hh:462
Balance::cumulative
bool cumulative() const
Getter for cumulative_.
Definition: balance.hh:190
Balance::init_from_input
void init_from_input(const Input::Record &in_rec, TimeGovernor &tg)
Definition: balance.cc:129
Balance::do_yaml_output_
static bool do_yaml_output_
Definition: balance.hh:431
Balance::quantities_
std::vector< Quantity > quantities_
Names of conserved quantities.
Definition: balance.hh:455
Balance::units
void units(const UnitSI &unit)
Setter for units of conserved quantities.
Definition: balance.cc:154
Balance::add_flux_values
void add_flux_values(unsigned int quantity_idx, const DHCellSide &side, const LocDofVec &loc_dof_indices, const std::vector< double > &mat_values, double vec_value)
Definition: balance.cc:476
index_types.hh
Balance::finish_mass_assembly
void finish_mass_assembly(std::vector< unsigned int > q_idx_vec)
Variant of the finish_mass_assembly() method for a set of quantities.
Definition: balance.hh:324
Balance::finish_flux_assembly
void finish_flux_assembly(std::vector< unsigned int > q_idx_vec)
Variant of the finish_flux_assembly() method for a set of quantities.
Definition: balance.hh:334
Balance::start_mass_assembly
void start_mass_assembly(unsigned int quantity_idx)
Definition: balance.cc:384
Balance::region_mass_vec_
Vec * region_mass_vec_
Vectors for calculation of mass (n_bulk_regions).
Definition: balance.hh:479
Balance::be_flux_matrix_
Mat * be_flux_matrix_
Matrices for calculation of flux (n_boundary_edges x n_dofs).
Definition: balance.hh:467
Balance::finish_mass_assembly
void finish_mass_assembly(unsigned int quantity_idx)
This method must be called after assembling the matrix for computing mass.
Definition: balance.cc:411
DHCellSide
Side accessor allows to iterate over sides of DOF handler cell.
Definition: dh_cell_accessor.hh:176
accessors.hh
Balance::Quantity::name_
string name_
Name of quantity (for output).
Definition: balance.hh:136
Balance::output_
std::ofstream output_
Handle for file for output in given OutputFormat of balance and total fluxes over individual regions ...
Definition: balance.hh:446
Balance::output_yaml
void output_yaml(double time)
Perform output in yaml format.
Definition: balance.cc:1146
Input::Record
Accessor to the data with type Type::Record.
Definition: accessors.hh:291
Balance::region_mass_matrix_
Mat * region_mass_matrix_
Matrices for calculation of mass (n_dofs x n_bulk_regions).
Definition: balance.hh:464
Balance::legacy
@ legacy
legacy
Definition: balance.hh:148
Balance::balance_on_
bool balance_on_
If the balance is on. Balance is off in the case of no balance output time marks.
Definition: balance.hh:539
DOFHandlerMultiDim
Provides the numbering of the finite element degrees of freedom on the computational mesh.
Definition: dofhandler.hh:151
accessors.hh
Balance::cumulative_
bool cumulative_
if true then cumulative balance is computed
Definition: balance.hh:533
Balance::~Balance
~Balance()
Definition: balance.cc:103
Balance::masses_
std::vector< std::vector< double > > masses_
Definition: balance.hh:500
TimeGovernor
Basic time management functionality for unsteady (and steady) solvers (class Equation).
Definition: time_governor.hh:310
Balance::be_flux_vec_
Vec * be_flux_vec_
Vectors for calculation of flux (n_boundary_edges).
Definition: balance.hh:476
TimeMark::Type
Definition: time_marks.hh:60
Balance::sum_fluxes_in_
std::vector< double > sum_fluxes_in_
Definition: balance.hh:506
UnitSI
Class for representation SI units of Fields.
Definition: unit_si.hh:40
Balance::sum_masses_
std::vector< double > sum_masses_
Definition: balance.hh:508
Balance::fluxes_
std::vector< std::vector< double > > fluxes_
Definition: balance.hh:497
Balance::start_source_assembly
void start_source_assembly(std::vector< unsigned int > q_idx_vec)
Variant of the start_source_assembly() method for a set of quantities.
Definition: balance.hh:259
Balance::gnuplot
@ gnuplot
gnuplot
Definition: balance.hh:150
Balance::output_line_counter_
unsigned int output_line_counter_
hold count of line printed into output_
Definition: balance.hh:549
Balance::output
void output()
Perform output to file for given time instant.
Definition: balance.cc:710
Balance::initial_mass_
std::vector< double > initial_mass_
Definition: balance.hh:512
Balance::add_output_times_
bool add_output_times_
Add output time marks to balance output time marks.
Definition: balance.hh:542
Balance::calculate_mass
void calculate_mass(unsigned int quantity_idx, const Vec &solution, vector< double > &output_array)
Definition: balance.cc:608
Input::Type::Selection
Template for classes storing finite set of named values.
Definition: type_selection.hh:65
Side::side_idx
unsigned int side_idx() const
Returns local index of the side on the element.
Definition: accessors.hh:458
Input::Type::Record
Record type proxy class.
Definition: type_record.hh:182
Balance::region_source_matrix_
Mat * region_source_matrix_
Matrices for calculation of source (n_dofs x n_bulk_regions).
Definition: balance.hh:470
Balance::is_current
bool is_current()
Returns true if the current time step is marked for the balance output.
Definition: balance.cc:373
Balance::format_csv_val
std::string format_csv_val(std::string val, char delimiter, bool initial=false)
Format string value of csv output. Wrap string into quotes and if delimiter is space,...
Definition: balance.cc:1116
LongIdx
int LongIdx
Define type that represents indices of large arrays (elements, nodes, dofs etc.)
Definition: index_types.hh:24
Balance::calculate_cumulative
void calculate_cumulative(unsigned int quantity_idx, const Vec &solution)
Definition: balance.cc:549
Balance::output_format_
OutputFormat output_format_
Format of output file.
Definition: balance.hh:452
Balance::fluxes_in_
std::vector< std::vector< double > > fluxes_in_
Definition: balance.hh:498
Balance::be_offset_
int be_offset_
Offset for local part of vector of boundary edges.
Definition: balance.hh:492
Mesh
Definition: mesh.h:98
Balance::sources_in_
std::vector< std::vector< double > > sources_in_
Definition: balance.hh:501
Balance::add_source_values
void add_source_values(unsigned int quantity_idx, unsigned int region_idx, const LocDofVec &loc_dof_indices, const std::vector< double > &mult_mat_values, const std::vector< double > &add_mat_values)
Definition: balance.cc:510
Balance::sum_fluxes_
std::vector< double > sum_fluxes_
Definition: balance.hh:505
Balance::increment_sources_
std::vector< double > increment_sources_
Definition: balance.hh:518
Balance::file_prefix_
std::string file_prefix_
Save prefix passed in in constructor.
Definition: balance.hh:440
Balance::last_time_
double last_time_
time of last calculated balance
Definition: balance.hh:521
Balance::set_yaml_output
static void set_yaml_output()
Set global variable to output balance files into YAML format (in addition to the table format).
Definition: balance.cc:63
DHCellAccessor
Cell accessor allow iterate over DOF handler cells.
Definition: dh_cell_accessor.hh:43
Balance::output_csv
void output_csv(double time, char delimiter, const std::string &comment_string, unsigned int repeat=0)
Perform output in csv format.
Definition: balance.cc:1007
Balance::fluxes_out_
std::vector< std::vector< double > > fluxes_out_
Definition: balance.hh:499
Balance::get_format_selection_input_type
static const Input::Type::Selection & get_format_selection_input_type()
Input selection for file format.
Definition: balance.cc:42
unit_si.hh
Balance::get_boundary_edge_uid
LongIdx get_boundary_edge_uid(SideIter side)
Definition: balance.hh:426
Balance::n_loc_dofs_par_
unsigned int n_loc_dofs_par_
Allocation parameters. Set by the allocate method used in the lazy_initialize.
Definition: balance.hh:434
Balance::input_record_
Input::Record input_record_
Record for current balance.
Definition: balance.hh:555
Balance::output_mark_type_
TimeMark::Type output_mark_type_
TimeMark type for output of particular equation.
Definition: balance.hh:527
Balance::start_source_assembly
void start_source_assembly(unsigned int quantity_idx)
Definition: balance.cc:402
Balance::sum_sources_in_
std::vector< double > sum_sources_in_
Definition: balance.hh:510
Balance::finish_source_assembly
void finish_source_assembly(std::vector< unsigned int > q_idx_vec)
Variant of the finish_source_assembly() method for a set of quantities.
Definition: balance.hh:344
Balance::allocation_done_
bool allocation_done_
true before allocating necessary internal structures (Petsc matrices etc.)
Definition: balance.hh:536
Balance::sum_sources_out_
std::vector< double > sum_sources_out_
Definition: balance.hh:511
time_marks.hh
Balance::Quantity::Quantity
Quantity(const unsigned int index, const string &name)
Definition: balance.hh:130
Balance::balance_output_file_
FilePath balance_output_file_
File path for output_ stream.
Definition: balance.hh:443
Balance::output_yaml_
std::ofstream output_yaml_
Definition: balance.hh:449
Balance::initial_
bool initial_
true before calculating the mass at initial time, otherwise false
Definition: balance.hh:530
Balance::max_dofs_per_boundary_
unsigned int max_dofs_per_boundary_
Definition: balance.hh:436
Balance::add_mass_values
void add_mass_values(unsigned int quantity_idx, const DHCellAccessor &dh_cell, const LocDofVec &loc_dof_indices, const std::vector< double > &mat_values, double vec_value)
Definition: balance.cc:445
Balance::add_cumulative_source
void add_cumulative_source(unsigned int quantity_idx, double source)
Definition: balance.cc:539
Balance::finish_flux_assembly
void finish_flux_assembly(unsigned int quantity_idx)
This method must be called after assembling the matrix and vector for computing flux.
Definition: balance.cc:422
Balance::integrated_fluxes_
std::vector< double > integrated_fluxes_
Definition: balance.hh:516
Balance::region_source_rhs_
Mat * region_source_rhs_
Matrices for calculation of signed source (n_dofs x n_bulk_regions).
Definition: balance.hh:473
Balance::sources_out_
std::vector< std::vector< double > > sources_out_
Definition: balance.hh:502
SideIter
Definition: accessors.hh:504
Balance::be_id_map_
std::unordered_map< LongIdx, unsigned int > be_id_map_
Definition: balance.hh:486
Balance::get_input_type
static const Input::Type::Record & get_input_type()
Main balance input record type.
Definition: balance.cc:50
Balance::output_legacy
void output_legacy(double time)
Perform output in old format (for compatibility)
Definition: balance.cc:853
Balance::OutputFormat
OutputFormat
Definition: balance.hh:146
Balance::add_quantities
std::vector< unsigned int > add_quantities(const std::vector< string > &names)
Definition: balance.cc:173