www.mooseframework.org
ComputeConcentrationDependentElasticityTensor.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 
16 
17 InputParameters
19 {
20  InputParameters params = ComputeRotatedElasticityTensorBase::validParams();
21  params.addClassDescription("Compute concentration dependent elasticity tensor.");
22  params.addRequiredParam<std::vector<Real>>("C0_ijkl",
23  "Stiffness tensor for zero concentration phase");
24  params.addRequiredParam<std::vector<Real>>("C1_ijkl",
25  "Stiffness tensor for phase having concentration 1.0");
26  params.addParam<MooseEnum>(
27  "fill_method0", RankFourTensor::fillMethodEnum() = "symmetric9", "The fill method");
28  params.addParam<MooseEnum>(
29  "fill_method1", RankFourTensor::fillMethodEnum() = "symmetric9", "The fill method");
30  params.addRequiredCoupledVar("c", "Concentration");
31  return params;
32 }
33 
35  const InputParameters & parameters)
37  _Cijkl0(getParam<std::vector<Real>>("C0_ijkl"),
38  (RankFourTensor::FillMethod)(int)getParam<MooseEnum>("fill_method0")),
39  _Cijkl1(getParam<std::vector<Real>>("C1_ijkl"),
40  (RankFourTensor::FillMethod)(int)getParam<MooseEnum>("fill_method1")),
41  _c(coupledValue("c")),
42  _c_name(getVar("c", 0)->name()),
43  _delasticity_tensor_dc(
44  declarePropertyDerivative<RankFourTensor>(_elasticity_tensor_name, _c_name))
45 {
46  // Define a rotation according to Euler angle parameters
47  RotationTensor R(_Euler_angles); // R type: RealTensorValue
48 
49  // Rotate tensors
50  _Cijkl0.rotate(R);
51  _Cijkl1.rotate(R);
52 }
53 
54 void
56 {
57  // Assign elasticity tensor at a given quad point
58  _elasticity_tensor[_qp] = _Cijkl0 + (_Cijkl1 - _Cijkl0) * _c[_qp];
59  // Define derivative of elasticity tensor with respect to concentration.
61 }
registerMooseObject
registerMooseObject("TensorMechanicsApp", ComputeConcentrationDependentElasticityTensor)
ComputeConcentrationDependentElasticityTensor::ComputeConcentrationDependentElasticityTensor
ComputeConcentrationDependentElasticityTensor(const InputParameters &parameters)
Definition: ComputeConcentrationDependentElasticityTensor.C:34
ComputeConcentrationDependentElasticityTensor::_Cijkl0
RankFourTensor _Cijkl0
Elasticity tensor for phase with zero concentration.
Definition: ComputeConcentrationDependentElasticityTensor.h:34
ComputeRotatedElasticityTensorBase
ComputeRotatedElasticityTensorBase is an intermediate base class that rotates an elasticity tensor ba...
Definition: ComputeRotatedElasticityTensorBase.h:23
ComputeConcentrationDependentElasticityTensor.h
ComputeConcentrationDependentElasticityTensor::_delasticity_tensor_dc
MaterialProperty< RankFourTensor > & _delasticity_tensor_dc
Derivative of elasticity tensor with respect to concentration.
Definition: ComputeConcentrationDependentElasticityTensor.h:42
ComputeConcentrationDependentElasticityTensor::_Cijkl1
RankFourTensor _Cijkl1
Elasticity tensor for phase with concentration 1.
Definition: ComputeConcentrationDependentElasticityTensor.h:36
ComputeRotatedElasticityTensorBase::validParams
static InputParameters validParams()
Definition: ComputeRotatedElasticityTensorBase.C:16
ComputeConcentrationDependentElasticityTensor::_c
const VariableValue & _c
Concentration variable.
Definition: ComputeConcentrationDependentElasticityTensor.h:38
ComputeConcentrationDependentElasticityTensor
ComputeElasticityTensor defines an elasticity tensor material object as a function of concentration f...
Definition: ComputeConcentrationDependentElasticityTensor.h:23
RotationTensor
This is a RealTensor version of a rotation matrix It is instantiated with the Euler angles,...
Definition: RotationTensor.h:29
name
const std::string name
Definition: Setup.h:21
defineLegacyParams
defineLegacyParams(ComputeConcentrationDependentElasticityTensor)
ComputeElasticityTensorBase::_elasticity_tensor
MaterialProperty< RankFourTensor > & _elasticity_tensor
Definition: ComputeElasticityTensorBase.h:40
ComputeRotatedElasticityTensorBase::_Euler_angles
RealVectorValue _Euler_angles
Definition: ComputeRotatedElasticityTensorBase.h:31
RankFourTensorTempl< Real >
RotationTensor.h
ComputeConcentrationDependentElasticityTensor::validParams
static InputParameters validParams()
Definition: ComputeConcentrationDependentElasticityTensor.C:18
ComputeConcentrationDependentElasticityTensor::computeQpElasticityTensor
virtual void computeQpElasticityTensor()
Definition: ComputeConcentrationDependentElasticityTensor.C:55