Mesh Oriented datABase
(version 5.4.1)
Array-based unstructured mesh datastructure
|
00001 /* 00002 * MeshGeneration.hpp 00003 * class for generating simple meshes online 00004 */ 00005 00006 #ifndef MESHGENERATION_HPP_ 00007 #define MESHGENERATION_HPP_ 00008 #include "moab/Core.hpp" 00009 00010 #include "moab/CartVect.hpp" 00011 00012 namespace moab 00013 { 00014 00015 // Forward Declarations 00016 class ParallelComm; 00017 00018 class MeshGeneration 00019 { 00020 00021 public: 00022 struct BrickOpts 00023 { 00024 // follow the options in examples/advanced/GenLargeMesh.cpp 00025 CartVect ui, uj, uk; // such that ui * uj = uk; uj*uk=ui, etc 00026 double xsize, ysize, zsize; // extents of the brick 00027 int A, B, C; // number of blocks per processor 00028 int M, N, K; // number of processors in each direction 00029 int blockSize; // each small block size 00030 int GL; // number of ghost layers 00031 bool newMergeMethod; // = false; 00032 bool quadratic; // = false; 00033 bool keep_skins; // = false; 00034 bool tetra; // = false; 00035 bool adjEnts; // = false; 00036 bool parmerge; // = false; 00037 }; 00038 00039 MeshGeneration( Interface* mbi, 00040 #ifdef MOAB_HAVE_MPI 00041 ParallelComm* pcomm = 0, 00042 #endif 00043 EntityHandle rset = 0 ); 00044 virtual ~MeshGeneration(); 00045 00046 ErrorCode BrickInstance( BrickOpts& opts ); 00047 00048 private: 00049 Interface* mb; 00050 #ifdef MOAB_HAVE_MPI 00051 ParallelComm* pc; 00052 #endif 00053 EntityHandle cset; 00054 }; 00055 00056 } /* namespace moab */ 00057 #endif /* MESHGENERATION_HPP_ */