https://mooseframework.inl.gov
ComputePolycrystalElasticityTensor.C
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 
11 #include "RotationTensor.h"
12 
14 
17 {
19  params.addClassDescription(
20  "Compute an evolving elasticity tensor coupled to a grain growth phase field model.");
21  params.addRequiredParam<UserObjectName>(
22  "grain_tracker", "Name of GrainTracker user object that provides RankFourTensors");
23  params.addParam<Real>("length_scale", 1.0e-9, "Length scale of the problem, in meters");
24  params.addParam<Real>("pressure_scale", 1.0e6, "Pressure scale of the problem, in pa");
26  "v", "var_name_base", "op_num", "Array of coupled variables");
27  params.addParam<UserObjectName>("euler_angle_provider",
28  "Name of Euler angle provider user object");
29 
30  return params;
31 }
32 
34  const InputParameters & parameters)
35  : ComputeElasticityTensorBase(parameters),
36  _length_scale(getParam<Real>("length_scale")),
37  _pressure_scale(getParam<Real>("pressure_scale")),
38  _grain_tracker(getUserObject<GrainDataTracker<RankFourTensor>>("grain_tracker")),
39  _op_num(coupledComponents("v")),
40  _vals(coupledValues("v")),
41  _euler(isParamValid("euler_angle_provider")
42  ? &getUserObject<EulerAngleProvider>("euler_angle_provider")
43  : nullptr),
44  _crysrot(isParamValid("euler_angle_provider")
45  ? &declareProperty<RankTwoTensor>(_base_name + "crysrot")
46  : nullptr),
47  _D_elastic_tensor(_op_num),
48  _JtoeV(6.24150974e18)
49 {
50  // Loop over variables (ops)
51  for (MooseIndex(_op_num) op_index = 0; op_index < _op_num; ++op_index)
52  {
53  // declare elasticity tensor derivative properties
54  _D_elastic_tensor[op_index] = &declarePropertyDerivative<RankFourTensor>(
55  _elasticity_tensor_name, coupledName("v", op_index));
56  }
57 }
58 
59 void
61 {
62  // Get list of active order parameters from grain tracker
63  const auto & op_to_grains = _grain_tracker.getVarToFeatureVector(_current_elem->id());
64 
65  // Calculate elasticity tensor
66  _elasticity_tensor[_qp].zero();
67  Real sum_h = 0.0;
68  for (MooseIndex(op_to_grains) op_index = 0; op_index < op_to_grains.size(); ++op_index)
69  {
70  auto grain_id = op_to_grains[op_index];
71  if (grain_id == FeatureFloodCount::invalid_id)
72  continue;
73 
74  // Interpolation factor for elasticity tensors
75  Real h = (1.0 + std::sin(libMesh::pi * ((*_vals[op_index])[_qp] - 0.5))) / 2.0;
76 
77  // Sum all rotated elasticity tensors
78  _elasticity_tensor[_qp] += _grain_tracker.getData(grain_id) * h;
79  sum_h += h;
80 
81  if (isParamValid("euler_angle_provider"))
82  {
83  EulerAngles angles;
84  angles = _euler->getEulerAngles(grain_id);
85 
86  RotationTensor R(angles);
87  if ((*_vals[op_index])[_qp] > 0.5)
88  (*_crysrot)[_qp] = R; // this is done for the crystal plasticity model compatibility
89  }
90  }
91 
92  const Real tol = 1.0e-10;
93  sum_h = std::max(sum_h, tol);
94  _elasticity_tensor[_qp] /= sum_h;
95 
96  // Calculate elasticity tensor derivative: Cderiv = dhdopi/sum_h * (Cop - _Cijkl)
97  for (MooseIndex(_op_num) op_index = 0; op_index < _op_num; ++op_index)
98  (*_D_elastic_tensor[op_index])[_qp].zero();
99 
100  for (MooseIndex(op_to_grains) op_index = 0; op_index < op_to_grains.size(); ++op_index)
101  {
102  auto grain_id = op_to_grains[op_index];
103  if (grain_id == FeatureFloodCount::invalid_id)
104  continue;
105 
106  Real dhdopi = libMesh::pi * std::cos(libMesh::pi * ((*_vals[op_index])[_qp] - 0.5)) / 2.0;
107  RankFourTensor & C_deriv = (*_D_elastic_tensor[op_index])[_qp];
108 
109  C_deriv = (_grain_tracker.getData(grain_id) - _elasticity_tensor[_qp]) * dhdopi / sum_h;
110 
111  // Convert from XPa to eV/(xm)^3, where X is pressure scale and x is length scale;
113  }
114 }
const Real _JtoeV
Conversion factor from J to eV.
const T & getData(unsigned int grain_id) const
return data for selected grain
VariableName coupledName(const std::string &var_name, unsigned int comp=0) const
void addParam(const std::string &name, const std::initializer_list< typename T::value_type > &value, const std::string &doc_string)
const EulerAngleProvider *const _euler
object providing the Euler angles
const double tol
ComputeElasticityTensorBase the base class for computing elasticity tensors.
GenericMaterialProperty< T, is_ad > & _elasticity_tensor
const double R
ComputePolycrystalElasticityTensor(const InputParameters &parameters)
void addRequiredParam(const std::string &name, const std::string &doc_string)
const std::vector< const VariableValue * > _vals
Order parameters.
virtual const std::vector< unsigned int > & getVarToFeatureVector(dof_id_type elem_id) const override
Returns a list of active unique feature ids for a particular element.
Definition: GrainTracker.C:130
Compute an evolving elasticity tensor coupled to a grain growth phase field model.
registerMooseObject("PhaseFieldApp", ComputePolycrystalElasticityTensor)
static const unsigned int invalid_id
This is a RealTensor version of a rotation matrix It is instantiated with the Euler angles...
const unsigned int _op_num
Number of order parameters.
std::vector< MaterialProperty< RankFourTensor > * > _D_elastic_tensor
vector of elasticity tensor material properties
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
void addRequiredCoupledVarWithAutoBuild(const std::string &name, const std::string &base_name, const std::string &num_name, const std::string &doc_string)
Euler angle triplet.
Definition: EulerAngles.h:24
virtual const EulerAngles & getEulerAngles(unsigned int i) const
const GrainDataTracker< RankFourTensor > & _grain_tracker
Grain tracker object.
void addClassDescription(const std::string &doc_string)
Abstract base class for user objects that implement the Euler Angle provider interface.
bool isParamValid(const std::string &name) const
GrainTracker derived class template to base objects on which maintain physical parameters for individ...
const Real pi