35 virtual const std::vector<Point>
37 virtual const std::vector<RealVectorValue>
41 std::vector<Xfem::CutEdge> & cut_edges,
42 std::vector<Xfem::CutNode> & cut_nodes)
const override;
44 std::vector<Xfem::CutFace> & cut_faces)
const override;
46 std::vector<Xfem::CutEdge> & cut_edges)
const override;
48 std::vector<Xfem::CutFace> & cut_faces)
const override;
160 std::vector<unsigned long int>
_dn;
161 std::vector<unsigned long int>
_n;
164 std::vector<std::vector<dof_id_type>>
_front;
177 const std::vector<Point> & _vertices,
178 Point & point)
const;
185 const std::vector<Point> & vertices,
186 Point & point)
const;
191 bool isInsideEdge(
const Point & p1,
const Point & p2,
const Point & p)
const;
201 bool isInsideCutPlane(
const std::vector<Point> & _vertices,
const Point & p)
const;
GrowthDirectionEnum
Enum to for crack growth direction.
CrackMeshCut3DUserObject: (1) reads in a mesh describing the crack surface, (2) uses the mesh to do i...
std::vector< unsigned long int > _dn
Fatigue life.
Real _size_control
Used for cutter mesh refinement and front advancement.
void findBoundaryNodes()
Find boundary nodes of the cutter mesh This is a simple algorithm simply based on the added angle = 3...
std::vector< int > getFrontPointsIndex()
Get crack front points in the active segment -1 means inactive; positive is the point's index in the ...
const unsigned int _cut_elem_nnode
The cutter mesh has triangluar elements only.
void findActiveBoundaryNodes()
Find all active boundary nodes in the cutter mesh Find boundary nodes that will grow; nodes outside o...
unsigned int _n_step_growth
Number of steps to grow the mesh.
std::vector< unsigned long int > _n
bool findIntersection(const Point &p1, const Point &p2, const std::vector< Point > &vertices, Point &point) const
Find directional intersection along the positive extension of the vector from p1 to p2...
const GrowthDirectionEnum _growth_dir_method
The direction method for growing mesh at the front.
virtual bool cutFragmentByGeometry(std::vector< std::vector< Point >> &frag_edges, std::vector< Xfem::CutEdge > &cut_edges) const override
void setSubCriticalGrowthSize(std::vector< Real > &growth_size)
Return growth size at the active boundary to the mesh cutter.
Real getRelativePosition(const Point &p1, const Point &p2, const Point &p) const
Get the relative position of p from p1.
Real findDistance(dof_id_type node1, dof_id_type node2)
Find distance between two nodes.
std::map< dof_id_type, std::vector< dof_id_type > > _boundary_map
A map of boundary nodes and their neighbors.
void growFront()
Grow the cutter mesh.
const Real _const_intersection
Used to define intersection points.
void findBoundaryEdges()
Find boundary edges of the cutter mesh.
const unsigned int _elem_dim
The structural mesh must be 3D only.
void triangulation()
Create tri3 elements between the new front and the old front.
void refineFront()
Refine the mesh at the front.
std::vector< dof_id_type > _tracked_crack_front_points
Front nodes that are grown from the crack front definition defined in the input therefore, they are (1) in the same order as defined in the input and (2) the number of nodes does not change.
void sortFrontNodes()
Sort the front nodes.
Class used in fracture integrals to define geometric characteristics of the crack front...
std::vector< dof_id_type > _crack_front_points
updated crack front definition they are in the same order as defined in the input but the number of n...
void findFrontIntersection()
Find front-structure intersections.
const Function * _func_x
Parsed functions of front growth.
std::vector< std::vector< dof_id_type > > _front
New boundary after growth.
virtual void initialSetup() override
virtual const std::vector< Point > getCrackFrontPoints(unsigned int num_crack_front_points) const override
get a set of points along a crack front from a XFEM GeometricCutUserObject
unsigned int _num_crack_front_points
Total number of crack front points in the mesh cutter.
virtual bool cutElementByGeometry(const Elem *elem, std::vector< Xfem::CutEdge > &cut_edges, std::vector< Xfem::CutNode > &cut_nodes) const override
bool _is_mesh_modified
Indicator that shows if the cutting mesh is modified or not in this calculation step.
CrackMeshCut3DUserObject(const InputParameters ¶meters)
bool _stop
Variables to help control the work flow.
const unsigned int _cut_elem_dim
std::vector< unsigned int > _inactive_boundary_pos
Inactive boundary.
void joinBoundary()
Join active boundaries and inactive boundaries to be the new boundary.
virtual const std::vector< RealVectorValue > getCrackPlaneNormals(unsigned int num_crack_front_points) const override
get a set of normal vectors along a crack front from a XFEM GeometricCutUserObject ...
virtual bool intersectWithEdge(const Point &p1, const Point &p2, const std::vector< Point > &_vertices, Point &point) const
Check if a line intersects with an element.
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
void sortBoundaryNodes()
Sort boundary nodes to be in the right order along the boundary.
std::vector< std::vector< dof_id_type > > _active_boundary
Active boundary nodes where growth is allowed.
unsigned int getNumberOfCrackFrontPoints() const
Return the total number of crack front points.
MooseMesh & _mesh
The structural mesh.
CrackFrontDefinition * _crack_front_definition
The crack front definition.
const InputParameters & parameters() const
static InputParameters validParams()
virtual void initialize() override
GrowthRateEnum
Enum to for crack growth rate.
const GrowthRateEnum _growth_rate_method
The rate method for growing mesh at the front.
bool isInsideEdge(const Point &p1, const Point &p2, const Point &p) const
Check if point p is inside the edge p1-p2.
std::set< Xfem::CutEdge > _boundary_edges
Edges at the boundary.
std::vector< Real > _growth_size
Growth size for the active boundary in a subcritical simulation.
void refineBoundary()
If boundary nodes are too sparse, add nodes in between.
std::vector< std::vector< Point > > _active_direction
Growth direction for active boundaries.
void findActiveBoundaryDirection()
Find growth direction at each active node.
std::unique_ptr< MeshBase > _cut_mesh
The cutter mesh.
bool isInsideCutPlane(const std::vector< Point > &_vertices, const Point &p) const
Check if point p is inside a plane.
std::vector< dof_id_type > _boundary
Boundary nodes of the cutter mesh.