www.mooseframework.org
ACKappaFunction.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 
10 #include "ACKappaFunction.h"
11 
12 registerMooseObject("PhaseFieldApp", ACKappaFunction);
13 registerMooseObject("PhaseFieldApp", ADACKappaFunction);
14 
15 template <bool is_ad>
18 {
20  params.addClassDescription("Gradient energy term for when kappa as a function of the variable");
21  params.addParam<MaterialPropertyName>("mob_name", "L", "The mobility used with the kernel");
22  params.addParam<MaterialPropertyName>("kappa_name", "kappa_op", "The kappa function name");
23  params.addCoupledVar("v", "Vector of order parameters");
24  return params;
25 }
26 template <bool is_ad>
29  _L(this->template getGenericMaterialProperty<Real, is_ad>("mob_name")),
30  _kappa_name(this->template getParam<MaterialPropertyName>("kappa_name")),
31  _dkappadvar(this->template getGenericMaterialProperty<Real, is_ad>(
32  this->derivativePropertyNameFirst(_kappa_name, _var.name()))),
33  _v_num(this->coupledComponents("v")),
34  _grad_v(_v_num)
35 {
36  for (unsigned int i = 0; i < _v_num; ++i)
37  _grad_v[i] = &this->template coupledGenericGradient<is_ad>("v", i);
38 }
39 
41  : ACKappaFunctionTempl<false>(parameters),
42  _dLdvar(getMaterialPropertyDerivative<Real>("mob_name", _var.name())),
43  _d2kappadvar2(getMaterialPropertyDerivative<Real>(_kappa_name, _var.name(), _var.name())),
44  _v_map(getParameterJvarMap("v")),
45  _dLdv(_v_num),
46  _d2kappadvardv(_v_num)
47 {
48  for (unsigned int i = 0; i < _v_num; ++i)
49  {
50  auto v_name = coupledName("v", i);
51  _dLdv[i] = &getMaterialPropertyDerivative<Real>("mob_name", v_name);
52  _d2kappadvardv[i] = &getMaterialPropertyDerivative<Real>(_kappa_name, _var.name(), v_name);
53  }
54 }
55 
56 template <bool is_ad>
59 {
60  return 0.5 * _test[_i][_qp] * _L[_qp] * _dkappadvar[_qp] * computeFg();
61 }
62 
63 Real
65 {
66  Real pre_jac = 0.5 * _test[_i][_qp] * _phi[_j][_qp] * computeFg();
67  Real term1 = _test[_i][_qp] * _L[_qp] * _dkappadvar[_qp] * _grad_u[_qp] * _grad_phi[_j][_qp];
68 
69  return pre_jac * (_dLdvar[_qp] * _dkappadvar[_qp] + _L[_qp] * _d2kappadvar2[_qp]) + term1;
70 }
71 
72 Real
74 {
75  auto i = mapJvarToCvar(jvar, _v_map);
76  if (i >= 0)
77  {
78  const Real pre_jac = 0.5 * _test[_i][_qp] * _phi[_j][_qp] * computeFg();
79  const Real term1 =
80  _test[_i][_qp] * _L[_qp] * _dkappadvar[_qp] * (*_grad_v[i])[_qp] * _grad_phi[_j][_qp];
81  return pre_jac * ((*_dLdv[i])[_qp] * _dkappadvar[_qp] + _L[_qp] * (*_d2kappadvardv[i])[_qp]) +
82  term1;
83  }
84 
85  return 0.0;
86 }
87 
88 template <bool is_ad>
91 {
92  GenericReal<is_ad> sum_grad_etai2 = 0.0;
93  for (unsigned int i = 0; i < _v_num; ++i)
94  sum_grad_etai2 += (*_grad_v[i])[_qp] * (*_grad_v[i])[_qp];
95 
96  return sum_grad_etai2 + _grad_u[_qp] * _grad_u[_qp];
97 }
virtual Real computeQpJacobian() override
void addParam(const std::string &name, const std::initializer_list< typename T::value_type > &value, const std::string &doc_string)
static InputParameters validParams()
ACKappaFunction(const InputParameters &parameters)
std::vector< const GenericVariableGradient< is_ad > * > _grad_v
virtual GenericReal< is_ad > computeQpResidual() override
const MaterialProperty< Real > & _dLdvar
virtual Real computeQpOffDiagJacobian(unsigned int jvar) override
registerMooseObject("PhaseFieldApp", ACKappaFunction)
std::vector< const MaterialProperty< Real > * > _dLdv
When kappa is a function of phase field variables, this kernel should be used to calculate the term w...
const std::string name
Definition: Setup.h:20
GenericReal< is_ad > computeFg()
void addCoupledVar(const std::string &name, const std::string &doc_string)
ACKappaFunctionTempl(const InputParameters &parameters)
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
const GenericMaterialProperty< Real, is_ad > & _L
std::vector< const MaterialProperty< Real > * > _d2kappadvardv
void addClassDescription(const std::string &doc_string)
const MaterialProperty< Real > & _d2kappadvar2
typename Moose::GenericType< Real, is_ad > GenericReal
const MaterialPropertyName _kappa_name
const unsigned int _v_num
const GenericMaterialProperty< Real, is_ad > & _dkappadvar
static InputParameters validParams()