Dune Core Modules (2.5.0)

Dune::LevelAmiraMeshWriter< GridType > Class Template Reference

Provides file writing facilities in the AmiraMesh format for level grids. More...

#include <dune/grid/io/file/amirameshwriter.hh>

Public Member Functions

 LevelAmiraMeshWriter ()
 Default constructor.
 
 LevelAmiraMeshWriter (const GridType &grid, int level)
 Constructor which initializes the AmiraMesh object with a given level grid.
 
void addGrid (const GridType::LevelGridView &gridView, bool splitAll=false)
 Add a grid view to the file. More...
 
void addLevelGrid (const GridType2 &grid, int level, bool splitAll=false)
 Add level grid. More...
 
void addLeafGrid (const GridType2 &grid, bool splitAll=false)
 Add leaf grid. More...
 
void addCellData (const DataContainer &data, const GridType::LevelGridView &gridView, bool GridSplitUp=false)
 Add cell data. More...
 
void addVertexData (const DataContainer &data, const GridType::LevelGridView &gridView, bool GridSplitUp=false)
 Add vertex data. More...
 
void write (const std::string &filename, bool ascii=false) const
 Write AmiraMesh object to disk. More...
 
void addUniformData (const GridType::LevelGridView &gridView, const std::array< unsigned int, dim > &n, const DataContainer &data)
 Write data on a uniform grid into an AmiraMesh file.
 

Static Public Member Functions

static void writeGrid (const GridType &grid, const std::string &filename, int level)
 Write a grid in AmiraMesh format. More...
 
template<class VectorType >
static void writeBlockVector (const GridType &grid, const VectorType &f, const std::string &filename, int level, bool GridSplitUp=false)
 Writes an ISTL block vector in AmiraMesh format. More...
 
static void writeSurfaceGrid (const GridType::LevelGridView &gridView, const std::string &filename)
 Write a 2d grid in a 3d world. More...
 

Detailed Description

template<class GridType>
class Dune::LevelAmiraMeshWriter< GridType >

Provides file writing facilities in the AmiraMesh format for level grids.

Member Function Documentation

◆ addCellData()

void Dune::AmiraMeshWriter< GridType::LevelGridView >::addCellData ( const DataContainer &  data,
const GridType::LevelGridView &  gridView,
bool  GridSplitUp = false 
)
inherited

Add cell data.

Parameters
dataAn ISTL compliant vector type
gridViewGrid view that the data belongs to
GridSplitUpIf the grid has been split up into triangles/tetrahedra you have to set GridSplitUp to make the data consistent with the grid

◆ addGrid()

void Dune::AmiraMeshWriter< GridType::LevelGridView >::addGrid ( const GridType::LevelGridView &  gridView,
bool  splitAll = false 
)
inherited

Add a grid view to the file.

Parameters
gridViewGridView to be written
splitAllIf this is set every element of the grid will be split into triangles/tetrahedra. Amira doesn't support 2d quad grids so if this is not set for a quadrilateral grid in 2d the file won't be readable by standard Amira. See the refinement documentation to see which types can be split up yet. If the grid has been split up and contains other types than triangles/tetrahedra you also have to set GridSplitUp when calling the functions "addVertexData" and "writeBlockVector" to make the data consistent with the grid!

◆ addLeafGrid()

void Dune::AmiraMeshWriter< GridType::LevelGridView >::addLeafGrid ( const GridType2 &  grid,
bool  splitAll = false 
)
inherited

Add leaf grid.

Parameters
gridGrid to be written
splitAllIf this is set every element of the grid will be split into triangles/tetrahedra. Amira doesn't support 2d quad grids so if this is not set for a quadrilateral grid in 2d the file won't be readable by standard Amira. See the refinement documentation to see which types can be split up yet. If the grid has been split up and contains other types than triangles/tetrahedra you also have to set GridSplitUp when calling the functions "addVertexData" and "writeBlockVector" to make the data consistent with the grid!

◆ addLevelGrid()

void Dune::AmiraMeshWriter< GridType::LevelGridView >::addLevelGrid ( const GridType2 &  grid,
int  level,
bool  splitAll = false 
)
inherited

Add level grid.

Parameters
gridGrid to be written
levelLevel of the level grid that is to be written
splitAllIf this is set every element of the grid will be split into triangles/tetrahedra. Amira doesn't support 2d quad grids so if this is not set for a quadrilateral grid in 2d the file won't be readable by standard Amira. See the refinement documentation to see which types can be split up yet. If the grid has been split up and contains other types than triangles/tetrahedra you also have to set GridSplitUp when calling the functions "addVertexData" and "writeBlockVector" to make the data consistent with the grid!

◆ addVertexData()

void Dune::AmiraMeshWriter< GridType::LevelGridView >::addVertexData ( const DataContainer &  data,
const GridType::LevelGridView &  gridView,
bool  GridSplitUp = false 
)
inherited

Add vertex data.

Parameters
dataAn ISTL compliant vector type
gridViewGrid view that the data belongs to
GridSplitUpIf the grid has been split up into triangles/tetrahedra you have to set GridSplitUp to make the data consistent with the grid

◆ write()

void Dune::AmiraMeshWriter< GridType::LevelGridView >::write ( const std::string &  filename,
bool  ascii = false 
) const
inherited

Write AmiraMesh object to disk.

Parameters
filenameName of the file to write to
asciiSet this if you want an ascii AmiraMesh file

◆ writeBlockVector()

template<class GridType >
template<class VectorType >
static void Dune::LevelAmiraMeshWriter< GridType >::writeBlockVector ( const GridType &  grid,
const VectorType &  f,
const std::string &  filename,
int  level,
bool  GridSplitUp = false 
)
inlinestatic

Writes an ISTL block vector in AmiraMesh format.

Parameters
gridThe grid objects that the vector lives on
fThe vector to be written. Has to comply with the ISTL conventions
filenameThe filename
levelThe level of the grid that the vector lives on
GridSplitUpIf the grid has been split up into triangles/tetrahedra you have to set this parameter to make the data consistent with the grid

References Dune::AmiraMeshWriter< GridView >::addCellData(), Dune::AmiraMeshWriter< GridView >::addVertexData(), and Dune::AmiraMeshWriter< GridView >::write().

◆ writeGrid()

template<class GridType >
static void Dune::LevelAmiraMeshWriter< GridType >::writeGrid ( const GridType &  grid,
const std::string &  filename,
int  level 
)
inlinestatic

Write a grid in AmiraMesh format.

Parameters
gridThe grid objects that is to be written
filenameThe filename
levelThe level to be written

References Dune::AmiraMeshWriter< GridView >::write().

◆ writeSurfaceGrid()

void Dune::AmiraMeshWriter< GridType::LevelGridView >::writeSurfaceGrid ( const GridType::LevelGridView &  gridView,
const std::string &  filename 
)
staticinherited

Write a 2d grid in a 3d world.

Technically, the format written is 'HyperSurface', not 'AmiraMesh'. AmiraMesh doesn't support 2d grids in a 3d world. Hypersurface is the native Amira format for such grids. Historically, it is the ancestor of the AmiraMesh format, and syntactically it is fairly similar.

Currently, quadrilaterals will get split into triangles.

Note
This code is experimental and may change withour prior warning

The documentation for this class was generated from the following file:
Creative Commons License   |  Legal Statements / Impressum  |  Hosted by TU Dresden  |  generated with Hugo v0.111.3 (Nov 23, 23:29, 2024)