https://mooseframework.inl.gov
CrackMeshCut3DUserObject.h
Go to the documentation of this file.
1 //* This file is part of the MOOSE framework
2 //* https://mooseframework.inl.gov
3 //*
4 //* All rights reserved, see COPYRIGHT for full restrictions
5 //* https://github.com/idaholab/moose/blob/master/COPYRIGHT
6 //*
7 //* Licensed under LGPL 2.1, please see LICENSE for details
8 //* https://www.gnu.org/licenses/lgpl-2.1.html
9 
10 #pragma once
11 
12 #include "MeshCutUserObjectBase.h"
13 #include "CrackFrontDefinition.h"
14 
15 #include <array>
16 
17 class Function;
18 
26 {
27 public:
29 
31 
32  virtual void initialSetup() override;
33  virtual void initialize() override;
34 
35  virtual const std::vector<Point>
36  getCrackFrontPoints(unsigned int num_crack_front_points) const override;
37  virtual const std::vector<RealVectorValue>
38  getCrackPlaneNormals(unsigned int num_crack_front_points) const override;
39 
40  virtual bool cutElementByGeometry(const Elem * elem,
41  std::vector<Xfem::CutEdge> & cut_edges,
42  std::vector<Xfem::CutNode> & cut_nodes) const override;
43  virtual bool cutElementByGeometry(const Elem * elem,
44  std::vector<Xfem::CutFace> & cut_faces) const override;
45  virtual bool cutFragmentByGeometry(std::vector<std::vector<Point>> & frag_edges,
46  std::vector<Xfem::CutEdge> & cut_edges) const override;
47  virtual bool cutFragmentByGeometry(std::vector<std::vector<Point>> & frag_faces,
48  std::vector<Xfem::CutFace> & cut_faces) const override;
49 
55 
60  std::vector<int> getFrontPointsIndex() const;
61 
70  unsigned int getNumberOfCrackFrontPoints() const;
71 
72 protected:
74  const unsigned int _cut_elem_nnode = 3;
75  const unsigned int _cut_elem_dim = 2;
76 
79 
82 
88  std::vector<dof_id_type> _crack_front_points;
89 
92  {
94  FUNCTION
95  };
98 
100  enum class GrowthRateEnum
101  {
102  REPORTER,
103  FUNCTION
104  };
107 
109  const unsigned int _elem_dim = 3;
110 
112  const Real _const_intersection = 0.01;
113 
116 
118  unsigned int _n_step_growth;
119 
121  bool _stop;
122  bool _grow;
123 
125  std::vector<dof_id_type> _boundary;
126 
128  std::vector<std::vector<dof_id_type>> _active_boundary;
129 
131  std::vector<unsigned int> _inactive_boundary_pos;
132 
135  std::vector<dof_id_type> _tracked_crack_front_points;
136 
137  bool _cfd;
138 
140  std::set<Xfem::CutEdge> _boundary_edges;
141 
143  std::map<dof_id_type, std::vector<dof_id_type>> _boundary_map;
144 
146  std::vector<std::vector<Point>> _active_direction;
147 
149  std::vector<std::vector<dof_id_type>> _front;
150 
153 
156 
160  virtual bool intersectWithEdge(const Point & p1,
161  const Point & p2,
162  const std::vector<Point> & _vertices,
163  Point & point) const;
164 
168  bool findIntersection(const Point & p1,
169  const Point & p2,
170  const std::vector<Point> & vertices,
171  Point & point) const;
172 
176  bool isInsideEdge(const Point & p1, const Point & p2, const Point & p) const;
177 
181  Real getRelativePosition(const Point & p1, const Point & p2, const Point & p) const;
182 
186  bool isInsideCutPlane(const std::vector<Point> & _vertices, const Point & p) const;
187 
194  void findBoundaryNodes();
195 
199  void findBoundaryEdges();
200 
204  void sortBoundaryNodes();
205 
210 
214  void refineBoundary();
215 
220 
224  void growFront();
225 
229  void sortFrontNodes();
230 
234  void findFrontIntersection();
235 
239  void refineFront();
240 
244  void triangulation();
245 
249  void joinBoundary();
250 
254  const Function * _func_x;
255  const Function * _func_y;
256  const Function * _func_z;
257  const Function * _func_v;
258 
260  const std::vector<Real> * const _ki_vpp;
262  const std::vector<Real> * const _kii_vpp;
264  const std::vector<Real> * const _growth_inc_reporter;
265 };
GrowthDirectionEnum
Enum to for crack growth direction.
CrackMeshCut3DUserObject: (1) reads in a mesh describing the crack surface, (2) uses the mesh to do i...
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...
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...
std::vector< int > getFrontPointsIndex() const
Get crack front points in the active segment -1 means inactive; positive is the point&#39;s index in the ...
unsigned int _n_step_growth
Number of steps to grow the mesh.
const InputParameters & parameters() const
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.
const GrowthRateEnum _growth_increment_method
The growth increment 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
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.
const std::vector< Real > *const _ki_vpp
Pointer to fracture integral ki if available.
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 &parameters)
bool _stop
Variables to help control the work flow.
const std::vector< Real > *const _kii_vpp
Pointer to fracture integral kii if available.
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.
Simple base class for XFEM cutting objects that use a mesh to cut.
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.
static InputParameters validParams()
virtual void initialize() override
GrowthRateEnum
Enum to for crack growth rate.
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.
void refineBoundary()
If boundary nodes are too sparse, add nodes in between.
std::vector< std::vector< Point > > _active_direction
Growth direction for active boundaries.
const std::vector< Real > *const _growth_inc_reporter
Pointer to reporter with growth increment if available.
void findActiveBoundaryDirection()
Find growth direction at each active node.
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.
uint8_t dof_id_type