16 #ifndef dealii__data_out_base_h 17 #define dealii__data_out_base_h 20 #include <deal.II/base/config.h> 21 #include <deal.II/base/point.h> 22 #include <deal.II/base/table.h> 23 #include <deal.II/base/geometry_info.h> 24 #include <deal.II/base/std_cxx11/tuple.h> 31 #include <deal.II/base/mpi.h> 35 #ifdef DEAL_II_HAVE_TECPLOT 42 DEAL_II_NAMESPACE_OPEN
237 template <
int dim,
int spacedim=dim>
353 <<
"It is not possible to have a structural dimension of " << arg1
354 <<
" to be larger than the space dimension of the surrounding" 355 <<
" space " << arg2);
371 template<
typename FlagsType>
402 template<
typename FlagsType>
407 template<
typename FlagsType>
412 template<
typename FlagsType>
415 return sizeof(FlagsType);
455 DXFlags (
const bool write_neighbors =
false,
456 const bool int_binary =
false,
457 const bool coordinates_binary =
false,
458 const bool data_binary =
false);
496 UcdFlags (
const bool write_preamble =
false);
556 const bool bicubic_patch =
false,
557 const bool external_data =
false);
722 bool is_grey ()
const;
733 const double min_value,
734 const double max_value);
753 default_color_function (
const double value,
754 const double min_value,
755 const double max_value);
763 grey_scale_color_function (
const double value,
764 const double min_value,
765 const double max_value);
774 reverse_grey_scale_color_function (
const double value,
775 const double min_value,
776 const double max_value);
781 EpsFlags (
const unsigned int height_vector = 0,
782 const unsigned int color_vector = 0,
784 const unsigned int size = 300,
785 const double line_width = 0.5,
786 const double azimut_angle = 60,
787 const double turn_angle = 30,
788 const double z_scaling = 1.0,
789 const bool draw_mesh =
true,
790 const bool draw_cells =
true,
791 const bool shade_cells =
true,
792 const ColorFunction color_function= &default_color_function);
851 TecplotFlags (
const char *tecplot_binary_file_name = NULL,
852 const char *zone_name = NULL,
853 const double solution_time = -1.0);
921 VtkFlags (
const double time = std::numeric_limits<double>::min(),
922 const unsigned int cycle = std::numeric_limits<unsigned int>::min(),
923 const bool print_date_and_time =
true,
959 unsigned int line_thickness;
974 SvgFlags(
const unsigned int height_vector = 0,
975 const int azimuth_angle = 37,
976 const int polar_angle = 45,
977 const unsigned int line_thickness = 1,
978 const bool margin =
true,
979 const bool draw_colorbar =
true);
1025 const bool xdmf_hdf5_output =
false);
1079 return (lhs(0) < rhs(0) || (!(rhs(0) < lhs(0)) && (lhs(1) < rhs(1) || (!(rhs(1) < lhs(1)) && lhs(2) < rhs(2)))));
1083 typedef std::multimap<Point<3>,
unsigned int,
Point3Comp> Map3DPoint;
1115 void internal_add_cell(
const unsigned int &cell_index,
const unsigned int &pt_index);
1127 void write_point(
const unsigned int &index,
const Point<dim> &p);
1133 void write_cell(
unsigned int index,
unsigned int start,
unsigned int d1,
unsigned int d2,
unsigned int d3);
1141 void write_data_set(
const std::string &name,
const unsigned int &dimension,
const unsigned int &set_num,
const Table<2,double> &data_vectors);
1147 void fill_node_data(std::vector<double> &node_data)
const;
1153 void fill_cell_data(
const unsigned int &local_node_offset, std::vector<unsigned int> &cell_data)
const;
1160 return data_set_names.at(set_num);
1168 return data_set_dims.at(set_num);
1177 return &data_sets[set_num][0];
1186 return existing_points.size();
1195 return filtered_cells.size()/n_cell_verts;
1204 return data_set_names.size();
1298 template <
int dim,
int spacedim>
1300 const std::vector<std::string> &data_names,
1301 const std::vector<std_cxx11::tuple<unsigned int, unsigned int, std::string> > &vector_data_ranges,
1349 template <
int spacedim>
1351 const std::vector<std::string> &data_names,
1352 const std::vector<std_cxx11::tuple<unsigned int, unsigned int, std::string> > &vector_data_ranges,
1361 template <
int dim,
int spacedim>
1363 const std::vector<std::string> &data_names,
1364 const std::vector<std_cxx11::tuple<unsigned int, unsigned int, std::string> > &vector_data_ranges,
1378 template <
int dim,
int spacedim>
1380 const std::vector<std::string> &data_names,
1381 const std::vector<std_cxx11::tuple<unsigned int, unsigned int, std::string> > &vector_data_ranges,
1441 template <
int dim,
int spacedim>
1443 const std::vector<std::string> &data_names,
1444 const std::vector<std_cxx11::tuple<unsigned int, unsigned int, std::string> > &vector_data_ranges,
1493 template <
int dim,
int spacedim>
1495 const std::vector<std::string> &data_names,
1496 const std::vector<std_cxx11::tuple<unsigned int, unsigned int, std::string> > &vector_data_ranges,
1506 template <
int dim,
int spacedim>
1508 const std::vector<std::string> &data_names,
1509 const std::vector<std_cxx11::tuple<unsigned int, unsigned int, std::string> > &vector_data_ranges,
1532 template <
int dim,
int spacedim>
1535 const std::vector<std::string> &data_names,
1536 const std::vector<std_cxx11::tuple<unsigned int, unsigned int, std::string> > &vector_data_ranges,
1554 template <
int dim,
int spacedim>
1556 const std::vector<std::string> &data_names,
1557 const std::vector<std_cxx11::tuple<unsigned int, unsigned int, std::string> > &vector_data_ranges,
1580 template <
int dim,
int spacedim>
1582 const std::vector<std::string> &data_names,
1583 const std::vector<std_cxx11::tuple<unsigned int, unsigned int, std::string> > &vector_data_ranges,
1611 template <
int dim,
int spacedim>
1613 const std::vector<std::string> &data_names,
1614 const std::vector<std_cxx11::tuple<unsigned int, unsigned int, std::string> > &vector_data_ranges,
1638 template <
int dim,
int spacedim>
1640 const std::vector<std::string> &data_names,
1641 const std::vector<std_cxx11::tuple<unsigned int, unsigned int, std::string> > &vector_data_ranges,
1665 template <
int spacedim>
1667 const std::vector<std::string> &data_names,
1668 const std::vector<std_cxx11::tuple<unsigned int, unsigned int, std::string> > &vector_data_ranges,
1709 template <
int dim,
int spacedim>
1712 const std::vector<std::string> &data_names,
1713 const std::vector<std_cxx11::tuple<unsigned int, unsigned int, std::string> > &vector_data_ranges,
1721 template <
int dim,
int spacedim>
1724 const std::string &filename,
1734 template <
int dim,
int spacedim>
1737 const bool write_mesh_file,
1738 const std::string &mesh_filename,
1739 const std::string &solution_filename,
1748 template <
int dim,
int spacedim>
1750 const std::vector<std::string> &data_names,
1751 const std::vector<std_cxx11::tuple<unsigned int, unsigned int, std::string> > &vector_data_ranges,
1765 std::pair<unsigned int, unsigned int>
1818 <<
"The number of points in this data set is " << arg1
1819 <<
", but we expected " << arg2 <<
" in each space direction.");
1833 <<
"There was an error opening Tecplot file " << arg1
1953 template <
int dim,
int spacedim=dim>
1972 void write_dx (std::ostream &out)
const;
1978 void write_eps (std::ostream &out)
const;
1984 void write_gmv (std::ostream &out)
const;
2015 void write_ucd (std::ostream &out)
const;
2028 void write_vtk (std::ostream &out)
const;
2044 void write_vtu (std::ostream &out)
const;
2054 void write_vtu_in_parallel (
const char *filename, MPI_Comm comm)
const;
2086 void write_pvtu_record (std::ostream &out,
2087 const std::vector<std::string> &piece_names)
const;
2138 void write_pvd_record (std::ostream &out,
2139 const std::vector<std::pair<double,std::string> > ×_and_names)
const;
2152 void write_visit_record (std::ostream &out,
2153 const std::vector<std::string> &piece_names)
const;
2184 void write_visit_record (std::ostream &out,
2185 const std::vector<std::vector<std::string> > &piece_names)
const;
2191 void write_svg(std::ostream &out)
const;
2211 const std::string &h5_filename,
2212 const double cur_time,
2213 MPI_Comm comm)
const;
2221 const std::string &h5_mesh_filename,
2222 const std::string &h5_solution_filename,
2223 const double cur_time,
2224 MPI_Comm comm)
const;
2246 void write_xdmf_file (
const std::vector<XDMFEntry> &entries,
2247 const std::string &filename,
2248 MPI_Comm comm)
const;
2264 const std::string &filename,
2265 MPI_Comm comm)
const;
2275 const bool write_mesh_file,
2276 const std::string &mesh_filename,
2277 const std::string &solution_filename,
2278 MPI_Comm comm)
const;
2297 void write (std::ostream &out,
2311 template<
typename FlagType>
2312 void set_flags (
const FlagType &flags);
2366 const std::vector<DataOutBase::Patch<dim,spacedim> > &
2367 get_patches ()
const = 0;
2374 std::vector<std::string>
2375 get_dataset_names ()
const = 0;
2396 std::vector<std_cxx11::tuple<unsigned int, unsigned int, std::string> >
2397 get_vector_data_ranges ()
const;
2525 template <
int dim,
int spacedim=dim>
2534 void read (std::istream &in);
2578 <<
"Either the dimensions <" << arg1 <<
"> and <" 2579 << arg2 <<
"> or the space dimensions <" 2580 << arg3 <<
"> and <" << arg4
2581 <<
"> do not match!");
2592 virtual const std::vector<::DataOutBase::Patch<dim,spacedim> > &
2593 get_patches ()
const;
2601 virtual std::vector<std::string> get_dataset_names ()
const;
2622 std::vector<std_cxx11::tuple<unsigned int, unsigned int, std::string> >
2623 get_vector_data_ranges ()
const;
2630 std::vector<::DataOutBase::Patch<dim,spacedim> >
patches;
2631 std::vector<std::string> dataset_names;
2637 std::vector<std_cxx11::tuple<unsigned int, unsigned int, std::string> >
2667 std::string
indent(
const unsigned int indent_level)
const 2669 std::string res =
"";
2670 for (
unsigned int i=0; i<indent_level; ++i) res +=
" ";
2676 XDMFEntry(
const std::string filename,
const double time,
const unsigned int nodes,
const unsigned int cells,
const unsigned int dim) : valid(
true), h5_sol_filename(filename), h5_mesh_filename(filename), entry_time(time), num_nodes(nodes), num_cells(cells), dimension(dim) {};
2677 XDMFEntry(
const std::string mesh_filename,
const std::string solution_filename,
const double time,
const unsigned int nodes,
const unsigned int cells,
const unsigned int dim) : valid(
true), h5_sol_filename(solution_filename), h5_mesh_filename(mesh_filename), entry_time(time), num_nodes(nodes), num_cells(cells), dimension(dim) {};
2684 attribute_dims[attr_name] = dimension;
2690 template <
class Archive>
2705 std::string get_xdmf_content(
const unsigned int indent_level)
const;
2718 return (red == green) && (red == blue);
2732 template <
int dim,
int spacedim>
2747 template <
int dim,
int spacedim>
2754 DEAL_II_NAMESPACE_CLOSE
void write_gmv(const std::vector< Patch< dim, spacedim > > &patches, const std::vector< std::string > &data_names, const std::vector< std_cxx11::tuple< unsigned int, unsigned int, std::string > > &vector_data_ranges, const GmvFlags &flags, std::ostream &out)
static const unsigned int invalid_unsigned_int
Map3DPoint existing_points
Map of points to an internal index.
unsigned int height_vector
void write_vtu_footer(std::ostream &out)
static void declare_parameters(ParameterHandler &prm)
void write_ucd(const std::vector< Patch< dim, spacedim > > &patches, const std::vector< std::string > &data_names, const std::vector< std_cxx11::tuple< unsigned int, unsigned int, std::string > > &vector_data_ranges, const UcdFlags &flags, std::ostream &out)
DeclException0(ExcNoPatches)
std::size_t memory_consumption() const
std::map< unsigned int, unsigned int > filtered_cells
Map of cells to the filtered points.
std::pair< unsigned int, unsigned int > determine_intermediate_format_dimensions(std::istream &input)
void swap(Patch< dim, spacedim > &other_patch)
bool valid
Whether this entry is valid and contains data to be written.
unsigned int neighbors[dim > 0 ? GeometryInfo< dim >::faces_per_cell :1]
void write_vtu_header(std::ostream &out, const VtkFlags &flags)
unsigned int n_nodes() const
double entry_time
The simulation time associated with this entry.
ZlibCompressionLevel compression_level
std::vector< std_cxx11::tuple< unsigned int, unsigned int, std::string > > vector_data_ranges
void write_filtered_data(const std::vector< Patch< dim, spacedim > > &patches, const std::vector< std::string > &data_names, const std::vector< std_cxx11::tuple< unsigned int, unsigned int, std::string > > &vector_data_ranges, DataOutFilter &filtered_data)
unsigned int default_subdivisions
std::vector< unsigned int > data_set_dims
Data set dimensions.
Point< spacedim > vertices[GeometryInfo< dim >::vertices_per_cell]
bool filter_duplicate_vertices
std::vector< std::vector< double > > data_sets
Data set data.
std::map< std::string, unsigned int > attribute_dims
The attributes associated with this entry and their dimension.
const char * tecplot_binary_file_name
int n_cell_verts
Number of vertices per cell.
DataOutBase::PovrayFlags povray_flags
std::string get_data_set_name(const unsigned int &set_num) const
DataOutBase::DataOutFilterFlags flags
Flags used to specify filtering behavior.
unsigned int n_data_sets() const
std::string default_suffix(const OutputFormat output_format)
std::istream & operator>>(std::istream &in, Patch< dim, spacedim > &patch)
std::string indent(const unsigned int indent_level) const
Small function to create indentation for XML file.
unsigned int n_cells() const
void serialize(Archive &ar, const unsigned int)
std::vector< std::string > data_set_names
Data set names.
void add_attribute(const std::string &attr_name, const unsigned int dimension)
void write_povray(const std::vector< Patch< dim, spacedim > > &patches, const std::vector< std::string > &data_names, const std::vector< std_cxx11::tuple< unsigned int, unsigned int, std::string > > &vector_data_ranges, const PovrayFlags &flags, std::ostream &out)
void write_eps(const std::vector< Patch< 2, spacedim > > &patches, const std::vector< std::string > &data_names, const std::vector< std_cxx11::tuple< unsigned int, unsigned int, std::string > > &vector_data_ranges, const EpsFlags &flags, std::ostream &out)
void parse_parameters(const ParameterHandler &prm)
DataOutBase::Deal_II_IntermediateFlags deal_II_intermediate_flags
int node_dim
Dimensionality of the nodes, used to properly output filtered data.
OutputFormat parse_output_format(const std::string &format_name)
void write_svg(const std::vector< Patch< 2, spacedim > > &patches, const std::vector< std::string > &data_names, const std::vector< std_cxx11::tuple< unsigned int, unsigned int, std::string > > &vector_data_ranges, const SvgFlags &flags, std::ostream &out)
void write_dx(const std::vector< Patch< dim, spacedim > > &patches, const std::vector< std::string > &data_names, const std::vector< std_cxx11::tuple< unsigned int, unsigned int, std::string > > &vector_data_ranges, const DXFlags &flags, std::ostream &out)
ColorFunction color_function
unsigned int n_subdivisions
DataOutBase::TecplotFlags tecplot_flags
std::ostream & operator<<(std::ostream &out, const Patch< dim, spacedim > &patch)
DataOutBase::SvgFlags svg_flags
std::string h5_sol_filename
The name of the HDF5 heavy data solution and/or mesh files this entry references. ...
const double * get_data_set(const unsigned int &set_num) const
unsigned int get_data_set_dim(const unsigned int &set_num) const
void write_vtk(const std::vector< Patch< dim, spacedim > > &patches, const std::vector< std::string > &data_names, const std::vector< std_cxx11::tuple< unsigned int, unsigned int, std::string > > &vector_data_ranges, const VtkFlags &flags, std::ostream &out)
bool operator==(const Patch &patch) const
DeclException1(ExcErrorOpeningTecplotFile, char *,<< "There was an error opening Tecplot file "<< arg1<< " for output")
void write_vtu(const std::vector< Patch< dim, spacedim > > &patches, const std::vector< std::string > &data_names, const std::vector< std_cxx11::tuple< unsigned int, unsigned int, std::string > > &vector_data_ranges, const VtkFlags &flags, std::ostream &out)
static const unsigned int no_neighbor
DataOutBase::GmvFlags gmv_flags
DataOutBase::VtkFlags vtk_flags
std::vector<::DataOutBase::Patch< dim, spacedim > > patches
void write_tecplot_binary(const std::vector< Patch< dim, spacedim > > &patches, const std::vector< std::string > &data_names, const std::vector< std_cxx11::tuple< unsigned int, unsigned int, std::string > > &vector_data_ranges, const TecplotFlags &flags, std::ostream &out)
DeclException2(ExcInvalidCombinationOfDimensions, int, int,<< "It is not possible to have a structural dimension of "<< arg1<< " to be larger than the space dimension of the surrounding"<< " space "<< arg2)
static const unsigned int space_dim
DataOutBase::GnuplotFlags gnuplot_flags
unsigned int num_nodes
The number of nodes, cells and dimensionality associated with the data.
#define DeclException4(Exception4, type1, type2, type3, type4, outsequence)
void write_tecplot(const std::vector< Patch< dim, spacedim > > &patches, const std::vector< std::string > &data_names, const std::vector< std_cxx11::tuple< unsigned int, unsigned int, std::string > > &vector_data_ranges, const TecplotFlags &flags, std::ostream &out)
unsigned int color_vector
void write_vtu_main(const std::vector< Patch< dim, spacedim > > &patches, const std::vector< std::string > &data_names, const std::vector< std_cxx11::tuple< unsigned int, unsigned int, std::string > > &vector_data_ranges, const VtkFlags &flags, std::ostream &out)
DataOutBase::OutputFormat default_fmt
void write_hdf5_parallel(const std::vector< Patch< dim, spacedim > > &patches, const DataOutFilter &data_filter, const std::string &filename, MPI_Comm comm)
DataOutBase::EpsFlags eps_flags
void write_deal_II_intermediate(const std::vector< Patch< dim, spacedim > > &patches, const std::vector< std::string > &data_names, const std::vector< std_cxx11::tuple< unsigned int, unsigned int, std::string > > &vector_data_ranges, const Deal_II_IntermediateFlags &flags, std::ostream &out)
void write_gnuplot(const std::vector< Patch< dim, spacedim > > &patches, const std::vector< std::string > &data_names, const std::vector< std_cxx11::tuple< unsigned int, unsigned int, std::string > > &vector_data_ranges, const GnuplotFlags &flags, std::ostream &out)
std::size_t memory_consumption() const
std::map< unsigned int, unsigned int > filtered_points
Map of actual point index to internal point index.
bool points_are_available
std::string get_output_format_names()
DataOutBase::UcdFlags ucd_flags
unsigned int height_vector
DataOutBase::DXFlags dx_flags