Discontinuous Galerkin Library
#include "dg/algorithm.h"
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
dg::RealGrid3d< real_type > Struct Template Reference

The simplest implementation of aRealTopology3d. More...

Inheritance diagram for dg::RealGrid3d< real_type >:
[legend]

Public Member Functions

 RealGrid3d (real_type x0, real_type x1, real_type y0, real_type y1, real_type z0, real_type z1, unsigned n, unsigned Nx, unsigned Ny, unsigned Nz, bc bcx=PER, bc bcy=PER, bc bcz=PER)
 Equal polynomial coefficients. More...
 
 RealGrid3d (RealGrid1d< real_type > gx, RealGrid1d< real_type > gy, RealGrid1d< real_type > gz)
 Construct a 3d topology as the product of three 1d grids. More...
 
 RealGrid3d (const aRealTopology3d< real_type > &src)
 allow explicit type conversion from any other topology More...
 
- Public Member Functions inherited from dg::aRealTopology3d< real_type >
real_type x0 () const
 left boundary in x More...
 
real_type x1 () const
 right boundary in x More...
 
real_type y0 () const
 left boundary in y More...
 
real_type y1 () const
 right boundary in y More...
 
real_type z0 () const
 left boundary in z More...
 
real_type z1 () const
 right boundary in z More...
 
real_type lx () const
 length in x More...
 
real_type ly () const
 length in y More...
 
real_type lz () const
 length in z More...
 
real_type hx () const
 cell size in x More...
 
real_type hy () const
 cell size in y More...
 
real_type hz () const
 cell size in z More...
 
unsigned n () const
 number of polynomial coefficients in x More...
 
unsigned nx () const
 number of polynomial coefficients in x More...
 
unsigned ny () const
 number of polynomial coefficients in y More...
 
unsigned nz () const
 number of polynomial coefficients in z More...
 
unsigned Nx () const
 number of points in x More...
 
unsigned Ny () const
 number of points in y More...
 
unsigned Nz () const
 number of points in z More...
 
bc bcx () const
 boundary conditions in x More...
 
bc bcy () const
 boundary conditions in y More...
 
bc bcz () const
 boundary conditions in z More...
 
const DLT< real_type > & dltx () const
 discrete legendre transformation in x More...
 
const DLT< real_type > & dlty () const
 discrete legendre transformation in y More...
 
const DLT< real_type > & dltz () const
 discrete legendre transformation in z More...
 
const RealGrid1d< real_type > & gx () const
 The x-axis grid. More...
 
const RealGrid1d< real_type > & gy () const
 The y-axis grid. More...
 
const RealGrid1d< real_type > & gz () const
 The z-axis grid. More...
 
unsigned size () const
 The total number of points. More...
 
void display (std::ostream &os=std::cout) const
 Display. More...
 
void shift (bool &negative, real_type &x, real_type &y, real_type &z) const
 Shift any point coordinate to a corresponding grid coordinate according to the boundary condition. More...
 
void shift (bool &negative, real_type &x, real_type &y, real_type &z, bc bcx, bc bcy, bc bcz) const
 Shift any point coordinate to a corresponding grid coordinate according to the boundary condition. More...
 
bool contains (real_type x, real_type y, real_type z) const
 Check if the grid contains a point. More...
 
template<class Vector >
bool contains (const Vector &x) const
 Shortcut for contains( x[0], x[1], x[2]) More...
 
void multiplyCellNumbers (real_type fx, real_type fy)
 Multiply the number of cells with a given factor. More...
 
void set (unsigned new_n, unsigned new_Nx, unsigned new_Ny, unsigned new_Nz)
 Set the number of polynomials and cells. More...
 
void set (unsigned new_nx, unsigned new_Nx, unsigned new_ny, unsigned new_Ny, unsigned new_nz, unsigned new_Nz)
 Set the number of polynomials and cells. More...
 

Additional Inherited Members

- Public Types inherited from dg::aRealTopology3d< real_type >
using value_type = real_type
 
using host_vector = thrust::host_vector< real_type >
 The host vector type used by host functions like evaluate. More...
 
using host_grid = RealGrid3d< real_type >
 
- Protected Member Functions inherited from dg::aRealTopology3d< real_type >
 ~aRealTopology3d ()=default
 disallow deletion through base class pointer More...
 
 aRealTopology3d (RealGrid1d< real_type > gx, RealGrid1d< real_type > gy, RealGrid1d< real_type > gz)
 Construct a 3d topology as the product of three 1d grids. More...
 
 aRealTopology3d (const aRealTopology3d &src)=default
 
aRealTopology3doperator= (const aRealTopology3d &src)=default
 
virtual void do_set (unsigned new_nx, unsigned new_Nx, unsigned new_ny, unsigned new_Ny, unsigned new_nz, unsigned new_Nz)=0
 

Detailed Description

template<class real_type>
struct dg::RealGrid3d< real_type >

The simplest implementation of aRealTopology3d.

This code snippet demonstrates how to discretize and compute the norm of a function

// define the function to integrate
double function(double x, double y, double z, double amp){
return amp*exp(x)*exp(y)*exp(z);
}
// create a grid of the domain [0,2]x[0,2]x[0,2] with 20 cells in x, y and z and 3 polynomial coefficients and x and y and 1 in z
dg::Grid3d g3d( 0, 2, 0, 2, 0, 2, 3, 20, 20, 20);
// create the Gaussian weights (volume form) for the integration
const dg::HVec w3d = dg::create::weights( g3d);
// our function needs to depend only on x, y and z so let's fix the amplitude to 2
using namespace std::placeholders; //for _1, _2, _3
auto functor = std::bind( function, _1, _2, _3, 2.);
// discretize the function on the grid
const dg::HVec vec = dg::evaluate( functor, g3d);
// now compute the scalar product (the L2 norm)
double norm = dg::blas2::dot(vec, w3d, vec);
// norm is now: (exp(4)-exp(0))^3/2
get_value_type< MatrixType > dot(const ContainerType1 &x, const MatrixType &m, const ContainerType2 &y)
; Binary reproducible general dot product
Definition: blas2.h:85
thrust::host_vector< real_type > evaluate(UnaryOp f, const RealGrid1d< real_type > &g)
Evaluate a 1d function on grid coordinates.
Definition: evaluation.h:67
MPI_Vector< thrust::host_vector< real_type > > weights(const aRealMPITopology2d< real_type > &g)
Nodal weight coefficients.
Definition: mpi_weights.h:22
thrust::host_vector< double > HVec
Host Vector.
Definition: typedefs.h:19
The simplest implementation of aRealTopology3d.
Definition: grid.h:844

Constructor & Destructor Documentation

◆ RealGrid3d() [1/3]

template<class real_type >
dg::RealGrid3d< real_type >::RealGrid3d ( real_type  x0,
real_type  x1,
real_type  y0,
real_type  y1,
real_type  z0,
real_type  z1,
unsigned  n,
unsigned  Nx,
unsigned  Ny,
unsigned  Nz,
bc  bcx = PER,
bc  bcy = PER,
bc  bcz = PER 
)
inline

Equal polynomial coefficients.

Parameters
x0left boundary in x
x1right boundary in x
y0lower boundary in y
y1upper boundary in y
z0lower boundary in z
z1upper boundary in z
n# of polynomial coefficients for x and y dimension ( z-direction is set to 1) (1<=n<=20)
Nx# of points in x
Ny# of points in y
Nz# of points in z
bcxboundary condition in x
bcyboundary condition in y
bczboundary condition in z

◆ RealGrid3d() [2/3]

template<class real_type >
dg::RealGrid3d< real_type >::RealGrid3d ( RealGrid1d< real_type >  gx,
RealGrid1d< real_type >  gy,
RealGrid1d< real_type >  gz 
)
inline

Construct a 3d topology as the product of three 1d grids.

real_type y0() const
left boundary in y
Definition: grid.h:547
unsigned nz() const
number of polynomial coefficients in z
Definition: grid.h:616
bc bcz() const
boundary conditions in z
Definition: grid.h:652
unsigned Nx() const
number of points in x
Definition: grid.h:622
unsigned ny() const
number of polynomial coefficients in y
Definition: grid.h:614
real_type x0() const
left boundary in x
Definition: grid.h:534
real_type y1() const
right boundary in y
Definition: grid.h:553
real_type z0() const
left boundary in z
Definition: grid.h:560
real_type x1() const
right boundary in x
Definition: grid.h:540
unsigned Ny() const
number of points in y
Definition: grid.h:628
bc bcy() const
boundary conditions in y
Definition: grid.h:646
bc bcx() const
boundary conditions in x
Definition: grid.h:640
real_type z1() const
right boundary in z
Definition: grid.h:566
unsigned Nz() const
number of points in z
Definition: grid.h:634
unsigned nx() const
number of polynomial coefficients in x
Definition: grid.h:612
Parameters
gxa Grid1d in x - direction
gya Grid1d in y - direction
gza Grid1d in z - direction

◆ RealGrid3d() [3/3]

template<class real_type >
dg::RealGrid3d< real_type >::RealGrid3d ( const aRealTopology3d< real_type > &  src)
inlineexplicit

allow explicit type conversion from any other topology

Parameters
srcsource

The documentation for this struct was generated from the following file: