https://mooseframework.inl.gov
SplitCHParsed.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 
10 #include "SplitCHParsed.h"
11 
12 registerMooseObject("PhaseFieldApp", SplitCHParsed);
13 
16 {
18  params.addClassDescription(
19  "Split formulation Cahn-Hilliard Kernel that uses a DerivativeMaterial Free Energy");
20  params.addRequiredParam<MaterialPropertyName>(
21  "f_name", "Base name of the free energy function F defined in a DerivativeParsedMaterial");
22  params.addCoupledVar("args", "Vector of additional variable arguments to F");
23  params.deprecateCoupledVar("args", "coupled_variables", "02/27/2024");
24 
25  return params;
26 }
27 
30  _dFdc(getMaterialPropertyDerivative<Real>("f_name", _var.name())),
31  _d2Fdc2(getMaterialPropertyDerivative<Real>("f_name", _var.name(), _var.name())),
32  _d2Fdcdarg(_n_args)
33 {
34  // Iterate over all coupled variables
35  for (unsigned int i = 0; i < _n_args; ++i)
36  _d2Fdcdarg[i] = &getMaterialPropertyDerivative<Real>("f_name", _var.name(), i);
37 }
38 
39 void
41 {
47  validateNonlinearCoupling<Real>("f_name", _var.name());
48  validateDerivativeMaterialPropertyBase<Real>("f_name");
49 }
50 
51 Real
52 SplitCHParsed::computeDFDC(PFFunctionType type)
53 {
54  switch (type)
55  {
56  case Residual:
57  return _dFdc[_qp];
58 
59  case Jacobian:
60  return _d2Fdc2[_qp] * _phi[_j][_qp];
61  }
62 
63  mooseError("Internal error");
64 }
65 
66 Real
68 {
69  if (jvar == _w_var)
71 
72  // get the coupled variable jvar is referring to
73  const unsigned int cvar = mapJvarToCvar(jvar);
74 
75  return (*_d2Fdcdarg[cvar])[_qp] * _phi[_j][_qp] * _test[_i][_qp];
76 }
registerMooseObject("PhaseFieldApp", SplitCHParsed)
void mooseError(Args &&... args)
const MaterialProperty< Real > & _d2Fdc2
Definition: SplitCHParsed.h:39
virtual void initialSetup()
Definition: SplitCHParsed.C:40
virtual Real computeQpOffDiagJacobian(unsigned int jvar)
Definition: SplitCHParsed.C:67
static InputParameters validParams()
Definition: SplitCHCRes.C:13
void addRequiredParam(const std::string &name, const std::string &doc_string)
const MaterialProperty< Real > & _dFdc
Definition: SplitCHParsed.h:38
const std::string name
Definition: Setup.h:20
std::vector< const MaterialProperty< Real > * > _d2Fdcdarg
Definition: SplitCHParsed.h:40
void deprecateCoupledVar(const std::string &old_name, const std::string &new_name, const std::string &removal_date)
void addCoupledVar(const std::string &name, const std::string &doc_string)
virtual Real computeQpOffDiagJacobian(unsigned int jvar)
Definition: SplitCHCRes.C:70
CHParsed uses the Free Energy function and derivatives provided by a DerivativeParsedMaterial.
Definition: SplitCHParsed.h:24
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
virtual Real computeDFDC(PFFunctionType type)
Definition: SplitCHParsed.C:52
void addClassDescription(const std::string &doc_string)
SplitCHParsed(const InputParameters &parameters)
Definition: SplitCHParsed.C:28
The couple, SplitCHCRes and SplitCHWRes, splits the CH equation by replacing chemical potential with ...
Definition: SplitCHCRes.h:17
static InputParameters validParams()
Definition: SplitCHParsed.C:15