2013-08-08 05:34:54 +08:00
|
|
|
#ifndef MESH_READER_H
|
|
|
|
#define MESH_READER_H
|
|
|
|
|
|
|
|
#include "Array2D.h"
|
|
|
|
#include "MatrixDef.h"
|
|
|
|
#include "MatrixLibrary.h"
|
|
|
|
#include "ATC_Error.h"
|
|
|
|
#include "FE_Mesh.h"
|
|
|
|
#include <sstream>
|
2013-08-22 07:06:07 +08:00
|
|
|
#include <set>
|
|
|
|
#include <utility>
|
|
|
|
#include <string>
|
2013-08-08 05:34:54 +08:00
|
|
|
|
|
|
|
namespace ATC {
|
|
|
|
|
|
|
|
class MeshReader {
|
|
|
|
|
|
|
|
public:
|
|
|
|
/** constructor, takes a filename */
|
2013-08-22 07:06:07 +08:00
|
|
|
MeshReader(std::string filename, Array<bool> periodicity, double tol=1.e-8);
|
2013-08-08 05:34:54 +08:00
|
|
|
|
|
|
|
/** destructor */
|
|
|
|
~MeshReader();
|
|
|
|
|
|
|
|
/** creates handle to new mesh object */
|
|
|
|
FE_Mesh* create_mesh();
|
|
|
|
|
|
|
|
private:
|
2013-08-22 07:06:07 +08:00
|
|
|
int number_of_vertices(std::string str);
|
|
|
|
|
2013-08-08 05:34:54 +08:00
|
|
|
/** reads .mesh format file */
|
|
|
|
void read_mesh_file();
|
|
|
|
|
|
|
|
/** reads .exo format file */
|
|
|
|
void read_exo_file();
|
|
|
|
|
|
|
|
/** Data members for storing necessary information */
|
2013-08-22 07:06:07 +08:00
|
|
|
std::string meshfile_;
|
|
|
|
ATC_matrix::Array<bool> periodicity_;
|
|
|
|
std::string elementType_;
|
2013-08-08 05:34:54 +08:00
|
|
|
int nNodes_;
|
|
|
|
int nElements_;
|
|
|
|
int nNodeSets_;
|
2013-08-22 07:06:07 +08:00
|
|
|
ATC_matrix::Array2D<int> * conn_;
|
2013-08-08 05:34:54 +08:00
|
|
|
DENS_MAT * nodeCoords_;
|
2013-08-22 07:06:07 +08:00
|
|
|
ATC_matrix::Array<std::pair<std::string,std::set<int> > > * nodeSets_;
|
2013-08-08 05:34:54 +08:00
|
|
|
double coordTol_;
|
|
|
|
};
|
|
|
|
|
|
|
|
}; // end namespace ATC
|
|
|
|
|
|
|
|
#endif
|