20 #include "libmesh/libmesh_config.h" 22 #ifdef LIBMESH_ENABLE_INFINITE_ELEMENTS 25 #include "libmesh/face_inf_quad4.h" 26 #include "libmesh/fe_interface.h" 27 #include "libmesh/fe_type.h" 28 #include "libmesh/edge_edge2.h" 29 #include "libmesh/edge_inf_edge2.h" 30 #include "libmesh/enum_io_package.h" 31 #include "libmesh/enum_order.h" 32 #include "libmesh/inf_fe_map.h" 51 #ifdef LIBMESH_ENABLE_AMR 81 const unsigned int s)
const 83 libmesh_assert_less (s,
n_sides());
92 libmesh_assert_less(s,
n_sides());
129 if (conservative_p_dist_sq < min_distance_sq)
168 std::unique_ptr<Elem> edge;
174 edge = std::make_unique<Edge2>();
182 edge = std::make_unique<InfEdge2>();
187 libmesh_error_msg(
"Invalid side i = " << i);
191 for (
auto n : edge->node_index_range())
194 edge->set_interior_parent(
this);
195 edge->inherit_data_from(*
this);
203 const unsigned int i)
206 side->set_interior_parent(
this);
207 side->inherit_data_from(*
this);
214 std::vector<dof_id_type> & conn)
const 240 libmesh_error_msg(
"Unsupported IO package " << iop);
248 libmesh_assert_less (s, 3);
269 #endif // ifdef LIBMESH_ENABLE_INFINITE_ELEMENTS class FEType hides (possibly multiple) FEFamily and approximation orders, thereby enabling specialize...
ElemType
Defines an enum for geometric element types.
void swap2boundaryedges(unsigned short e1, unsigned short e2, BoundaryInfo *boundary_info) const
Swaps two edges in boundary_info, if it is non-null.
Order
defines an enum for polynomial orders.
virtual bool on_reference_element(const Point &p, const Real eps=TOLERANCE) const override final
virtual bool contains_point(const Point &p, Real tol=TOLERANCE) const override
static const unsigned int side_nodes_map[num_sides][nodes_per_side]
This maps the node of the side to element node numbers.
IOPackage
libMesh interfaces with several different software packages for the purposes of creating, reading, and writing mesh files.
void swap2boundarysides(unsigned short s1, unsigned short s2, BoundaryInfo *boundary_info) const
Swaps two sides in boundary_info, if it is non-null.
static const int num_sides
Geometric constants for all InfQuads.
The libMesh namespace provides an interface to certain functionality in the library.
static Point inverse_map(const unsigned int dim, const Elem *elem, const Point &p, const Real tolerance=TOLERANCE, const bool secure=true)
auto norm_sq() const -> decltype(std::norm(T()))
virtual Point origin() const override final
virtual std::vector< unsigned int > nodes_on_edge(const unsigned int e) const override
void swap2nodes(unsigned int n1, unsigned int n2)
Swaps two node_ptrs.
virtual bool is_node_on_side(const unsigned int n, const unsigned int s) const override
The BoundaryInfo class contains information relevant to boundary conditions including storing faces...
virtual unsigned short dim() const override final
virtual void connectivity(const unsigned int sf, const IOPackage iop, std::vector< dof_id_type > &conn) const override
void swap2neighbors(unsigned int n1, unsigned int n2)
Swaps two neighbor_ptrs.
virtual Order default_order() const override
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
virtual unsigned int n_sides() const override final
ElemType side_type(const unsigned int s) const override final
virtual void flip(BoundaryInfo *) override final
Flips the element (by swapping node and neighbor pointers) to have a mapping Jacobian of opposite sig...
static const int nodes_per_side
virtual std::vector< unsigned int > nodes_on_side(const unsigned int s) const override
static const int num_children
virtual unsigned int n_sub_elem() const override
static const int num_nodes
Geometric constants for InfQuad4.
A Point defines a location in LIBMESH_DIM dimensional Real space.
dof_id_type node_id(const unsigned int i) const
const Point & point(const unsigned int i) const
virtual std::unique_ptr< Elem > build_side_ptr(const unsigned int i) override
virtual std::unique_ptr< Elem > side_ptr(const unsigned int i) override final
static const Real _embedding_matrix[num_children][num_nodes][num_nodes]
Matrix that computes new nodal locations/solution values from current nodes/solution.