20 #ifndef __mast_level_set_intersection_h__ 21 #define __mast_level_set_intersection_h__ 30 #include "libmesh/elem.h" 63 const libMesh::Elem& e,
65 unsigned int max_elem_id,
66 unsigned int max_node_id);
77 const libMesh::Elem&
elem()
const;
160 const std::vector<const libMesh::Elem*>&
163 const std::vector<const libMesh::Elem*>&
180 const libMesh::Point&
204 std::pair<const libMesh::Node*, const libMesh::Node*>
227 std::unique_ptr<libMesh::Elem>
236 const libMesh::Elem& e,
241 (
const libMesh::Elem& e,
242 std::vector<std::pair<libMesh::Point, libMesh::Point> >& side_nondim_points,
243 std::map<const libMesh::Node*, libMesh::Point>& node_coord_map);
247 const libMesh::Elem& e,
249 const std::map<
const libMesh::Node*, std::pair<Real, bool> >&
258 const libMesh::Point& p1,
302 std::map<const libMesh::Node*, std::pair<const libMesh::Node*, const libMesh::Node*>>
_bounding_nodes;
311 #endif // __mast_level_set_intersection_h__ unsigned int edge_on_boundary() const
MAST::LevelSet2DIntersectionMode _mode
const MAST::FieldFunction< Real > * _phi
const std::vector< const libMesh::Elem * > & get_sub_elems_positive_phi() const
unsigned int get_side_on_interface(const libMesh::Elem &e) const
Real _find_intersection_on_straight_edge(const libMesh::Point &p0, const libMesh::Point &p1, const MAST::FieldFunction< Real > &phi, const Real t)
bool if_elem_has_positive_phi_region() const
const libMesh::Elem & elem() const
void get_material_sides_without_intersection(std::set< unsigned int > &sides) const
identifies the sides of the element that are completely on the material side without any intersection...
MAST::LevelSet2DIntersectionMode get_intersection_mode() const
bool _if_elem_on_negative_phi
true if element is completely on the negative side of level set with no intersection ...
virtual ~LevelSetIntersection()
Real get_node_phi_value(const libMesh::Node *n) const
std::unique_ptr< libMesh::Elem > _first_order_elem(const libMesh::Elem &e)
creates a first order element from the given high-order element.
bool if_node_is_new(const libMesh::Node &node) const
identifies if the node from the subelements is a new node or an existing node from the parent element...
bool if_elem_on_positive_phi() const
bool if_elem_on_negative_phi() const
bool if_hanging_node(const libMesh::Node *n) const
The case of two adjacent edges results in a new node on an edge that is not coincident with the level...
bool _if_elem_on_positive_phi
true if element is completely on the positive side of level set with no intersection ...
std::map< const libMesh::Elem *, int > _elem_sides_on_interface
std::map< const libMesh::Node *, std::pair< const libMesh::Node *, const libMesh::Node * > > _bounding_nodes
std::pair< const libMesh::Node *, const libMesh::Node * > get_bounding_nodes_for_node(const libMesh::Node &node) const
for new nodes required to create the subelements this method returns the nodes on an edge that bound ...
const unsigned int _max_elem_divs
void _add_node_local_coords(const libMesh::Elem &e, std::vector< std::pair< libMesh::Point, libMesh::Point > > &side_nondim_points, std::map< const libMesh::Node *, libMesh::Point > &node_coord_map)
void _find_quad4_intersections(const MAST::FieldFunction< Real > &phi, const libMesh::Elem &e, const Real t, const std::map< const libMesh::Node *, std::pair< Real, bool > > &node_phi_vals)
void init(const MAST::FieldFunction< Real > &phi, const libMesh::Elem &e, const Real t, unsigned int max_elem_id, unsigned int max_node_id)
const libMesh::Elem * _elem
std::vector< libMesh::Elem * > _new_elems
std::vector< const libMesh::Elem * > _positive_phi_elems
std::map< const libMesh::Node *, libMesh::Point > _node_local_coords
unsigned int _max_mesh_node_id
std::vector< libMesh::Node * > _new_nodes
bool if_intersection_through_elem() const
Real get_positive_phi_volume_fraction() const
bool if_interior_node(const libMesh::Node &node) const
identifies if the new node is on an edge along the level-set method in the interior of the element (a...
bool has_side_on_interface(const libMesh::Elem &e) const
void get_corner_nodes_on_negative_phi(std::set< const libMesh::Node *> &nodes) const
This creates the base class for functions that have a saptial and temporal dependence, and provide sensitivity operations with respect to the functions and parameters.
unsigned int node_on_boundary() const
bool if_elem_has_boundary() const
const std::vector< const libMesh::Elem * > & get_sub_elems_negative_phi() const
unsigned int _node_num_on_boundary
bool if_elem_has_negative_phi_region() const
std::vector< const libMesh::Elem * > _negative_phi_elems
const libMesh::Point & get_nondimensional_coordinate_for_node(const libMesh::Node &n) const
std::set< const libMesh::Node * > _interior_nodes
std::map< const libMesh::Node *, std::pair< Real, bool > > _node_phi_vals
unsigned int _max_mesh_elem_id
void _init_on_first_order_ref_elem(const MAST::FieldFunction< Real > &phi, const libMesh::Elem &e, const Real t)
initializes on a reference element that is a first-order counterpart of the given high-order element...
void get_nearest_intersection_point(const libMesh::Point &p, libMesh::Point &pt)
void clear()
clears the data structures
unsigned int _edge_num_on_boundary
LevelSet2DIntersectionMode
std::set< const libMesh::Node * > _hanging_node