Reference documentation for deal.II version 9.1.0-pre
Classes | Public Member Functions | Private Member Functions | Private Attributes | List of all members
DataOutBase::DataOutFilter Class Reference

#include <deal.II/base/data_out_base.h>

Classes

struct  Point3Comp
 

Public Member Functions

 DataOutFilter ()
 
 DataOutFilter (const DataOutBase::DataOutFilterFlags &flags)
 
template<int dim>
void write_point (const unsigned int index, const Point< dim > &p)
 
template<int dim>
void write_cell (const unsigned int index, const unsigned int start, const unsigned int d1, const unsigned int d2, const unsigned int d3)
 
void write_data_set (const std::string &name, const unsigned int dimension, const unsigned int set_num, const Table< 2, double > &data_vectors)
 
void fill_node_data (std::vector< double > &node_data) const
 
void fill_cell_data (const unsigned int local_node_offset, std::vector< unsigned int > &cell_data) const
 
std::string get_data_set_name (const unsigned int set_num) const
 
unsigned int get_data_set_dim (const unsigned int set_num) const
 
const double * get_data_set (const unsigned int set_num) const
 
unsigned int n_nodes () const
 
unsigned int n_cells () const
 
unsigned int n_data_sets () const
 
void flush_points ()
 
void flush_cells ()
 

Private Member Functions

void internal_add_cell (const unsigned int cell_index, const unsigned int pt_index)
 

Private Attributes

DataOutBase::DataOutFilterFlags flags
 
unsigned int node_dim
 
unsigned int vertices_per_cell
 
Map3DPoint existing_points
 
std::map< unsigned int, unsigned int > filtered_points
 
std::map< unsigned int, unsigned int > filtered_cells
 
std::vector< std::string > data_set_names
 
std::vector< unsigned int > data_set_dims
 
std::vector< std::vector< double > > data_sets
 

Detailed Description

DataOutFilter provides a way to remove redundant vertices and values generated by the deal.II output. By default, DataOutBase and the classes that build on it output data at each corner of each cell. This means that data is output multiple times for each vertex of the mesh. The purpose of this scheme is to support output of discontinuous quantities, either because the finite element space is discontinuous or because the quantity that is output is computed from a solution field and is discontinuous across faces.

This class is an attempt to rein in the amount of data that is written. If the fields that are written to files are indeed discontinuous, the only way to faithfully represent them is indeed to write multiple values for each vertex (this is typically done by writing multiple node locations for the same vertex and defining data at these nodes). However, for fine meshes, one may not necessarily be interested in an exact representation of output fields that will likely only have small discontinuities. Rather, it may be sufficient to just output one value per vertex, which may be chosen arbitrarily from among those that are defined at this vertex from any of the adjacent cells.

Definition at line 1329 of file data_out_base.h.

Constructor & Destructor Documentation

DataOutBase::DataOutFilter::DataOutFilter ( )

Default constructor.

Definition at line 457 of file data_out_base.cc.

DataOutBase::DataOutFilter::DataOutFilter ( const DataOutBase::DataOutFilterFlags flags)

Destructor with a given set of flags. See DataOutFilterFlags for possible flags.

Definition at line 465 of file data_out_base.cc.

Member Function Documentation

template<int dim>
void DataOutBase::DataOutFilter::write_point ( const unsigned int  index,
const Point< dim > &  p 
)

Write a point with the specified index into the filtered data set. If the point already exists and we are filtering redundant values, the provided index will internally refer to another recorded point.

Definition at line 475 of file data_out_base.cc.

template<int dim>
void DataOutBase::DataOutFilter::write_cell ( const unsigned int  index,
const unsigned int  start,
const unsigned int  d1,
const unsigned int  d2,
const unsigned int  d3 
)

Record a deal.II cell in the internal reordered format.

Definition at line 607 of file data_out_base.cc.

void DataOutBase::DataOutFilter::write_data_set ( const std::string &  name,
const unsigned int  dimension,
const unsigned int  set_num,
const Table< 2, double > &  data_vectors 
)

Filter and record a data set. If there are multiple values at a given vertex and redundant values are being removed, one is arbitrarily chosen as the recorded value. In the future this can be expanded to average/min/max multiple values at a given vertex.

Definition at line 638 of file data_out_base.cc.

void DataOutBase::DataOutFilter::fill_node_data ( std::vector< double > &  node_data) const

Resize and fill a vector with all the filtered node vertex points, for output to a file.

Definition at line 513 of file data_out_base.cc.

void DataOutBase::DataOutFilter::fill_cell_data ( const unsigned int  local_node_offset,
std::vector< unsigned int > &  cell_data 
) const

Resize and fill a vector with all the filtered cell vertex indices, for output to a file.

Definition at line 529 of file data_out_base.cc.

std::string DataOutBase::DataOutFilter::get_data_set_name ( const unsigned int  set_num) const

Get the name of the data set indicated by the set number.

Definition at line 546 of file data_out_base.cc.

unsigned int DataOutBase::DataOutFilter::get_data_set_dim ( const unsigned int  set_num) const

Get the dimensionality of the data set indicated by the set number.

Definition at line 554 of file data_out_base.cc.

const double * DataOutBase::DataOutFilter::get_data_set ( const unsigned int  set_num) const

Get the raw double valued data of the data set indicated by the set number.

Definition at line 562 of file data_out_base.cc.

unsigned int DataOutBase::DataOutFilter::n_nodes ( ) const

Return the number of nodes in this DataOutFilter. This may be smaller than the original number of nodes if filtering is enabled.

Definition at line 570 of file data_out_base.cc.

unsigned int DataOutBase::DataOutFilter::n_cells ( ) const

Return the number of filtered cells in this DataOutFilter. Cells are not filtered so this will be the original number of cells.

Definition at line 578 of file data_out_base.cc.

unsigned int DataOutBase::DataOutFilter::n_data_sets ( ) const

Return the number of filtered data sets in this DataOutFilter. Data sets are not filtered so this will be the original number of data sets.

Definition at line 586 of file data_out_base.cc.

void DataOutBase::DataOutFilter::flush_points ( )

Empty functions to do base class inheritance.

Definition at line 594 of file data_out_base.cc.

void DataOutBase::DataOutFilter::flush_cells ( )

Empty functions to do base class inheritance.

Definition at line 600 of file data_out_base.cc.

void DataOutBase::DataOutFilter::internal_add_cell ( const unsigned int  cell_index,
const unsigned int  pt_index 
)
private

Record a cell vertex index based on the internal reordering.

Definition at line 504 of file data_out_base.cc.

Member Data Documentation

DataOutBase::DataOutFilterFlags DataOutBase::DataOutFilter::flags
private

Flags used to specify filtering behavior.

Definition at line 1477 of file data_out_base.h.

unsigned int DataOutBase::DataOutFilter::node_dim
private

The number of space dimensions in which the vertices represented by the current object live. This corresponds to the usual dim argument, but since this class is not templated on the dimension, we need to store it here.

Definition at line 1485 of file data_out_base.h.

unsigned int DataOutBase::DataOutFilter::vertices_per_cell
private

The number of vertices per cell. Equal to GeometryInfo<node_dim>::vertices_per_cell. We need to store it as a run-time variable here because the dimension node_dim is also a run-time variable.

Definition at line 1493 of file data_out_base.h.

Map3DPoint DataOutBase::DataOutFilter::existing_points
private

Map of points to an internal index.

Definition at line 1498 of file data_out_base.h.

std::map<unsigned int, unsigned int> DataOutBase::DataOutFilter::filtered_points
private

Map of actual point index to internal point index.

Definition at line 1503 of file data_out_base.h.

std::map<unsigned int, unsigned int> DataOutBase::DataOutFilter::filtered_cells
private

Map of cells to the filtered points.

Definition at line 1508 of file data_out_base.h.

std::vector<std::string> DataOutBase::DataOutFilter::data_set_names
private

Data set names.

Definition at line 1513 of file data_out_base.h.

std::vector<unsigned int> DataOutBase::DataOutFilter::data_set_dims
private

Data set dimensions.

Definition at line 1518 of file data_out_base.h.

std::vector<std::vector<double> > DataOutBase::DataOutFilter::data_sets
private

Data set data.

Definition at line 1523 of file data_out_base.h.


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