libMesh
Static Public Member Functions | Private Member Functions | List of all members
libMesh::InfFERadial Class Reference

Infinite elements are in some sense directional, compared to conventional finite elements. More...

#include <inf_fe.h>

Static Public Member Functions

static Real decay (const unsigned int dim, const Real v)
 
static Real decay_deriv (const Real)
 
static Real D (const Real v)
 
static Real D_deriv (const Real v)
 
static Order mapping_order ()
 
static unsigned int n_dofs (const Order o_radial)
 
static unsigned int n_dofs_at_node (const Order o_radial, const unsigned int n_onion)
 
static unsigned int n_dofs_per_elem (const Order o_radial)
 

Private Member Functions

 InfFERadial ()
 Never use an object of this type. More...
 

Detailed Description

Infinite elements are in some sense directional, compared to conventional finite elements.

All methods related to the radial part, which extends perpendicular from the base, are collected in this class. This class offers static methods for use in InfFE and InfFEMap

Author
Daniel Dreyer
Date
2003

Definition at line 53 of file inf_fe.h.

Constructor & Destructor Documentation

◆ InfFERadial()

libMesh::InfFERadial::InfFERadial ( )
inlineprivate

Never use an object of this type.

Definition at line 60 of file inf_fe.h.

60 {}

Member Function Documentation

◆ D()

static Real libMesh::InfFERadial::D ( const Real  v)
inlinestatic
Returns
The radial weight D, used as an additional weight for the test function, evaluated at local radial coordinate v.

Definition at line 82 of file inf_fe.h.

82 { return (1.-v)*(1.-v)/4.; }

Referenced by libMesh::InfFE< Dim, T_radial, T_map >::init_shape_functions().

◆ D_deriv()

static Real libMesh::InfFERadial::D_deriv ( const Real  v)
inlinestatic
Returns
The first (local) radial derivative of the radial weight D.

Definition at line 87 of file inf_fe.h.

87 { return (v-1.)/2.; }

Referenced by libMesh::InfFE< Dim, T_radial, T_map >::init_shape_functions().

◆ decay()

Real libMesh::InfFERadial::decay ( const unsigned int  dim,
const Real  v 
)
inlinestatic
Returns
The decay in the radial direction of the Dim dimensional infinite element.

Definition at line 850 of file inf_fe.h.

851 {
852  switch (dim)
853  //TODO:[DD] What decay do i have in 2D and 1D?
854  {
855  case 3:
856  return (1.-v)/2.;
857 
858  case 2:
859  return 0.;
860 
861  case 1:
862  return 0.;
863 
864  default:
865  libmesh_error_msg("Invalid dim = " << dim);
866  }
867 }

References dim.

Referenced by libMesh::InfFE< Dim, T_radial, T_map >::compute_data(), libMesh::InfFE< Dim, T_radial, T_map >::init_radial_shape_functions(), libMesh::InfFE< Dim, T_radial, T_map >::shape(), and libMesh::InfFE< Dim, T_radial, T_map >::shape_deriv().

◆ decay_deriv()

static Real libMesh::InfFERadial::decay_deriv ( const  Real)
inlinestatic
Returns
The first (local) derivative of the decay in radial direction of the infinite element.

This is only valid for 3D?? - RHS

Definition at line 76 of file inf_fe.h.

76 { return -.5; }

Referenced by libMesh::InfFE< Dim, T_radial, T_map >::compute_data(), libMesh::InfFE< Dim, T_radial, T_map >::init_radial_shape_functions(), and libMesh::InfFE< Dim, T_radial, T_map >::shape_deriv().

◆ mapping_order()

static Order libMesh::InfFERadial::mapping_order ( )
inlinestatic
Returns
The Order of the mapping functions in the radial direction. Currently, this is always FIRST.

Definition at line 93 of file inf_fe.h.

93 { return FIRST; }

References libMesh::FIRST.

Referenced by libMesh::InfFE< Dim, T_radial, T_map >::compute_data(), libMesh::InfFE< Dim, T_radial, T_map >::init_radial_shape_functions(), and libMesh::InfFEMap::map().

◆ n_dofs()

static unsigned int libMesh::InfFERadial::n_dofs ( const Order  o_radial)
inlinestatic
Returns
The number of shape functions in radial direction associated with this infinite element. Either way, if the modes are stored as nodal dofs (n_dofs_at_node) or as element dofs (n_dofs_per_elem), in each case we have the same number of modes in radial direction.
Note
For the case of 1D infinite elements, in the base the dof-per-node scheme is used.

From the formulation of the infinite elements, we have 1 mode, when o_radial=CONST. Therefore, we have a total of o_radial+1 modes in radial direction.

Definition at line 109 of file inf_fe.h.

110  { return static_cast<unsigned int>(o_radial)+1; }

Referenced by libMesh::InfFE< Dim, T_radial, T_map >::combine_base_radial(), libMesh::InfFE< Dim, T_radial, T_map >::init_radial_shape_functions(), and libMesh::InfFE< Dim, T_radial, T_map >::n_dofs().

◆ n_dofs_at_node()

unsigned int libMesh::InfFERadial::n_dofs_at_node ( const Order  o_radial,
const unsigned int  n_onion 
)
static
Returns
The number of dofs in radial direction on "onion slice" n (either 0 or 1) for an infinite element of type inf_elem_type and radial order o_radial.

Currently, the first radial mode is associated with the nodes in the base. All higher radial modes are associated with the physically existing nodes further out.

Definition at line 119 of file inf_fe_base_radial.C.

121 {
122  libmesh_assert_less (n_onion, 2);
123 
124  if (n_onion == 0)
125  /*
126  * in the base, no matter what, we have 1 node associated
127  * with radial direction
128  */
129  return 1;
130  else
131  /*
132  * this works, since for Order o_radial=CONST=0, we still
133  * have the (1-v)/2 mode, associated to the base
134  */
135  return static_cast<unsigned int>(o_radial);
136 }

Referenced by libMesh::InfFE< Dim, T_radial, T_map >::n_dofs_at_node().

◆ n_dofs_per_elem()

static unsigned int libMesh::InfFERadial::n_dofs_per_elem ( const Order  o_radial)
inlinestatic
Returns
The number of modes in radial direction interior to the element, not associated with any interior nodes.
Note
These modes are a discontinuous approximation, therefore we have no special formulation for coupling in the base, like in the case of associating (possibly) multiple dofs per (outer) node.

Definition at line 132 of file inf_fe.h.

133  { return static_cast<unsigned int>(o_radial)+1; }

Referenced by libMesh::InfFE< Dim, T_radial, T_map >::n_dofs_per_elem().


The documentation for this class was generated from the following files:
dim
unsigned int dim
Definition: adaptivity_ex3.C:113
libMesh::FIRST
Definition: enum_order.h:42