www.mooseframework.org
ComputePolycrystalElasticityTensor.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 "RotationTensor.h"
12 
14 
15 template <>
16 InputParameters
18 {
19  InputParameters params = validParams<ComputeElasticityTensorBase>();
20  params.addClassDescription(
21  "Compute an evolving elasticity tensor coupled to a grain growth phase field model.");
22  params.addRequiredParam<UserObjectName>(
23  "grain_tracker", "Name of GrainTracker user object that provides RankFourTensors");
24  params.addParam<Real>("length_scale", 1.0e-9, "Length scale of the problem, in meters");
25  params.addParam<Real>("pressure_scale", 1.0e6, "Pressure scale of the problem, in pa");
26  params.addRequiredCoupledVarWithAutoBuild(
27  "v", "var_name_base", "op_num", "Array of coupled variables");
28  return params;
29 }
30 
32  const InputParameters & parameters)
33  : ComputeElasticityTensorBase(parameters),
34  _length_scale(getParam<Real>("length_scale")),
35  _pressure_scale(getParam<Real>("pressure_scale")),
36  _grain_tracker(getUserObject<GrainDataTracker<RankFourTensor>>("grain_tracker")),
37  _op_num(coupledComponents("v")),
38  _vals(_op_num),
39  _D_elastic_tensor(_op_num),
40  _JtoeV(6.24150974e18)
41 {
42  // Loop over variables (ops)
43  for (MooseIndex(_op_num) op_index = 0; op_index < _op_num; ++op_index)
44  {
45  // Initialize variables
46  _vals[op_index] = &coupledValue("v", op_index);
47 
48  // declare elasticity tensor derivative properties
49  _D_elastic_tensor[op_index] = &declarePropertyDerivative<RankFourTensor>(
50  _elasticity_tensor_name, getVar("v", op_index)->name());
51  }
52 }
53 
54 void
56 {
57  // Get list of active order parameters from grain tracker
58  const auto & op_to_grains = _grain_tracker.getVarToFeatureVector(_current_elem->id());
59 
60  // Calculate elasticity tensor
61  _elasticity_tensor[_qp].zero();
62  Real sum_h = 0.0;
63  for (MooseIndex(op_to_grains) op_index = 0; op_index < op_to_grains.size(); ++op_index)
64  {
65  auto grain_id = op_to_grains[op_index];
66  if (grain_id == FeatureFloodCount::invalid_id)
67  continue;
68 
69  // Interpolation factor for elasticity tensors
70  Real h = (1.0 + std::sin(libMesh::pi * ((*_vals[op_index])[_qp] - 0.5))) / 2.0;
71 
72  // Sum all rotated elasticity tensors
73  _elasticity_tensor[_qp] += _grain_tracker.getData(grain_id) * h;
74  sum_h += h;
75  }
76 
77  const Real tol = 1.0e-10;
78  sum_h = std::max(sum_h, tol);
79  _elasticity_tensor[_qp] /= sum_h;
80 
81  // Calculate elasticity tensor derivative: Cderiv = dhdopi/sum_h * (Cop - _Cijkl)
82  for (MooseIndex(_op_num) op_index = 0; op_index < _op_num; ++op_index)
83  (*_D_elastic_tensor[op_index])[_qp].zero();
84 
85  for (MooseIndex(op_to_grains) op_index = 0; op_index < op_to_grains.size(); ++op_index)
86  {
87  auto grain_id = op_to_grains[op_index];
88  if (grain_id == FeatureFloodCount::invalid_id)
89  continue;
90 
91  Real dhdopi = libMesh::pi * std::cos(libMesh::pi * ((*_vals[op_index])[_qp] - 0.5)) / 2.0;
92  RankFourTensor & C_deriv = (*_D_elastic_tensor[op_index])[_qp];
93 
94  C_deriv = (_grain_tracker.getData(grain_id) - _elasticity_tensor[_qp]) * dhdopi / sum_h;
95 
96  // Convert from XPa to eV/(xm)^3, where X is pressure scale and x is length scale;
98  }
99 }
ComputePolycrystalElasticityTensor::_pressure_scale
Real _pressure_scale
Definition: ComputePolycrystalElasticityTensor.h:34
ComputePolycrystalElasticityTensor.h
GrainDataTracker
GrainTracker derived class template to base objects on which maintain physical parameters for individ...
Definition: GrainDataTracker.h:19
ComputePolycrystalElasticityTensor::ComputePolycrystalElasticityTensor
ComputePolycrystalElasticityTensor(const InputParameters &parameters)
Definition: ComputePolycrystalElasticityTensor.C:31
ComputePolycrystalElasticityTensor
Compute an evolving elasticity tensor coupled to a grain growth phase field model.
Definition: ComputePolycrystalElasticityTensor.h:25
GrainDataTracker::getData
const T & getData(unsigned int grain_id) const
return data for selected grain
Definition: GrainDataTracker.h:44
ComputeElasticityTensorBase
ComputeElasticityTensorBase the base class for computing elasticity tensors.
Definition: ComputeElasticityTensorBase.h:25
ComputePolycrystalElasticityTensor::_op_num
const unsigned int _op_num
Number of order parameters.
Definition: ComputePolycrystalElasticityTensor.h:40
tol
const double tol
Definition: Setup.h:18
validParams< ComputePolycrystalElasticityTensor >
InputParameters validParams< ComputePolycrystalElasticityTensor >()
Definition: ComputePolycrystalElasticityTensor.C:17
validParams< ComputeElasticityTensorBase >
InputParameters validParams< ComputeElasticityTensorBase >()
registerMooseObject
registerMooseObject("PhaseFieldApp", ComputePolycrystalElasticityTensor)
name
const std::string name
Definition: Setup.h:21
FeatureFloodCount::invalid_id
static const unsigned int invalid_id
Definition: FeatureFloodCount.h:94
GrainTracker::getVarToFeatureVector
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:131
ComputePolycrystalElasticityTensor::computeQpElasticityTensor
virtual void computeQpElasticityTensor()
Definition: ComputePolycrystalElasticityTensor.C:55
ComputeElasticityTensorBase::_elasticity_tensor
MaterialProperty< RankFourTensor > & _elasticity_tensor
Definition: ComputeElasticityTensorBase.h:40
ComputePolycrystalElasticityTensor::_D_elastic_tensor
std::vector< MaterialProperty< RankFourTensor > * > _D_elastic_tensor
vector of elasticity tensor material properties
Definition: ComputePolycrystalElasticityTensor.h:46
RankFourTensorTempl< Real >
ComputeElasticityTensorBase::_elasticity_tensor_name
std::string _elasticity_tensor_name
Definition: ComputeElasticityTensorBase.h:38
RotationTensor.h
ComputePolycrystalElasticityTensor::_length_scale
Real _length_scale
Definition: ComputePolycrystalElasticityTensor.h:33
ComputePolycrystalElasticityTensor::_JtoeV
const Real _JtoeV
Conversion factor from J to eV.
Definition: ComputePolycrystalElasticityTensor.h:49
ComputePolycrystalElasticityTensor::_grain_tracker
const GrainDataTracker< RankFourTensor > & _grain_tracker
Grain tracker object.
Definition: ComputePolycrystalElasticityTensor.h:37
ComputePolycrystalElasticityTensor::_vals
std::vector< const VariableValue * > _vals
Order parameters.
Definition: ComputePolycrystalElasticityTensor.h:43