libMesh
Public Member Functions | Static Protected Member Functions | Protected Attributes | List of all members
FETestBase< order, family, elem_type, build_nx, CaseName > Class Template Reference

#include <fe_test.h>

Inheritance diagram for FETestBase< order, family, elem_type, build_nx, CaseName >:
[legend]

Public Member Functions

void setUp ()
 
void tearDown ()
 

Static Protected Member Functions

static RealGradient true_gradient (Point p)
 
static RealTensor true_hessian (Point p)
 

Protected Attributes

std::string libmesh_suite_name
 
std::string _case_name
 Name of the case, can be used in the test to switch cases. More...
 
unsigned int _dim
 
unsigned int _nx
 
unsigned int _ny
 
unsigned int _nz
 
Elem_elem
 
std::vector< dof_id_type_dof_indices
 
System_sys
 
std::unique_ptr< Mesh_mesh
 
std::unique_ptr< EquationSystems_es
 
std::unique_ptr< FEBase_fe
 
std::unique_ptr< QGauss_qrule
 
Real _value_tol
 
Real _grad_tol
 
Real _hess_tol
 

Detailed Description

template<Order order, FEFamily family, ElemType elem_type, unsigned int build_nx, typename CaseName = Default>
class FETestBase< order, family, elem_type, build_nx, CaseName >

Definition at line 269 of file fe_test.h.

Member Function Documentation

◆ setUp()

template<Order order, FEFamily family, ElemType elem_type, unsigned int build_nx, typename CaseName = Default>
void FETestBase< order, family, elem_type, build_nx, CaseName >::setUp ( )
inline

Definition at line 356 of file fe_test.h.

Referenced by FESideTest< order, family, elem_type >::setUp().

357  {
358  _mesh = std::make_unique<Mesh>(*TestCommWorld);
359  _dim = Elem::type_to_dim_map[elem_type];
360  const unsigned int build_ny = (_dim > 1) * build_nx;
361  const unsigned int build_nz = (_dim > 2) * build_nx;
362 
363  unsigned char weight_index = 0;
364 
365  if (family == RATIONAL_BERNSTEIN)
366  {
367  // Make sure we can handle non-zero weight indices
368  _mesh->add_node_integer("buffer integer");
369 
370  // Default weight to 1.0 so we don't get NaN from contains_point
371  // checks with a default GhostPointNeighbors ghosting
372  const Real default_weight = 1.0;
373  weight_index = cast_int<unsigned char>
374  (_mesh->add_node_datum<Real>("rational_weight", true,
375  &default_weight));
376  libmesh_assert_not_equal_to(weight_index, 0);
377 
378  // Set mapping data but not type, since here we're testing
379  // rational basis functions in the FE space but testing then
380  // with Lagrange bases for the mapping space.
381  _mesh->set_default_mapping_data(weight_index);
382  }
383 
384  if (elem_type == C0POLYGON)
385  {
386  // Build a pentagon by hand for testing purposes. Make this
387  // one non-skewed so a MONOMIAL basis will be able to exactly
388  // represent the polynomials we're projecting.
389 
390  _mesh->add_point(Point(0, 0), 0);
391  _mesh->add_point(Point(1, 0), 1);
392  _mesh->add_point(Point(1+cos(2*libMesh::pi/5), sin(2*libMesh::pi/5)), 2);
393  _mesh->add_point(Point(0.5, sin(2*libMesh::pi/5)+sin(libMesh::pi/5)), 3);
394  _mesh->add_point(Point(-cos(2*libMesh::pi/5), sin(2*libMesh::pi/5)), 4);
395 
396  std::unique_ptr<Elem> polygon = std::make_unique<C0Polygon>(5);
397  for (auto i : make_range(5))
398  polygon->set_node(i, _mesh->node_ptr(i));
399  polygon->set_id() = 0;
400 
401  _mesh->add_elem(std::move(polygon));
402  _mesh->prepare_for_use();
403  }
404  else if (elem_type == C0POLYHEDRON)
405  {
406  // Build a plain cube by hand for testing purposes. We could
407  // upgrade this, but it should be to something non-skewed so a
408  // MONOMIAL basis will be able to exactly represent the
409  // polynomials we're projecting.
410  //
411  // See elem_test.h for the limitations here.
412 
413  _mesh->add_point(Point(0, 0, 0), 0);
414  _mesh->add_point(Point(1, 0, 0), 1);
415  _mesh->add_point(Point(1, 1, 0), 2);
416  _mesh->add_point(Point(0, 1, 0), 3);
417  _mesh->add_point(Point(0, 0, 1), 4);
418  _mesh->add_point(Point(1, 0, 1), 5);
419  _mesh->add_point(Point(1, 1, 1), 6);
420  _mesh->add_point(Point(0, 1, 1), 7);
421 
422  // Pick case
423  std::vector<std::vector<unsigned int>> nodes_on_side;
424  if (_case_name == "Default")
425  nodes_on_side = { {0, 1, 2, 3}, // min z
426  {0, 1, 5, 4}, // min y
427  {2, 6, 5, 1}, // max x
428  {2, 3, 7, 6}, // max y
429  {0, 4, 7, 3}, // min x
430  {5, 6, 7, 4} }; // max z
431  else if (_case_name == "MidNode")
432  nodes_on_side = { {0, 1, 2, 3}, // min z
433  {0, 1, 5, 4}, // min y
434  {1, 2, 6, 5}, // max x
435  {2, 3, 7, 6}, // max y
436  {3, 0, 4, 7}, // min x
437  {4, 5, 6, 7} }; // max z
438  else
439  libmesh_error_msg("Unknown case name: " + _case_name);
440 
441  // Build all the sides.
442  std::vector<std::shared_ptr<Polygon>> sides(nodes_on_side.size());
443 
444  for (auto s : index_range(nodes_on_side))
445  {
446  const auto & nodes_on_s = nodes_on_side[s];
447  sides[s] = std::make_shared<C0Polygon>(nodes_on_s.size());
448  for (auto i : index_range(nodes_on_s))
449  sides[s]->set_node(i, _mesh->node_ptr(nodes_on_s[i]));
450  }
451 
452  std::unique_ptr<libMesh::Node> mid_elem_node;
453  std::unique_ptr<Elem> polyhedron = std::make_unique<C0Polyhedron>(sides, mid_elem_node);
454  _mesh->add_elem(std::move(polyhedron));
455  if (mid_elem_node)
456  _mesh->add_node(std::move(mid_elem_node));
457  _mesh->prepare_for_use();
458  }
459  else
460  {
462  build_nx, build_ny, build_nz,
463  0., 1., 0., 1., 0., 1.,
464  elem_type);
465  }
466 
467  // For debugging purposes it can be helpful to only consider one
468  // element even when we're using an element type that requires
469  // more than one element to fill out a square or cube.
470 #if 0
471  for (dof_id_type i = 0; i != _mesh->max_elem_id(); ++i)
472  {
473  Elem * elem = _mesh->query_elem_ptr(i);
474  if (elem && elem->id())
475  _mesh->delete_elem(elem);
476  }
477  _mesh->prepare_for_use();
478  CPPUNIT_ASSERT_EQUAL(_mesh->n_elem(), dof_id_type(1));
479 #endif
480 
481  // Permute our elements randomly and rotate and skew our mesh so
482  // we test all sorts of orientations ... except with Hermite
483  // elements, which are only designed to support meshes with a
484  // single orientation shared by all elements. We're also not
485  // rotating and/or skewing the rational elements, since our test
486  // solution was designed for a specific weighted mesh.
487  if (family != HERMITE &&
488  family != RATIONAL_BERNSTEIN)
489  {
491 
492  // Not yet testing manifolds embedded in higher-D space
493  if (_dim > 1)
495  8*(_dim>2), 16*(_dim>2));
496 
497  SkewFunc skew_func;
499  }
500 
501  // Set rational weights so we can exactly match our test solution
502  if (family == RATIONAL_BERNSTEIN)
503  {
504  for (auto elem : _mesh->active_element_ptr_range())
505  {
506  const unsigned int nv = elem->n_vertices();
507  const unsigned int nn = elem->n_nodes();
508  // We want interiors in lower dimensional elements treated
509  // like edges or faces as appropriate.
510  const unsigned int n_edges =
511  (elem->type() == EDGE3) ? 1 : elem->n_edges();
512  const unsigned int n_faces =
513  (elem->type() == QUAD9) ? 1 : elem->n_faces();
514  const unsigned int nve = std::min(nv + n_edges, nn);
515  const unsigned int nvef = std::min(nve + n_faces, nn);
516 
517  for (unsigned int i = 0; i != nv; ++i)
518  elem->node_ref(i).set_extra_datum<Real>(weight_index, 1.);
519  for (unsigned int i = nv; i != nve; ++i)
520  elem->node_ref(i).set_extra_datum<Real>(weight_index, rational_w);
521  const Real w2 = rational_w * rational_w;
522  for (unsigned int i = nve; i != nvef; ++i)
523  elem->node_ref(i).set_extra_datum<Real>(weight_index, w2);
524  const Real w3 = rational_w * w2;
525  for (unsigned int i = nvef; i != nn; ++i)
526  elem->node_ref(i).set_extra_datum<Real>(weight_index, w3);
527  }
528  }
529 
530  _es = std::make_unique<EquationSystems>(*_mesh);
531  _sys = &(_es->add_system<System> ("SimpleSystem"));
532  _sys->add_variable("u", order, family);
533  _es->init();
534 
535  if (family == RATIONAL_BERNSTEIN && order > 1)
536  {
538  }
539  else if (order > 3)
540  {
542  }
543  // Lagrange "cubic" on Tet7 only supports a bubble function, not
544  // all of P^3
545  else if (FE_CAN_TEST_CUBIC)
546  {
548  }
549  else if (order > 1)
550  {
552  }
553  else
554  {
556  }
557 
558  FEType fe_type = _sys->variable_type(0);
559  _fe = FEBase::build(_dim, fe_type);
560 
561  // Create quadrature rule for use in computing dual shape coefficients
562  _qrule = std::make_unique<QGauss>(_dim, fe_type.default_quadrature_order());
563  _fe->attach_quadrature_rule(_qrule.get());
564 
565  auto rng = _mesh->active_local_element_ptr_range();
566  this->_elem = rng.begin() == rng.end() ? nullptr : *(rng.begin());
567 
569 
570  _nx = 10;
571  _ny = (_dim > 1) ? _nx : 1;
572  _nz = (_dim > 2) ? _nx : 1;
573 
574  this->_value_tol = TOLERANCE * sqrt(TOLERANCE);
575 
576  // We see 6.5*tol*sqrt(tol) errors on cubic Hermites with the fe_cubic
577  // hermite test function
578  // On Tri7 we see 10*tol*sqrt(tol) errors, even!
579  // On Tet14 Monomial gives us at least 13*tol*sqrt(tol) in some
580  // cases
581  this->_grad_tol = 15 * TOLERANCE * sqrt(TOLERANCE);
582 
583  this->_hess_tol = sqrt(TOLERANCE); // FIXME: we see some ~1e-5 errors?!?
584 
585  // Prerequest everything we'll want to calculate later.
586  _fe->get_phi();
587  _fe->get_dphi();
588  _fe->get_dphidx();
589 #if LIBMESH_DIM > 1
590  _fe->get_dphidy();
591 #endif
592 #if LIBMESH_DIM > 2
593  _fe->get_dphidz();
594 #endif
595 
596 #if LIBMESH_ENABLE_SECOND_DERIVATIVES
597 
598  // Szabab elements don't have second derivatives yet
599  if (family == SZABAB)
600  return;
601 
602  _fe->get_d2phi();
603  _fe->get_d2phidx2();
604 #if LIBMESH_DIM > 1
605  _fe->get_d2phidxdy();
606  _fe->get_d2phidy2();
607 #endif
608 #if LIBMESH_DIM > 2
609  _fe->get_d2phidxdz();
610  _fe->get_d2phidydz();
611  _fe->get_d2phidz2();
612 #endif
613 
614 #endif
615  }
std::unique_ptr< EquationSystems > _es
Definition: fe_test.h:282
class FEType hides (possibly multiple) FEFamily and approximation orders, thereby enabling specialize...
Definition: fe_type.h:196
unsigned int _dim
Definition: fe_test.h:277
std::string _case_name
Name of the case, can be used in the test to switch cases.
Definition: fe_test.h:275
void dof_indices(const Elem *const elem, std::vector< dof_id_type > &di) const
Definition: dof_map.C:2201
static constexpr Real TOLERANCE
Gradient quadratic_test_grad(const Point &p, const Parameters &, const std::string &, const std::string &)
Definition: fe_test.h:111
This is the base class from which all geometric element types are derived.
Definition: elem.h:94
Gradient rational_test_grad(const Point &p, const Parameters &, const std::string &, const std::string &)
Definition: fe_test.h:220
Elem * _elem
Definition: fe_test.h:278
Order default_quadrature_order() const
Definition: fe_type.h:415
unsigned int _nx
Definition: fe_test.h:277
Gradient fe_cubic_test_grad(const Point &p, const Parameters &, const std::string &, const std::string &)
Definition: fe_test.h:144
Gradient fe_quartic_test_grad(const Point &p, const Parameters &, const std::string &, const std::string &)
Definition: fe_test.h:177
Number fe_cubic_test(const Point &p, const Parameters &, const std::string &, const std::string &)
Definition: fe_test.h:131
std::vector< dof_id_type > _dof_indices
Definition: fe_test.h:279
static const Real rational_w
Definition: fe_test.h:200
void permute_elements(MeshBase &mesh)
Randomly permute the nodal ordering of each element (without twisting the element mapping)...
std::unique_ptr< FEBase > _fe
Definition: fe_test.h:283
Number linear_test(const Point &p, const Parameters &, const std::string &, const std::string &)
Definition: fe_test.h:69
System * _sys
Definition: fe_test.h:280
Number rational_test(const Point &p, const Parameters &, const std::string &, const std::string &)
Definition: fe_test.h:203
const Node & node_ref(const unsigned int i) const
Definition: elem.h:2535
dof_id_type id() const
Definition: dof_object.h:819
virtual unsigned int n_nodes() const =0
Manages consistently variables, degrees of freedom, and coefficient vectors.
Definition: system.h:98
Real _value_tol
Definition: fe_test.h:286
unsigned int add_variable(std::string_view var, const FEType &type, const std::set< subdomain_id_type > *const active_subdomains=nullptr)
Adds the variable var to the list of variables for this system.
Definition: system.C:1344
void set_extra_datum(const unsigned int index, const T value)
Sets the value on this object of the extra datum associated with index, which should have been obtain...
Definition: dof_object.h:1102
Number quadratic_test(const Point &p, const Parameters &, const std::string &, const std::string &)
Definition: fe_test.h:98
virtual unsigned int n_edges() const =0
unsigned int _ny
Definition: fe_test.h:277
void project_solution(FunctionBase< Number > *f, FunctionBase< Gradient > *g=nullptr, std::optional< ConstElemRange > active_local_range=std::nullopt, std::optional< std::vector< unsigned int >> variable_numbers=std::nullopt) const
Projects arbitrary functions onto the current solution.
RealTensorValue rotate(MeshBase &mesh, const Real phi, const Real theta=0., const Real psi=0.)
Rotates the mesh in the xy plane.
std::unique_ptr< Mesh > _mesh
Definition: fe_test.h:281
virtual unsigned int n_vertices() const =0
const FEType & variable_type(const unsigned int i) const
Definition: system.C:2721
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
unsigned int _nz
Definition: fe_test.h:277
IntRange< T > make_range(T beg, T end)
The 2-parameter make_range() helper function returns an IntRange<T> when both input parameters are of...
Definition: int_range.h:176
void redistribute(MeshBase &mesh, const FunctionBase< Real > &mapfunc)
Deterministically perturb the nodal locations.
virtual unsigned int n_faces() const =0
Number fe_quartic_test(const Point &p, const Parameters &, const std::string &, const std::string &)
Definition: fe_test.h:164
Real _grad_tol
Definition: fe_test.h:286
Gradient linear_test_grad(const Point &, const Parameters &, const std::string &, const std::string &)
Definition: fe_test.h:82
const DofMap & get_dof_map() const
Definition: system.h:2417
virtual ElemType type() const =0
A Point defines a location in LIBMESH_DIM dimensional Real space.
Definition: point.h:39
Real _hess_tol
Definition: fe_test.h:286
auto index_range(const T &sizable)
Helper function that returns an IntRange<std::size_t> representing all the indices of the passed-in v...
Definition: int_range.h:153
std::unique_ptr< QGauss > _qrule
Definition: fe_test.h:284
void build_cube(UnstructuredMesh &mesh, const unsigned int nx=0, const unsigned int ny=0, const unsigned int nz=0, const Real xmin=0., const Real xmax=1., const Real ymin=0., const Real ymax=1., const Real zmin=0., const Real zmax=1., const ElemType type=INVALID_ELEM, const bool gauss_lobatto_grid=false)
Builds a (elements) cube.
uint8_t dof_id_type
Definition: id_types.h:67
const Real pi
.
Definition: libmesh.h:292

◆ tearDown()

template<Order order, FEFamily family, ElemType elem_type, unsigned int build_nx, typename CaseName = Default>
void FETestBase< order, family, elem_type, build_nx, CaseName >::tearDown ( )
inline

Definition at line 617 of file fe_test.h.

Referenced by FESideTest< order, family, elem_type >::tearDown().

617 {}

◆ true_gradient()

template<Order order, FEFamily family, ElemType elem_type, unsigned int build_nx, typename CaseName = Default>
static RealGradient FETestBase< order, family, elem_type, build_nx, CaseName >::true_gradient ( Point  p)
inlinestaticprotected

Definition at line 289 of file fe_test.h.

290  {
291  Parameters dummy;
292 
293  Gradient true_grad;
294  RealGradient returnval;
295 
296  if (family == RATIONAL_BERNSTEIN && order > 1)
297  true_grad = rational_test_grad(p, dummy, "", "");
298  else if (order > 3)
299  true_grad = fe_quartic_test_grad(p, dummy, "", "");
300  else if (FE_CAN_TEST_CUBIC)
301  true_grad = fe_cubic_test_grad(p, dummy, "", "");
302  else if (order > 1)
303  {
304  const Real & x = p(0);
305  const Real & y = (LIBMESH_DIM > 1) ? p(1) : 0;
306  const Real & z = (LIBMESH_DIM > 2) ? p(2) : 0;
307 
308  true_grad = Gradient(2*x+0.125*y+0.0625*z,
309  y+0.125*x+0.03125*z,
310  0.5*z+0.0625*x+0.03125*y);
311  }
312  else
313  true_grad = Gradient(1.0, 0.25, 0.0625);
314 
315  for (unsigned int d=0; d != LIBMESH_DIM; ++d)
316  {
317  CPPUNIT_ASSERT(true_grad(d) ==
318  Number(libmesh_real(true_grad(d))));
319 
320  returnval(d) = libmesh_real(true_grad(d));
321  }
322 
323  return returnval;
324  }
T libmesh_real(T a)
This class provides the ability to map between arbitrary, user-defined strings and several data types...
Definition: parameters.h:74
Gradient rational_test_grad(const Point &p, const Parameters &, const std::string &, const std::string &)
Definition: fe_test.h:220
This class defines a vector in LIBMESH_DIM dimensional Real or Complex space.
Gradient fe_cubic_test_grad(const Point &p, const Parameters &, const std::string &, const std::string &)
Definition: fe_test.h:144
Gradient fe_quartic_test_grad(const Point &p, const Parameters &, const std::string &, const std::string &)
Definition: fe_test.h:177
NumberVectorValue Gradient
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real

◆ true_hessian()

template<Order order, FEFamily family, ElemType elem_type, unsigned int build_nx, typename CaseName = Default>
static RealTensor FETestBase< order, family, elem_type, build_nx, CaseName >::true_hessian ( Point  p)
inlinestaticprotected

Definition at line 327 of file fe_test.h.

328  {
329  const Real & x = p(0);
330  const Real & y = LIBMESH_DIM > 1 ? p(1) : 0;
331  const Real & z = LIBMESH_DIM > 2 ? p(2) : 0;
332 
333  if (order > 3)
334  return RealTensor
335  { 12*x*x-12*x+2+2*z*(1-y)-2*(1-y)*(1-z), -2*x*z-(1-2*x)*(1-z)-(1-2*y)*z, 2*x*(1-y)-(1-2*x)*(1-y)-y*(1-y),
336  -2*x*z-(1-2*x)*(1-z)-(1-2*y)*z, -2*(1-x)*z, -x*x+x*(1-x)+(1-x)*(1-2*y),
337  2*x*(1-y)-(1-2*x)*(1-y)-y*(1-y), -x*x+x*(1-x)+(1-x)*(1-2*y), 12*z*z-12*z+2 };
338  else if (FE_CAN_TEST_CUBIC)
339  return RealTensor
340  { 6*x-4+2*(1-y), -2*x+z-1, y-1,
341  -2*x+z-1, -2*z, x+1-2*y,
342  y-1, x+1-2*y, 6*z-4 };
343  else if (order > 1)
344  return RealTensor
345  { 2, 0.125, 0.0625,
346  0.125, 1, 0.03125,
347  0.0625, 0.03125, 0.5 };
348 
349  return RealTensor
350  { 0, 0, 0,
351  0, 0, 0,
352  0, 0, 0 };
353  }
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
This class defines a tensor in LIBMESH_DIM dimensional Real or Complex space.

Member Data Documentation

◆ _case_name

template<Order order, FEFamily family, ElemType elem_type, unsigned int build_nx, typename CaseName = Default>
std::string FETestBase< order, family, elem_type, build_nx, CaseName >::_case_name
protected

Name of the case, can be used in the test to switch cases.

Definition at line 275 of file fe_test.h.

◆ _dim

template<Order order, FEFamily family, ElemType elem_type, unsigned int build_nx, typename CaseName = Default>
unsigned int FETestBase< order, family, elem_type, build_nx, CaseName >::_dim
protected

Definition at line 277 of file fe_test.h.

◆ _dof_indices

template<Order order, FEFamily family, ElemType elem_type, unsigned int build_nx, typename CaseName = Default>
std::vector<dof_id_type> FETestBase< order, family, elem_type, build_nx, CaseName >::_dof_indices
protected

Definition at line 279 of file fe_test.h.

◆ _elem

template<Order order, FEFamily family, ElemType elem_type, unsigned int build_nx, typename CaseName = Default>
Elem* FETestBase< order, family, elem_type, build_nx, CaseName >::_elem
protected

Definition at line 278 of file fe_test.h.

◆ _es

template<Order order, FEFamily family, ElemType elem_type, unsigned int build_nx, typename CaseName = Default>
std::unique_ptr<EquationSystems> FETestBase< order, family, elem_type, build_nx, CaseName >::_es
protected

Definition at line 282 of file fe_test.h.

◆ _fe

template<Order order, FEFamily family, ElemType elem_type, unsigned int build_nx, typename CaseName = Default>
std::unique_ptr<FEBase> FETestBase< order, family, elem_type, build_nx, CaseName >::_fe
protected

Definition at line 283 of file fe_test.h.

◆ _grad_tol

template<Order order, FEFamily family, ElemType elem_type, unsigned int build_nx, typename CaseName = Default>
Real FETestBase< order, family, elem_type, build_nx, CaseName >::_grad_tol
protected

Definition at line 286 of file fe_test.h.

◆ _hess_tol

template<Order order, FEFamily family, ElemType elem_type, unsigned int build_nx, typename CaseName = Default>
Real FETestBase< order, family, elem_type, build_nx, CaseName >::_hess_tol
protected

Definition at line 286 of file fe_test.h.

◆ _mesh

template<Order order, FEFamily family, ElemType elem_type, unsigned int build_nx, typename CaseName = Default>
std::unique_ptr<Mesh> FETestBase< order, family, elem_type, build_nx, CaseName >::_mesh
protected

Definition at line 281 of file fe_test.h.

◆ _nx

template<Order order, FEFamily family, ElemType elem_type, unsigned int build_nx, typename CaseName = Default>
unsigned int FETestBase< order, family, elem_type, build_nx, CaseName >::_nx
protected

Definition at line 277 of file fe_test.h.

◆ _ny

template<Order order, FEFamily family, ElemType elem_type, unsigned int build_nx, typename CaseName = Default>
unsigned int FETestBase< order, family, elem_type, build_nx, CaseName >::_ny
protected

Definition at line 277 of file fe_test.h.

◆ _nz

template<Order order, FEFamily family, ElemType elem_type, unsigned int build_nx, typename CaseName = Default>
unsigned int FETestBase< order, family, elem_type, build_nx, CaseName >::_nz
protected

Definition at line 277 of file fe_test.h.

◆ _qrule

template<Order order, FEFamily family, ElemType elem_type, unsigned int build_nx, typename CaseName = Default>
std::unique_ptr<QGauss> FETestBase< order, family, elem_type, build_nx, CaseName >::_qrule
protected

Definition at line 284 of file fe_test.h.

◆ _sys

template<Order order, FEFamily family, ElemType elem_type, unsigned int build_nx, typename CaseName = Default>
System* FETestBase< order, family, elem_type, build_nx, CaseName >::_sys
protected

Definition at line 280 of file fe_test.h.

◆ _value_tol

template<Order order, FEFamily family, ElemType elem_type, unsigned int build_nx, typename CaseName = Default>
Real FETestBase< order, family, elem_type, build_nx, CaseName >::_value_tol
protected

Definition at line 286 of file fe_test.h.

◆ libmesh_suite_name

template<Order order, FEFamily family, ElemType elem_type, unsigned int build_nx, typename CaseName = Default>
std::string FETestBase< order, family, elem_type, build_nx, CaseName >::libmesh_suite_name
protected

Definition at line 272 of file fe_test.h.


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