20 #include "libmesh/libmesh_config.h" 21 #ifdef LIBMESH_ENABLE_HIGHER_ORDER_SHAPES 23 #include "libmesh/elem.h" 24 #include "libmesh/fe.h" 25 #include "libmesh/fe_interface.h" 46 const bool add_p_level)
51 FEType fe_type(order, _underlying_fe_family);
64 libmesh_error_msg(
"Rational bases require the real element \nto query nodal weighting.");
75 const bool add_p_level)
78 (elem, fet.
order, i, p, add_p_level);
88 const bool add_p_level)
92 FEType underlying_fe_type(order, _underlying_fe_family);
106 libmesh_error_msg(
"Rational bases require the real element \nto query nodal weighting.");
115 const unsigned int i,
116 const unsigned int j,
118 const bool add_p_level)
121 (elem, fet.
order, i, j, p, add_p_level);
127 #ifdef LIBMESH_ENABLE_SECOND_DERIVATIVES 132 const unsigned int i,
133 const unsigned int j,
135 const bool add_p_level)
140 FEType underlying_fe_type(order, _underlying_fe_family);
155 libmesh_error_msg(
"Rational bases require the real element \nto query nodal weighting.");
163 const unsigned int i,
164 const unsigned int j,
166 const bool add_p_level)
169 (elem, fet.
order, i, j, p, add_p_level);
180 const unsigned int i,
181 const std::vector<Point> & p,
182 std::vector<OutputShape> & vi,
183 const bool add_p_level)
185 libmesh_assert_equal_to(p.size(), vi.size());
194 const std::vector<Point> & p,
195 std::vector<std::vector<OutputShape>> & v,
196 const bool add_p_level)
198 FEType underlying_fe_type(o, _underlying_fe_family);
208 const unsigned int i,
209 const unsigned int j,
210 const std::vector<Point> & p,
211 std::vector<OutputShape> & v,
212 const bool add_p_level)
214 libmesh_assert_equal_to(p.size(), v.size());
224 const std::vector<Point> & p,
225 std::vector<std::vector<Real>> * comps[3],
226 const bool add_p_level)
228 FEType underlying_fe_type(o, _underlying_fe_family);
238 #endif// LIBMESH_ENABLE_HIGHER_ORDER_SHAPES class FEType hides (possibly multiple) FEFamily and approximation orders, thereby enabling specialize...
ElemType
Defines an enum for geometric element types.
Order
defines an enum for polynomial orders.
static OutputShape shape(const ElemType t, const Order o, const unsigned int i, const Point &p)
static void all_shape_derivs(const Elem *elem, const Order o, const std::vector< Point > &p, std::vector< std::vector< OutputShape >> *comps[3], const bool add_p_level=true)
Fills comps with dphidxi (and in higher dimensions, eta/zeta) derivative component values for all sha...
This is the base class from which all geometric element types are derived.
static OutputShape shape_deriv(const ElemType t, const Order o, const unsigned int i, const unsigned int j, const Point &p)
OrderWrapper order
The approximation order of the element.
The libMesh namespace provides an interface to certain functionality in the library.
A specific instantiation of the FEBase class.
void rational_all_shape_derivs(const Elem &elem, const FEType underlying_fe_type, const std::vector< Point > &p, std::vector< std::vector< OutputShape >> *comps[3], const bool add_p_level)
Real rational_fe_shape(const Elem &elem, const FEType underlying_fe_type, const unsigned int i, const Point &p, const bool add_p_level)
Real rational_fe_shape_second_deriv(const Elem &elem, const FEType underlying_fe_type, const unsigned int i, const unsigned int j, const Point &p, const bool add_p_level)
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
static void shape_derivs(const Elem *elem, const Order o, const unsigned int i, const unsigned int j, const std::vector< Point > &p, std::vector< OutputShape > &v, const bool add_p_level=true)
Fills v with the derivative of the shape function, evaluated at all points p.
static void shapes(const Elem *elem, const Order o, const unsigned int i, const std::vector< Point > &p, std::vector< OutputShape > &v, const bool add_p_level=true)
Fills v with the values of the shape function, evaluated at all points p.
FEFamily
defines an enum for finite element families.
void rational_all_shapes(const Elem &elem, const FEType underlying_fe_type, const std::vector< Point > &p, std::vector< std::vector< Real >> &v, const bool add_p_level)
A Point defines a location in LIBMESH_DIM dimensional Real space.
auto index_range(const T &sizable)
Helper function that returns an IntRange<std::size_t> representing all the indices of the passed-in v...
static OutputShape shape_second_deriv(const ElemType t, const Order o, const unsigned int i, const unsigned int j, const Point &p)
Real rational_fe_shape_deriv(const Elem &elem, const FEType underlying_fe_type, const unsigned int i, const unsigned int j, const Point &p, const bool add_p_level)
static void all_shapes(const Elem *elem, const Order o, const std::vector< Point > &p, std::vector< std::vector< OutputShape > > &v, const bool add_p_level=true)
Fills v[i][qp] with the values of the shape functions, evaluated at all points in p...