00001 #ifndef _mmph_adapter_
00002 #define _mmph_adapter_
00003
00004 #include <metis.h>
00005 #include <parmetis.h>
00006 #include <unordered_map>
00007 #include <vector>
00008 #include <set>
00009
00010 #include "uth_intf.h"
00011
00012 #include "mmph_ipid.h"
00013
00014 #include "Transferer.hpp"
00015
00016 using namespace mmpt;
00017
00018 #ifdef __cplusplus
00019 extern "C"{
00020 #endif
00021
00022
00023
00024 #define MAC_USE_KWAY_GRAPH_PART_TOOL 0
00025 #define MAC_USE_RB_GRAPH_PART_TOOL 1
00026
00027 #define MAC_MAX_ELEMENT_FACES 6
00028 #define MAC_MAX_ELEMENT_EGDES 12
00029 #define MAC_MAX_ELEMENT_NODES 8
00030 #define MAC_MAX_NODES_ON_FACE 4
00031 #define MAC_MAX_NODES_COOR_ON_FACE 12
00032
00033 #define MAC_MAX_ELEMENTS_CONNECTED_BY_NODE 384
00034 #define MAC_MAX_PARTITIONS 128
00035
00036 #define MAC_PARALLEL_MESH_CORASING 1
00037
00038 #define MAC_PRISM_OPTIMIZATION 1
00039
00040 #define MMC_MAX_NUM_MESH 10 //* maximal number of meshes
00041
00042 #define MMPC_CLASSIC_PART_METHOD 0 //* use classic (old) partition method
00043 #define MMPC_METIS_PART_METHOD 1 //* use Metis and ParMetis libraries to partition a mesh
00044
00045
00046
00047
00048
00049 extern int mmpv_partition_method;
00050 extern std::vector<mmpt_mesh> mmpv_meshes;
00051
00052
00053
00057 mmpt_mesh* mmpr_select_mesh(
00058
00059
00060 int Mesh_id
00061 );
00062
00063
00064
00068 int mmpr_transfer_full_elems(mmpt_mesh & pmesh,
00069 const int Source_proc_id,
00070 const int Dest_proc_id,
00071 const int N_transfer_elems,
00072 const int * Transfer_elem_ids,
00073 const TRANSFER_POLICY T_policy);
00074
00075 #ifdef __cplusplus
00076 }
00077 #endif
00078
00079 #endif