www.mooseframework.org
CrackTipEnrichmentStressDivergenceTensors.C
Go to the documentation of this file.
1 //* This file is part of the MOOSE framework
2 //* https://www.mooseframework.org
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 
11 #include "ElasticityTensorTools.h"
12 
14 
15 template <>
16 InputParameters
18 {
19  InputParameters params = validParams<ALEKernel>();
20  params.addClassDescription("Enrich stress divergence kernel for small-strain simulations");
21  params.addRequiredParam<unsigned int>("component",
22  "An integer corresponding to the direction the variable "
23  "this kernel acts in. (0 for x, 1 for y, 2 for z)");
24  params.addRequiredParam<unsigned int>("enrichment_component",
25  "The component of the enrichement functions");
26  params.addRequiredCoupledVar("displacements",
27  "The string of displacements suitable for the problem statement");
28  params.addRequiredCoupledVar(
29  "enrichment_displacements",
30  "The string of enrichment displacements suitable for the problem statement");
31  params.addParam<std::string>("base_name", "Material property base name");
32  params.addRequiredParam<UserObjectName>("crack_front_definition",
33  "The CrackFrontDefinition user object name");
34  params.set<bool>("use_displaced_mesh") = false;
35  return params;
36 }
37 
39  const InputParameters & parameters)
40  : ALEKernel(parameters),
41  EnrichmentFunctionCalculation(&getUserObject<CrackFrontDefinition>("crack_front_definition")),
42  _base_name(isParamValid("base_name") ? getParam<std::string>("base_name") + "_" : ""),
43  _stress(getMaterialPropertyByName<RankTwoTensor>(_base_name + "stress")),
44  _Jacobian_mult(getMaterialPropertyByName<RankFourTensor>(_base_name + "Jacobian_mult")),
45  _component(getParam<unsigned int>("component")),
46  _enrichment_component(getParam<unsigned int>("enrichment_component")),
47  _nenrich_disp(coupledComponents("enrichment_displacements")),
48  _ndisp(coupledComponents("displacements")),
49  _B(4),
50  _dBX(4),
51  _dBx(4),
52  _BI(4),
53  _BJ(4)
54 {
56  for (unsigned int i = 0; i < _nenrich_disp; ++i)
57  _enrich_disp_var[i] = coupled("enrichment_displacements", i);
58 
59  _disp_var.resize(_ndisp);
60  for (unsigned int i = 0; i < _ndisp; ++i)
61  _disp_var[i] = coupled("displacements", i);
62 }
63 
64 Real
66 {
67  crackTipEnrichementFunctionAtPoint(*_current_elem->node_ptr(_i), _BI);
68 
69  crackTipEnrichementFunctionAtPoint(_q_point[_qp], _B);
70  unsigned int crack_front_point_index =
72 
73  for (unsigned int i = 0; i < 4; ++i)
74  rotateFromCrackFrontCoordsToGlobal(_dBx[i], _dBX[i], crack_front_point_index);
75 
76  RealVectorValue grad_B(_dBX[_enrichment_component]);
77 
78  return _stress[_qp].row(_component) *
79  (_grad_test[_i][_qp] * (_B[_enrichment_component] - _BI[_enrichment_component]) +
80  _test[_i][_qp] * grad_B);
81 }
82 
83 Real
85 {
86  crackTipEnrichementFunctionAtPoint(*_current_elem->node_ptr(_i), _BI);
87  crackTipEnrichementFunctionAtPoint(*_current_elem->node_ptr(_j), _BJ);
88 
89  crackTipEnrichementFunctionAtPoint(_q_point[_qp], _B);
90 
91  unsigned int crack_front_point_index =
93 
94  for (unsigned int i = 0; i < 4; ++i)
95  rotateFromCrackFrontCoordsToGlobal(_dBx[i], _dBX[i], crack_front_point_index);
96 
97  RealVectorValue grad_B(_dBX[_enrichment_component]);
98 
99  RealVectorValue grad_test =
100  _grad_test[_i][_qp] * (_B[_enrichment_component] - _BI[_enrichment_component]) +
101  _test[_i][_qp] * grad_B;
102  RealVectorValue grad_phi =
103  _grad_phi[_j][_qp] * (_B[_enrichment_component] - _BJ[_enrichment_component]) +
104  _phi[_j][_qp] * grad_B;
105 
107  _Jacobian_mult[_qp], _component, _component, grad_test, grad_phi);
108 }
109 
110 Real
112 {
113  unsigned int coupled_component = 0;
114  unsigned int coupled_enrichment_component = 0;
115  bool active(false);
116  bool active_enrich(false);
117 
118  for (unsigned int i = 0; i < _enrich_disp_var.size(); ++i)
119  {
120  if (jvar == _enrich_disp_var[i])
121  {
122  coupled_component = i / 4;
123  coupled_enrichment_component = i % 4;
124  active_enrich = true;
125  }
126  }
127 
128  for (unsigned int i = 0; i < _disp_var.size(); ++i)
129  {
130  if (jvar == _disp_var[i])
131  {
132  coupled_component = i;
133  active = true;
134  }
135  }
136 
137  if (active_enrich)
138  {
139  crackTipEnrichementFunctionAtPoint(*_current_elem->node_ptr(_i), _BI);
140  crackTipEnrichementFunctionAtPoint(*_current_elem->node_ptr(_j), _BJ);
141 
142  crackTipEnrichementFunctionAtPoint(_q_point[_qp], _B);
143  unsigned int crack_front_point_index =
145 
146  for (unsigned int i = 0; i < 4; ++i)
147  rotateFromCrackFrontCoordsToGlobal(_dBx[i], _dBX[i], crack_front_point_index);
148 
149  RealVectorValue grad_B_test(_dBX[_enrichment_component]);
150  RealVectorValue grad_B_phi(_dBX[coupled_enrichment_component]);
151 
152  RealVectorValue grad_test =
153  _grad_test[_i][_qp] * (_B[_enrichment_component] - _BI[_enrichment_component]) +
154  _test[_i][_qp] * grad_B_test;
155  RealVectorValue grad_phi = _grad_phi[_j][_qp] * (_B[coupled_enrichment_component] -
156  _BJ[coupled_enrichment_component]) +
157  _phi[_j][_qp] * grad_B_phi;
158 
160  _Jacobian_mult[_qp], _component, coupled_component, grad_test, grad_phi);
161  }
162  else if (active)
163  {
164  crackTipEnrichementFunctionAtPoint(*_current_elem->node_ptr(_i), _BI);
165 
166  crackTipEnrichementFunctionAtPoint(_q_point[_qp], _B);
167  unsigned int crack_front_point_index =
169 
170  for (unsigned int i = 0; i < 4; ++i)
171  rotateFromCrackFrontCoordsToGlobal(_dBx[i], _dBX[i], crack_front_point_index);
172 
173  RealVectorValue grad_B_test(_dBX[_enrichment_component]);
174 
175  RealVectorValue grad_test =
176  _grad_test[_i][_qp] * (_B[_enrichment_component] - _BI[_enrichment_component]) +
177  _test[_i][_qp] * grad_B_test;
178 
180  _Jacobian_mult[_qp], _component, coupled_component, grad_test, _grad_phi[_j][_qp]);
181  }
182 
183  return 0;
184 }
ElasticityTensorTools::elasticJacobian
Real elasticJacobian(const RankFourTensor &r4t, unsigned int i, unsigned int k, const RealGradient &grad_test, const RealGradient &grad_phi)
This is used for the standard kernel stress_ij*d(test)/dx_j, when varied wrt u_k Jacobian entry: d(st...
Definition: ElasticityTensorTools.C:21
CrackTipEnrichmentStressDivergenceTensors::_disp_var
std::vector< unsigned int > _disp_var
Definition: CrackTipEnrichmentStressDivergenceTensors.h:60
EnrichmentFunctionCalculation::crackTipEnrichementFunctionDerivativeAtPoint
virtual unsigned int crackTipEnrichementFunctionDerivativeAtPoint(const Point &point, std::vector< RealVectorValue > &dB)
calculate the enrichment function derivatives at point
Definition: EnrichmentFunctionCalculation.C:43
CrackTipEnrichmentStressDivergenceTensors::_dBx
std::vector< RealVectorValue > _dBx
derivatives of enrichment function respect to crack front cooridnate
Definition: CrackTipEnrichmentStressDivergenceTensors.h:68
CrackTipEnrichmentStressDivergenceTensors::_B
std::vector< Real > _B
enrichment function value
Definition: CrackTipEnrichmentStressDivergenceTensors.h:64
CrackTipEnrichmentStressDivergenceTensors.h
CrackTipEnrichmentStressDivergenceTensors::computeQpOffDiagJacobian
virtual Real computeQpOffDiagJacobian(unsigned int jvar) override
Definition: CrackTipEnrichmentStressDivergenceTensors.C:111
validParams< ALEKernel >
InputParameters validParams< ALEKernel >()
CrackTipEnrichmentStressDivergenceTensors::_BI
std::vector< Real > _BI
enrichment function at node I
Definition: CrackTipEnrichmentStressDivergenceTensors.h:70
CrackFrontDefinition
Works on top of NodalNormalsPreprocessor.
Definition: CrackFrontDefinition.h:36
ALEKernel
Definition: ALEKernel.h:21
CrackTipEnrichmentStressDivergenceTensors::_BJ
std::vector< Real > _BJ
enrichment function at node J
Definition: CrackTipEnrichmentStressDivergenceTensors.h:72
CrackTipEnrichmentStressDivergenceTensors::CrackTipEnrichmentStressDivergenceTensors
CrackTipEnrichmentStressDivergenceTensors(const InputParameters &parameters)
Definition: CrackTipEnrichmentStressDivergenceTensors.C:38
CrackTipEnrichmentStressDivergenceTensors::_component
const unsigned int _component
displacement components
Definition: CrackTipEnrichmentStressDivergenceTensors.h:50
ElasticityTensorTools.h
CrackTipEnrichmentStressDivergenceTensors::computeQpJacobian
virtual Real computeQpJacobian() override
Definition: CrackTipEnrichmentStressDivergenceTensors.C:84
CrackTipEnrichmentStressDivergenceTensors::_nenrich_disp
unsigned int _nenrich_disp
Coupled enrichment displacement variables.
Definition: CrackTipEnrichmentStressDivergenceTensors.h:55
validParams< CrackTipEnrichmentStressDivergenceTensors >
InputParameters validParams< CrackTipEnrichmentStressDivergenceTensors >()
Definition: CrackTipEnrichmentStressDivergenceTensors.C:17
CrackTipEnrichmentStressDivergenceTensors::computeQpResidual
virtual Real computeQpResidual() override
Definition: CrackTipEnrichmentStressDivergenceTensors.C:65
registerMooseObject
registerMooseObject("XFEMApp", CrackTipEnrichmentStressDivergenceTensors)
CrackTipEnrichmentStressDivergenceTensors::_dBX
std::vector< RealVectorValue > _dBX
derivatives of enrichment function respect to global cooridnate
Definition: CrackTipEnrichmentStressDivergenceTensors.h:66
RankFourTensorTempl
Definition: ACGrGrElasticDrivingForce.h:20
CrackTipEnrichmentStressDivergenceTensors::_enrich_disp_var
std::vector< unsigned int > _enrich_disp_var
Definition: CrackTipEnrichmentStressDivergenceTensors.h:56
CrackTipEnrichmentStressDivergenceTensors
CrackTipEnrichmentStressDivergenceTensors implements the residual and jacobian for enrichement displa...
Definition: CrackTipEnrichmentStressDivergenceTensors.h:29
CrackTipEnrichmentStressDivergenceTensors::_stress
const MaterialProperty< RankTwoTensor > & _stress
Definition: CrackTipEnrichmentStressDivergenceTensors.h:42
EnrichmentFunctionCalculation::crackTipEnrichementFunctionAtPoint
virtual unsigned int crackTipEnrichementFunctionAtPoint(const Point &point, std::vector< Real > &B)
calculate the enrichment function values at point
Definition: EnrichmentFunctionCalculation.C:19
RankTwoTensorTempl< Real >
CrackTipEnrichmentStressDivergenceTensors::_ndisp
unsigned int _ndisp
Coupled displacement variables.
Definition: CrackTipEnrichmentStressDivergenceTensors.h:59
EnrichmentFunctionCalculation::rotateFromCrackFrontCoordsToGlobal
void rotateFromCrackFrontCoordsToGlobal(const RealVectorValue &vector, RealVectorValue &rotated_vector, const unsigned int point_index)
rotate a vector from crack front coordinate to global cooridate
Definition: EnrichmentFunctionCalculation.C:78
CrackTipEnrichmentStressDivergenceTensors::_Jacobian_mult
const MaterialProperty< RankFourTensor > & _Jacobian_mult
Definition: CrackTipEnrichmentStressDivergenceTensors.h:43
CrackTipEnrichmentStressDivergenceTensors::_enrichment_component
const unsigned int _enrichment_component
enrichment function components
Definition: CrackTipEnrichmentStressDivergenceTensors.h:52
EnrichmentFunctionCalculation
Perform calculation of enrichment function values and derivatives.
Definition: EnrichmentFunctionCalculation.h:22