libMesh
Public Member Functions | List of all members
MixedExactSolution Class Reference

#include <mixed_exact_solution.h>

Public Member Functions

 MixedExactSolution ()=default
 
 ~MixedExactSolution ()=default
 
Real scalar (Real x, Real y)
 
Real scalar (Real x, Real y, Real z)
 
RealGradient operator() (Real x, Real y)
 
RealGradient operator() (Real x, Real y, Real z)
 
RealTensor grad (Real x, Real y)
 
RealTensor grad (Real x, Real y, Real z)
 
Real div (Real x, Real y)
 
Real div (Real x, Real y, Real z)
 
Real forcing (Real x, Real y)
 
Real forcing (Real x, Real y, Real z)
 

Detailed Description

Definition at line 26 of file mixed_exact_solution.h.

Constructor & Destructor Documentation

◆ MixedExactSolution()

MixedExactSolution::MixedExactSolution ( )
default

◆ ~MixedExactSolution()

MixedExactSolution::~MixedExactSolution ( )
default

Member Function Documentation

◆ div() [1/2]

Real MixedExactSolution::div ( Real  x,
Real  y 
)
inline

Definition at line 84 of file mixed_exact_solution.h.

References libMesh::Real.

85  {
86  const Real dux_dx = grad(x, y)(0, 0);
87  const Real duy_dy = grad(x, y)(1, 1);
88 
89  return dux_dx + duy_dy;
90  }
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
RealTensor grad(Real x, Real y)

◆ div() [2/2]

Real MixedExactSolution::div ( Real  x,
Real  y,
Real  z 
)
inline

Definition at line 92 of file mixed_exact_solution.h.

References libMesh::Real.

93  {
94  const Real dux_dx = grad(x, y, z)(0, 0);
95  const Real duy_dy = grad(x, y, z)(1, 1);
96  const Real duz_dz = grad(x, y, z)(2, 2);
97 
98  return dux_dx + duy_dy + duz_dz;
99  }
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
RealTensor grad(Real x, Real y)

◆ forcing() [1/2]

Real MixedExactSolution::forcing ( Real  x,
Real  y 
)
inline

Definition at line 101 of file mixed_exact_solution.h.

Referenced by alternative_fe_assembly(), compute_enriched_soln(), and fe_assembly().

102  {
103  return div(x, y);
104  }
Real div(Real x, Real y)

◆ forcing() [2/2]

Real MixedExactSolution::forcing ( Real  x,
Real  y,
Real  z 
)
inline

Definition at line 106 of file mixed_exact_solution.h.

107  {
108  return div(x, y, z);
109  }
Real div(Real x, Real y)

◆ grad() [1/2]

RealTensor MixedExactSolution::grad ( Real  x,
Real  y 
)
inline

Definition at line 59 of file mixed_exact_solution.h.

References libMesh::pi, and libMesh::Real.

60  {
61  const Real dux_dx = .5*pi*.5*pi*cos(.5*pi*x)*sin(.5*pi*y);
62  const Real dux_dy = .5*pi*.5*pi*sin(.5*pi*x)*cos(.5*pi*y);
63  const Real duy_dx = .5*pi*.5*pi*sin(.5*pi*x)*cos(.5*pi*y);
64  const Real duy_dy = .5*pi*.5*pi*cos(.5*pi*x)*sin(.5*pi*y);
65 
66  return RealTensor(dux_dx, dux_dy, Real(0), duy_dx, duy_dy);
67  }
RealTensorValue RealTensor
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
const Real pi
.
Definition: libmesh.h:299

◆ grad() [2/2]

RealTensor MixedExactSolution::grad ( Real  x,
Real  y,
Real  z 
)
inline

Definition at line 69 of file mixed_exact_solution.h.

References libMesh::pi, and libMesh::Real.

70  {
71  const Real dux_dx = .5*pi*.5*pi*cos(.5*pi*x)*sin(.5*pi*y)*cos(.5*pi*z);
72  const Real dux_dy = .5*pi*.5*pi*sin(.5*pi*x)*cos(.5*pi*y)*cos(.5*pi*z);
73  const Real dux_dz = -.5*pi*.5*pi*sin(.5*pi*x)*sin(.5*pi*y)*sin(.5*pi*z);
74  const Real duy_dx = .5*pi*.5*pi*sin(.5*pi*x)*cos(.5*pi*y)*cos(.5*pi*z);
75  const Real duy_dy = .5*pi*.5*pi*cos(.5*pi*x)*sin(.5*pi*y)*cos(.5*pi*z);
76  const Real duy_dz = .5*pi*.5*pi*cos(.5*pi*x)*cos(.5*pi*y)*sin(.5*pi*z);
77  const Real duz_dx = -.5*pi*.5*pi*sin(.5*pi*x)*sin(.5*pi*y)*sin(.5*pi*z);
78  const Real duz_dy = .5*pi*.5*pi*cos(.5*pi*x)*cos(.5*pi*y)*sin(.5*pi*z);
79  const Real duz_dz = .5*pi*.5*pi*cos(.5*pi*x)*sin(.5*pi*y)*cos(.5*pi*z);
80 
81  return RealTensor(dux_dx, dux_dy, dux_dz, duy_dx, duy_dy, duy_dz, duz_dx, duz_dy, duz_dz);
82  }
RealTensorValue RealTensor
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
const Real pi
.
Definition: libmesh.h:299

◆ operator()() [1/2]

RealGradient MixedExactSolution::operator() ( Real  x,
Real  y 
)
inline

Definition at line 42 of file mixed_exact_solution.h.

References libMesh::pi, and libMesh::Real.

43  {
44  const Real ux = .5*pi*sin(.5*pi*x)*sin(.5*pi*y);
45  const Real uy = -.5*pi*cos(.5*pi*x)*cos(.5*pi*y);
46 
47  return RealGradient(ux, uy);
48  }
RealVectorValue RealGradient
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
const Real pi
.
Definition: libmesh.h:299

◆ operator()() [2/2]

RealGradient MixedExactSolution::operator() ( Real  x,
Real  y,
Real  z 
)
inline

Definition at line 50 of file mixed_exact_solution.h.

References libMesh::pi, and libMesh::Real.

51  {
52  const Real ux = .5*pi*sin(.5*pi*x)*sin(.5*pi*y)*cos(.5*pi*z);
53  const Real uy = -.5*pi*cos(.5*pi*x)*cos(.5*pi*y)*cos(.5*pi*z);
54  const Real uz = .5*pi*cos(.5*pi*x)*sin(.5*pi*y)*sin(.5*pi*z);
55 
56  return RealGradient(ux, uy, uz);
57  }
RealVectorValue RealGradient
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
const Real pi
.
Definition: libmesh.h:299

◆ scalar() [1/2]

Real MixedExactSolution::scalar ( Real  x,
Real  y 
)
inline

Definition at line 32 of file mixed_exact_solution.h.

References libMesh::pi.

Referenced by alternative_fe_assembly(), and fe_assembly().

33  {
34  return cos(.5*pi*x)*sin(.5*pi*y);
35  }
const Real pi
.
Definition: libmesh.h:299

◆ scalar() [2/2]

Real MixedExactSolution::scalar ( Real  x,
Real  y,
Real  z 
)
inline

Definition at line 37 of file mixed_exact_solution.h.

References libMesh::pi.

38  {
39  return cos(.5*pi*x)*sin(.5*pi*y)*cos(.5*pi*z);
40  }
const Real pi
.
Definition: libmesh.h:299

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