libMesh
Public Member Functions | Protected Member Functions | Protected Attributes | Private Attributes | List of all members
libMesh::MeshInput< MT > Class Template Referenceabstract

This class defines an abstract interface for Mesh input. More...

#include <mesh_base.h>

Public Member Functions

virtual ~MeshInput ()
 Destructor. More...
 
virtual void read (const std::string &)=0
 This method implements reading a mesh from a specified file. More...
 
bool is_parallel_format () const
 Returns true iff this mesh file format and input class are parallelized, so that all processors can read their share of the data at once. More...
 

Protected Member Functions

 MeshInput (bool is_parallel_format=false)
 Default constructor. More...
 
 MeshInput (MT &, const bool is_parallel_format=false)
 Constructor. More...
 
MT & mesh ()
 
void set_n_partitions (unsigned int n_parts)
 Sets the number of partitions in the mesh. More...
 
void skip_comment_lines (std::istream &in, const char comment_start)
 Reads input from in, skipping all the lines that start with the character comment_start. More...
 

Protected Attributes

std::vector< bool > elems_of_dimension
 A vector of bools describing what dimension elements have been encountered when reading a mesh. More...
 

Private Attributes

MT * _obj
 A pointer to a non-const object object. More...
 
const bool _is_parallel_format
 Flag specifying whether this format is parallel-capable. More...
 

Detailed Description

template<class MT>
class libMesh::MeshInput< MT >

This class defines an abstract interface for Mesh input.

Specific classes derived from this class actually implement reading various mesh formats.

Author
Benjamin S. Kirk
Date
2004

Definition at line 56 of file mesh_base.h.

Constructor & Destructor Documentation

◆ MeshInput() [1/2]

template<class MT >
libMesh::MeshInput< MT >::MeshInput ( bool  is_parallel_format = false)
inlineexplicitprotected

Default constructor.

Will set the _obj to nullptr, effectively rendering this object useless.

Definition at line 139 of file mesh_input.h.

139  :
141  _obj (nullptr),
143 {
144 }
const bool _is_parallel_format
Flag specifying whether this format is parallel-capable.
Definition: mesh_input.h:130
std::vector< bool > elems_of_dimension
A vector of bools describing what dimension elements have been encountered when reading a mesh...
Definition: mesh_input.h:107
bool is_parallel_format() const
Returns true iff this mesh file format and input class are parallelized, so that all processors can r...
Definition: mesh_input.h:87
MT * _obj
A pointer to a non-const object object.
Definition: mesh_input.h:123

◆ MeshInput() [2/2]

template<class MT>
libMesh::MeshInput< MT >::MeshInput ( MT &  obj,
const bool  is_parallel_format = false 
)
inlineexplicitprotected

Constructor.

Takes a writable reference to an object. This is the constructor required to read an object.

Definition at line 150 of file mesh_input.h.

150  :
152  _obj (&obj),
154 {
155  if (!_is_parallel_format && !this->mesh().is_serial())
156  {
157  if (this->mesh().processor_id() == 0)
158  {
159  libmesh_do_once(libMesh::out <<
160  "Warning: This MeshOutput subclass only supports meshes which have been serialized!"
161  << std::endl;);
162  }
163  }
164 }
const bool _is_parallel_format
Flag specifying whether this format is parallel-capable.
Definition: mesh_input.h:130
std::vector< bool > elems_of_dimension
A vector of bools describing what dimension elements have been encountered when reading a mesh...
Definition: mesh_input.h:107
bool is_parallel_format() const
Returns true iff this mesh file format and input class are parallelized, so that all processors can r...
Definition: mesh_input.h:87
OStreamProxy out
MT * _obj
A pointer to a non-const object object.
Definition: mesh_input.h:123

◆ ~MeshInput()

template<class MT >
libMesh::MeshInput< MT >::~MeshInput ( )
inlinevirtual

Destructor.

Definition at line 170 of file mesh_input.h.

171 {
172 }

Member Function Documentation

◆ is_parallel_format()

template<class MT>
bool libMesh::MeshInput< MT >::is_parallel_format ( ) const
inline

Returns true iff this mesh file format and input class are parallelized, so that all processors can read their share of the data at once.

Definition at line 87 of file mesh_input.h.

Referenced by MeshInputTest::testSingleElementImpl().

87 { return this->_is_parallel_format; }
const bool _is_parallel_format
Flag specifying whether this format is parallel-capable.
Definition: mesh_input.h:130

◆ mesh()

template<class MT >
MT & libMesh::MeshInput< MT >::mesh ( )
inlineprotected
Returns
The object as a writable reference.

Definition at line 178 of file mesh_input.h.

Referenced by libMesh::GMVIO::_read_nodes(), libMesh::GMVIO::_read_one_cell(), libMesh::AbaqusIO::assign_boundary_node_ids(), libMesh::AbaqusIO::assign_sideset_ids(), libMesh::AbaqusIO::assign_subdomain_ids(), libMesh::ExodusII_IO::copy_elemental_solution(), libMesh::Nemesis_IO::copy_elemental_solution(), libMesh::GMVIO::copy_nodal_solution(), libMesh::ExodusII_IO::copy_nodal_solution(), libMesh::Nemesis_IO::copy_nodal_solution(), libMesh::TetGenIO::element_in(), libMesh::UNVIO::elements_in(), libMesh::UNVIO::groups_in(), libMesh::TetGenIO::node_in(), libMesh::UNVIO::nodes_in(), libMesh::AbaqusIO::read(), libMesh::NameBasedIO::read(), libMesh::TetGenIO::read(), libMesh::GMVIO::read(), libMesh::Nemesis_IO::read(), libMesh::ExodusII_IO::read(), libMesh::XdrIO::read(), libMesh::CheckpointIO::read(), libMesh::VTKIO::read(), libMesh::CheckpointIO::read_bcs(), libMesh::CheckpointIO::read_connectivity(), libMesh::ExodusII_IO::read_elemental_variable(), libMesh::AbaqusIO::read_elements(), libMesh::ExodusII_IO::read_header(), libMesh::CheckpointIO::read_header(), libMesh::XdrIO::read_header(), libMesh::UCDIO::read_implementation(), libMesh::UNVIO::read_implementation(), libMesh::GmshIO::read_mesh(), libMesh::DynaIO::read_mesh(), libMesh::AbaqusIO::read_nodes(), libMesh::CheckpointIO::read_nodes(), libMesh::CheckpointIO::read_nodesets(), libMesh::CheckpointIO::read_remote_elem(), libMesh::XdrIO::read_serialized_bcs_helper(), libMesh::XdrIO::read_serialized_connectivity(), libMesh::XdrIO::read_serialized_nodes(), libMesh::XdrIO::read_serialized_nodesets(), libMesh::XdrIO::read_serialized_subdomain_names(), libMesh::OFFIO::read_stream(), libMesh::MatlabIO::read_stream(), libMesh::CheckpointIO::read_subdomain_names(), libMesh::MeshInput< MeshBase >::set_n_partitions(), libMesh::NameBasedIO::write(), and libMesh::NameBasedIO::write_nodal_data().

179 {
180  libmesh_error_msg_if(_obj == nullptr, "ERROR: _obj should not be nullptr!");
181  return *_obj;
182 }
MT * _obj
A pointer to a non-const object object.
Definition: mesh_input.h:123

◆ read()

template<class MT>
virtual void libMesh::MeshInput< MT >::read ( const std::string &  )
pure virtual

This method implements reading a mesh from a specified file.

This should typically be called in parallel if is_parallel_format(), but should be called only on processor 0 (after which a mesh broadcast() is called) otherwise.

Implemented in libMesh::VTKIO, libMesh::CheckpointIO, libMesh::MatlabIO, libMesh::ExodusII_IO, libMesh::XdrIO, libMesh::DynaIO, libMesh::GmshIO, libMesh::UNVIO, libMesh::Nemesis_IO, libMesh::GMVIO, libMesh::UCDIO, libMesh::TetGenIO, libMesh::NameBasedIO, libMesh::AbaqusIO, and libMesh::OFFIO.

◆ set_n_partitions()

template<class MT>
void libMesh::MeshInput< MT >::set_n_partitions ( unsigned int  n_parts)
inlineprotected

Sets the number of partitions in the mesh.

Typically this gets done by the partitioner, but some parallel file formats begin "pre-partitioned".

Definition at line 101 of file mesh_input.h.

101 { this->mesh().set_n_partitions() = n_parts; }

◆ skip_comment_lines()

template<class MT >
void libMesh::MeshInput< MT >::skip_comment_lines ( std::istream &  in,
const char  comment_start 
)
protected

Reads input from in, skipping all the lines that start with the character comment_start.

Definition at line 187 of file mesh_input.h.

189 {
190  char c, line[256];
191 
192  while (in.get(c), c==comment_start)
193  in.getline (line, 255);
194 
195  // put back first character of
196  // first non-comment line
197  in.putback (c);
198 }

Member Data Documentation

◆ _is_parallel_format

template<class MT>
const bool libMesh::MeshInput< MT >::_is_parallel_format
private

Flag specifying whether this format is parallel-capable.

If this is false (default) I/O is only permitted when the mesh has been serialized.

Definition at line 130 of file mesh_input.h.

Referenced by libMesh::MeshInput< MeshBase >::is_parallel_format().

◆ _obj

template<class MT>
MT* libMesh::MeshInput< MT >::_obj
private

A pointer to a non-const object object.

This allows us to read the object from file.

Definition at line 123 of file mesh_input.h.

◆ elems_of_dimension

template<class MT>
std::vector<bool> libMesh::MeshInput< MT >::elems_of_dimension
protected

A vector of bools describing what dimension elements have been encountered when reading a mesh.

Definition at line 107 of file mesh_input.h.


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