www.mooseframework.org
Public Member Functions | Static Public Member Functions | Protected Types | Protected Member Functions | Protected Attributes | Private Attributes | List of all members
CHBulkPFCTrad Class Referenceabstract

#include <CHBulkPFCTrad.h>

Inheritance diagram for CHBulkPFCTrad:
[legend]

Public Member Functions

 CHBulkPFCTrad (const InputParameters &parameters)
 
virtual void initialSetup ()
 

Static Public Member Functions

static InputParameters validParams ()
 

Protected Types

enum  PFFunctionType
 

Protected Member Functions

virtual RealGradient computeGradDFDCons (PFFunctionType type)
 
virtual RealGradient precomputeQpResidual ()
 
virtual RealGradient precomputeQpJacobian ()
 
virtual Real computeQpOffDiagJacobian (unsigned int jvar)
 
virtual RealGradient computeGradDFDCons (PFFunctionType type)=0
 

Protected Attributes

const MaterialProperty< Real > & _M
 Mobility. More...
 
const MaterialProperty< Real > & _dMdc
 Mobility derivative w.r.t. concentration. More...
 
std::vector< const MaterialProperty< Real > * > _dMdarg
 Mobility derivative w.r.t coupled variables. More...
 

Private Attributes

const MaterialProperty< Real > & _C0
 
const MaterialProperty< Real > & _a
 
const MaterialProperty< Real > & _b
 

Detailed Description

Definition at line 20 of file CHBulkPFCTrad.h.

Member Enumeration Documentation

◆ PFFunctionType

enum CHBulk::PFFunctionType
protectedinherited

Definition at line 38 of file CHBulk.h.

39  {
40  Jacobian,
41  Residual
42  };

Constructor & Destructor Documentation

◆ CHBulkPFCTrad()

CHBulkPFCTrad::CHBulkPFCTrad ( const InputParameters &  parameters)

Definition at line 24 of file CHBulkPFCTrad.C.

25  : CHBulk<Real>(parameters),
26  _C0(getMaterialProperty<Real>("C0")),
27  _a(getMaterialProperty<Real>("a")),
28  _b(getMaterialProperty<Real>("b"))
29 {
30 }

Member Function Documentation

◆ computeGradDFDCons() [1/2]

RealGradient CHBulkPFCTrad::computeGradDFDCons ( PFFunctionType  type)
protectedvirtual

Definition at line 33 of file CHBulkPFCTrad.C.

34 {
35  Real d2fdc2 = 1.0 - _C0[_qp] - _a[_qp] * _u[_qp] + _b[_qp] * _u[_qp] * _u[_qp];
36 
37  switch (type)
38  {
39  case Residual:
40  return d2fdc2 * _grad_u[_qp];
41 
42  case Jacobian:
43  {
44  Real d3fdc3 = -_a[_qp] + 2.0 * _b[_qp] * _u[_qp];
45  return d2fdc2 * _grad_phi[_j][_qp] + d3fdc3 * _grad_u[_qp] * _phi[_j][_qp];
46  }
47  }
48 
49  mooseError("Invalid type passed in");
50 }

◆ computeGradDFDCons() [2/2]

virtual RealGradient CHBulk< Real >::computeGradDFDCons ( PFFunctionType  type)
protectedpure virtualinherited

Implemented in CahnHilliardBase< Real >.

◆ computeQpOffDiagJacobian()

Real CHBulk< Real >::computeQpOffDiagJacobian ( unsigned int  jvar)
protectedvirtualinherited

Reimplemented in KKSCHBulk, and CahnHilliardBase< Real >.

Definition at line 110 of file CHBulk.h.

111 {
112  // get the coupled variable jvar is referring to
113  const unsigned int cvar = mapJvarToCvar(jvar);
114 
115  return (*_dMdarg[cvar])[_qp] * _phi[_j][_qp] * computeGradDFDCons(Residual) * _grad_test[_i][_qp];
116 }

◆ initialSetup()

void CHBulk< Real >::initialSetup ( )
virtualinherited

Reimplemented in CahnHilliardBase< Real >.

Definition at line 86 of file CHBulk.h.

87 {
88  validateNonlinearCoupling<Real>("mob_name");
89 }

◆ precomputeQpJacobian()

RealGradient CHBulk< Real >::precomputeQpJacobian ( )
protectedvirtualinherited

Definition at line 100 of file CHBulk.h.

101 {
102  RealGradient grad_value = _M[_qp] * computeGradDFDCons(Jacobian) +
103  _dMdc[_qp] * _phi[_j][_qp] * computeGradDFDCons(Residual);
104 
105  return grad_value;
106 }

◆ precomputeQpResidual()

RealGradient CHBulk< Real >::precomputeQpResidual ( )
protectedvirtualinherited

Definition at line 93 of file CHBulk.h.

94 {
95  return _M[_qp] * computeGradDFDCons(Residual);
96 }

◆ validParams()

InputParameters CHBulk< Real >::validParams ( )
staticinherited

Definition at line 75 of file CHBulk.h.

76 {
77  InputParameters params = ::validParams<KernelGrad>();
78  params.addClassDescription("Cahn-Hilliard base Kernel");
79  params.addParam<MaterialPropertyName>("mob_name", "M", "The mobility used with the kernel");
80  params.addCoupledVar("args", "Vector of arguments of the mobility");
81  return params;
82 }

Member Data Documentation

◆ _a

const MaterialProperty<Real>& CHBulkPFCTrad::_a
private

Definition at line 30 of file CHBulkPFCTrad.h.

Referenced by computeGradDFDCons().

◆ _b

const MaterialProperty<Real>& CHBulkPFCTrad::_b
private

Definition at line 31 of file CHBulkPFCTrad.h.

Referenced by computeGradDFDCons().

◆ _C0

const MaterialProperty<Real>& CHBulkPFCTrad::_C0
private

Definition at line 29 of file CHBulkPFCTrad.h.

Referenced by computeGradDFDCons().

◆ _dMdarg

std::vector<const MaterialProperty<Real > *> CHBulk< Real >::_dMdarg
protectedinherited

Mobility derivative w.r.t coupled variables.

Definition at line 53 of file CHBulk.h.

◆ _dMdc

const MaterialProperty<Real >& CHBulk< Real >::_dMdc
protectedinherited

Mobility derivative w.r.t. concentration.

Definition at line 50 of file CHBulk.h.

◆ _M

const MaterialProperty<Real >& CHBulk< Real >::_M
protectedinherited

Mobility.

Definition at line 47 of file CHBulk.h.


The documentation for this class was generated from the following files:
CHBulk< Real >::computeGradDFDCons
virtual RealGradient computeGradDFDCons(PFFunctionType type)=0
libMesh::RealGradient
VectorValue< Real > RealGradient
Definition: GrainForceAndTorqueInterface.h:17
CHBulk< Real >::Jacobian
Definition: CHBulk.h:40
CHBulk< Real >::_dMdarg
std::vector< const MaterialProperty< Real > * > _dMdarg
Mobility derivative w.r.t coupled variables.
Definition: CHBulk.h:53
CHBulk< Real >::Residual
Definition: CHBulk.h:41
CHBulk< Real >::_dMdc
const MaterialProperty< Real > & _dMdc
Mobility derivative w.r.t. concentration.
Definition: CHBulk.h:50
CHBulkPFCTrad::_C0
const MaterialProperty< Real > & _C0
Definition: CHBulkPFCTrad.h:29
CHBulk< Real >::_M
const MaterialProperty< Real > & _M
Mobility.
Definition: CHBulk.h:47
CHBulkPFCTrad::_b
const MaterialProperty< Real > & _b
Definition: CHBulkPFCTrad.h:31
CHBulkPFCTrad::_a
const MaterialProperty< Real > & _a
Definition: CHBulkPFCTrad.h:30
CHBulk< Real >