Mesh Oriented datABase
(version 5.5.1)
An array-based unstructured mesh library
NCHelperESMF.hpp
Go to the documentation of this file.
1
/*
2
* NCHelperESMF.h
3
*
4
* Created on: Sep. 12, 2023
5
*/
6
7
#ifndef SRC_IO_NCHELPERESMF_H_
8
#define SRC_IO_NCHELPERESMF_H_
9
10
#include "
NCHelper.hpp
"
11
12
namespace
moab
13
{
14
#ifdef MOAB_HAVE_MPI
15
class
ParallelComm;
16
#endif
17
18
class
NCHelperESMF
:
public
UcdNCHelper
19
{
20
public
:
21
NCHelperESMF
(
ReadNC
* readNC,
int
fileId,
const
FileOptions
& opts,
EntityHandle
fileSet );
22
static
bool
can_read_file
(
ReadNC
* readNC );
23
24
25
private
:
26
27
//! Implementation of NCHelper::init_mesh_vals()
28
virtual
ErrorCode
init_mesh_vals
();
29
30
//! Implementation of NCHelper::create_mesh()
31
virtual
ErrorCode
create_mesh
(
Range
& faces );
32
//! Implementation of NCHelper::get_mesh_type_name()
33
virtual
std::string
get_mesh_type_name
()
34
{
35
return
"ESMF"
;
36
}
37
38
39
#ifdef MOAB_HAVE_MPI
40
//! Redistribute local cells after trivial partition (e.g. Zoltan partition, if applicable)
41
ErrorCode
redistribute_local_cells(
int
start_cell_index,
ParallelComm
* pco );
42
#endif
43
44
//! Create local vertices
45
ErrorCode
create_local_vertices
(
const
std::vector< int >& vertices_on_local_cells,
EntityHandle
& start_vertex );
46
47
//! Create local cells without padding (cells are divided into groups based on the number of
48
//! edges)
49
ErrorCode
create_local_cells
(
const
std::vector< int >& vertices_on_local_cells,
50
const
std::vector< int >& num_edges_on_local_cells,
51
EntityHandle
start_vertex,
52
Range
& faces );
53
54
//! Create local cells with padding (padded cells will have the same number of edges)
55
ErrorCode
create_padded_local_cells
(
const
std::vector< int >& vertices_on_local_cells,
56
EntityHandle
start_vertex,
57
Range
& faces );
58
59
virtual
ErrorCode
check_existing_mesh
() {
return
MB_SUCCESS
;}
60
61
//! Implementation of UcdNCHelper::read_ucd_variables_to_nonset_allocate()
62
virtual
ErrorCode
read_ucd_variables_to_nonset_allocate
( std::vector< ReadNC::VarData >&
/*vdatas*/
,
63
std::vector< int >&
/*tstep_nums*/
)
64
{
65
return
MB_SUCCESS
;
66
}
67
68
#ifdef MOAB_HAVE_PNETCDF
69
//! Implementation of UcdNCHelper::read_ucd_variables_to_nonset_async()
70
virtual
ErrorCode
read_ucd_variables_to_nonset_async( std::vector< ReadNC::VarData >&
/*vdatas*/
,
71
std::vector< int >&
/*tstep_nums*/
)
72
{
73
return
MB_SUCCESS
;
74
}
75
#else
76
//! Implementation of UcdNCHelper::read_ucd_variables_to_nonset()
77
virtual
ErrorCode
read_ucd_variables_to_nonset
( std::vector< ReadNC::VarData >&
/*vdatas*/
,
78
std::vector< int >&
/*tstep_nums*/
)
79
{
80
return
MB_SUCCESS
;
81
}
82
#endif
83
84
private
:
85
int
maxEdgesPerCell
;
86
int
coordDim
;
87
int
centerCoordsId
;
88
bool
degrees
;
89
Range
facesOwned
;
90
};
91
92
}
// namespace moab
93
94
#endif
/* SRC_IO_NCHELPERESMF_H_ */
src
io
NCHelperESMF.hpp
Generated on Tue Jul 30 2024 02:18:03 for Mesh Oriented datABase by
1.9.1.