|
SparseTensor< MPI_Vector< thrust::host_vector< real_type > > > | jacobian () const |
| The Jacobian of the coordinate transformation from physical to computational space.
|
|
SparseTensor< MPI_Vector< thrust::host_vector< real_type > > > | metric () const |
| The (inverse) metric tensor of the coordinate system.
|
|
std::vector< MPI_Vector< thrust::host_vector< real_type > > > | map () const |
| The coordinate map from computational to physical space.
|
|
virtual aRealMPIGeometry3d * | clone () const =0 |
| Geometries are cloneable.
|
|
virtual aRealGeometry3d< real_type > * | global_geometry () const =0 |
| Construct the global non-MPI geometry.
|
|
virtual | ~aRealMPIGeometry3d ()=default |
| allow deletion through base class pointer
|
|
unsigned | shape (unsigned u=0) const |
| \( n_u N_u\) the total number of points of an axis
|
|
host_vector | abscissas (unsigned u=0) const |
| Get the grid abscissas of the u axis.
|
|
host_vector | weights (unsigned u=0) const |
| Get the weights of the u axis.
|
|
std::array< unsigned, Nd > | get_shape () const |
| \( n_u N_u\) the total number of points of an axis
|
|
std::array< host_vector, Nd > | get_abscissas () const |
| Construct abscissas for all axes.
|
|
std::array< host_vector, Nd > | get_weights () const |
| Construct weights for all axes.
|
|
std::array< real_type, Nd > | get_p () const |
| Get left boundary point \( \vec p\).
|
|
std::array< real_type, Nd > | get_q () const |
| Get right boundary point \( \vec q\).
|
|
std::array< real_type, Nd > | get_l () const |
| Get grid length \( l_u = q_u - p_u\) for all axes.
|
|
std::array< real_type, Nd > | get_h () const |
| Get grid constant \( h_u = \frac{q_u - p_u}{N_u}\) for all axes.
|
|
std::array< unsigned, Nd > | get_N () const |
| Get number of cells \( N_u\) for all axes.
|
|
std::array< unsigned, Nd > | get_n () const |
| Get number of polynomial coefficients \( n_u\) for all axes.
|
|
std::array< dg::bc, Nd > | get_bc () const |
| Get boundary condition \( b_u\) for all axes.
|
|
std::array< MPI_Comm, Nd > | get_comms () const |
| Get 1d Cartesian communicator \( c_u\) for all axes.
|
|
real_type | p (unsigned u=0) const |
| Get left boundary point \( p_u\) for axis u .
|
|
real_type | q (unsigned u=0) const |
| Get right boundary point \( q_u\) for axis u .
|
|
real_type | h (unsigned u=0) const |
| Get grid constant \( h_u = \frac{q_u - p_u}{N_u}\) for axis u .
|
|
real_type | l (unsigned u=0) const |
| Get grid length \( l_u = q_u - p_u\) for axis u .
|
|
unsigned | n (unsigned u=0) const |
| Get number of polynomial coefficients \( n_u\) for axis u .
|
|
unsigned | N (unsigned u=0) const |
| Get number of cells \( N_u\) for axis u .
|
|
dg::bc | bc (unsigned u=0) const |
| Get boundary condition \( b_u\) for axis u .
|
|
MPI_Comm | comm (unsigned u) const |
| Get 1d Cartesian communicator \( c_u\) for axis u .
|
|
template<size_t Md = Nd> |
std::enable_if_t< Md==1, MPI_Comm > | comm () const |
| Equivalent to comm(0)
|
|
MPI_Comm | communicator () const |
| Return Nd dimensional MPI cartesian communicator that is used in this grid.
|
|
template<size_t Md = Nd> |
std::enable_if_t<(Md >=2), MPI_Comm > | get_perp_comm () const |
| MPI Cartesian communicator in the first two dimensions (x and y)
|
|
RealMPIGrid< real_type, 1 > | grid (unsigned u) const |
| Get axis u as a 1d grid.
|
|
RealMPIGrid< real_type, 1 > | axis (unsigned u) const |
| An alias for "grid".
|
|
const RealGrid< real_type, Nd > & | local () const |
| The local grid as a shared memory grid.
|
|
const RealGrid< real_type, Nd > & | global () const |
| The global grid as a shared memory grid.
|
|
template<size_t Md = Nd> |
real_type | x0 () const |
| Equivalent to p(0)
|
|
template<size_t Md = Nd> |
real_type | x1 () const |
| Equivalent to p(1)
|
|
template<size_t Md = Nd> |
real_type | y0 () const |
| Equivalent to p(2)
|
|
template<size_t Md = Nd> |
real_type | y1 () const |
| Equivalent to q(0)
|
|
template<size_t Md = Nd> |
real_type | z0 () const |
| Equivalent to q(1)
|
|
template<size_t Md = Nd> |
real_type | z1 () const |
| Equivalent to q(2)
|
|
template<size_t Md = Nd> |
real_type | lx () const |
| Equivalent to l(0)
|
|
template<size_t Md = Nd> |
real_type | ly () const |
| Equivalent to l(1)
|
|
template<size_t Md = Nd> |
real_type | lz () const |
| Equivalent to l(2)
|
|
template<size_t Md = Nd> |
real_type | hx () const |
| Equivalent to h(0)
|
|
template<size_t Md = Nd> |
real_type | hy () const |
| Equivalent to h(1)
|
|
template<size_t Md = Nd> |
real_type | hz () const |
| Equivalent to h(2)
|
|
template<size_t Md = Nd> |
unsigned | nx () const |
| Equivalent to n(0)
|
|
template<size_t Md = Nd> |
unsigned | ny () const |
| Equivalent to n(1)
|
|
template<size_t Md = Nd> |
unsigned | nz () const |
| Equivalent to n(2)
|
|
template<size_t Md = Nd> |
unsigned | Nx () const |
| Equivalent to N(0)
|
|
template<size_t Md = Nd> |
unsigned | Ny () const |
| Equivalent to N(1)
|
|
template<size_t Md = Nd> |
unsigned | Nz () const |
| Equivalent to N(2)
|
|
template<size_t Md = Nd> |
dg::bc | bcx () const |
| Equivalent to bc(0)
|
|
template<size_t Md = Nd> |
dg::bc | bcy () const |
| Equivalent to bc(1)
|
|
template<size_t Md = Nd> |
dg::bc | bcz () const |
| Equivalent to bc(2)
|
|
template<size_t Md = Nd> |
RealMPIGrid< real_type, 1 > | gx () const |
| Equivalent to grid(0)
|
|
template<size_t Md = Nd> |
RealMPIGrid< real_type, 1 > | gy () const |
| Equivalent to grid(1)
|
|
template<size_t Md = Nd> |
RealMPIGrid< real_type, 1 > | gz () const |
| Equivalent to grid(2)
|
|
template<size_t Md = Nd> |
std::enable_if_t<(Md >=2), void > | multiplyCellNumbers (real_type fx, real_type fy) |
| Multiply the number of cells in the first two dimensions with a given factor.
|
|
template<size_t Md = Nd> |
std::enable_if_t<(Md==1), void > | set (unsigned new_n, unsigned new_Nx) |
| Set n and N in a 1-dimensional grid.
|
|
template<size_t Md = Nd> |
std::enable_if_t<(Md==2), void > | set (unsigned new_n, unsigned new_Nx, unsigned new_Ny) |
| Set n and N in a 2-dimensional grid.
|
|
template<size_t Md = Nd> |
std::enable_if_t<(Md==3), void > | set (unsigned new_n, unsigned new_Nx, unsigned new_Ny, unsigned new_Nz) |
| Set n and N in a 3-dimensional grid.
|
|
void | set (unsigned new_n, std::array< unsigned, Nd > new_N) |
| Same as set( {new_n, new_n,...}, new_N);
|
|
void | set_axis (unsigned coord, unsigned new_n, unsigned new_N) |
| Set n and N for axis coord .
|
|
void | set (std::array< unsigned, Nd > new_n, std::array< unsigned, Nd > new_N) |
| Set the number of polynomials and cells.
|
|
void | set_pq (std::array< real_type, Nd > new_p, std::array< real_type, Nd > new_q) |
| Reset the boundaries of the grid.
|
|
void | set_bcs (std::array< dg::bc, Nd > new_bcs) |
| Reset the boundary conditions of the grid.
|
|
unsigned | size () const |
| The total global number of points.
|
|
unsigned | local_size () const |
| The total local number of points.
|
|
void | display (std::ostream &os=std::cout) const |
| Display global and local grid paramters.
|
|
template<size_t Md = Nd> |
std::enable_if_t<(Md==1), bool > | contains (real_type x) const |
| Check if the grid contains a point.
|
|
template<class Vector > |
bool | contains (const Vector &x) const |
| Check if the grid contains a point.
|
|
bool | local2globalIdx (int localIdx, int rank, int &globalIdx) const |
| Convert the index of a local vector and the rank of the containing process to a global index.
|
|
bool | global2localIdx (int globalIdx, int &localIdx, int &rank) const |
| Convert the global index of a vector to a local index and the rank of the containing process.
|
|
std::array< unsigned, Nd > | start () const |
| The global start coordinate in C-order of dg::file::MPINcHyperslab that the local grid represents.
|
|
std::array< unsigned, Nd > | count () const |
| Count vector in C-order for dg::file::MPINcHyperslab .
|
|
template<class real_type>
struct dg::aRealMPIGeometry3d< real_type >
This is the abstract interface class for a three-dimensional MPIGeometry.