Kernels System
A "Kernel" is a piece of physics. It can represent one or more operators or terms in the weak form of a partial differential equation.  With all terms on the left-hand-side, their sum is referred to as the "residual". The residual is evaluated at several integration quadrature points over the problem domain. To implement your own physics in MOOSE, you create your own kernel by subclassing the MOOSE Kernel class.
The Kernel system supports the use of automatic differentiation (AD) for residual calculations, as such there are two options for creating Kernel objects: Kernel and ADKernel. To further understand automatic differentiation, please refer to the Automatic Differentiation page for more information.
In a Kernel subclass the computeQpResidual() function must be overridden.  This is where you implement your PDE weak form terms.  For non-AD objects the following member functions can optionally be overridden:
- computeQpJacobian()
- computeQpOffDiagJacobian()
These two functions provide extra information that can help the numerical solver(s) converge faster and better.
Inside your Kernel class, you have access to several member variables for computing the residual and Jacobian values in the above mentioned functions:
- _i,- _j: indices for the current test and trial shape functions respectively.
- _qp: current quadrature point index.
- _u,- _grad_u: value and gradient of the variable this Kernel operates on; indexed by- _qp(i.e.- _u[_qp]).
- _test,- _grad_test: value () and gradient () of the test functions at the q-points; indexed by- _iand then- _qp(i.e.,- _test[_i][_qp]).
- _phi,- _grad_phi: value () and gradient () of the trial functions at the q-points; indexed by- _jand then- _qp(i.e.,- _phi[_j][_qp]).
- _q_point: XYZ coordinates of the current quadrature point.
- _current_elem: pointer to the current element being operated on.
Optimized Kernel Objects
Depending on the residual calculation being performed it is sometimes possible to optimize the calculation of the residual by precomputing values during the finite element assembly of the residual vector. The following table details the various Kernel base classes that can be used for as base classes to improve performance.
| Base | Override | Use | 
|---|---|---|
| Kernel ADKernel | computeQpResidual | Use when the term in the partial differential equation (PDE) is multiplied by both the test function and the gradient of the test function ( _testand_grad_testmust be applied) | 
| KernelValue ADKernelValue | precomputeQpResidual | Use when the term computed in the PDE is only multiplied by the test function (do not use _testin the override, it is applied automatically) | 
| KernelGrad ADKernelGrad | precomputeQpResidual | Use when the term computed in the PDE is only multiplied by the gradient of the test function (do not use _grad_testin the override, it is applied automatically) | 
Custom Kernel Creation
To create a custom kernel, you can follow the pattern of the Diffusion or ADDiffusion objects implemented and included in the MOOSE framework. Additionally, Example 2 in MOOSE provides a step-by-step overview of creating your own custom kernel. The following describes that calculation of the diffusion term of a PDE.
The strong-form of the diffusion equation is defined on a 3-D domain as: find such that
(1)where is defined as the boundary on which the value of is fixed to a known constant , is defined as the boundary on which the flux across the boundary is fixed to a known constant , and is the boundary outward normal.
The weak form is generated by multiplying by a test function () and integrating over the domain (using inner-product notation):
and then integrating by parts which gives the weak form:
(2)where is known as the trial function that defines the finite element discretization, , with being the basis functions.
The Jacobian, which is the derivative of Eq. (2) with respect to , is defined as:
(3)As mentioned, the computeQpResidual method must be overridden for both flavors of kernels non-AD and AD. The computeQpResidual method for the non-AD version, Diffusion, is provided in Listing 1.
Listing 1: The C++ weak-form residual statement of Eq. (2) as implemented in the Diffusion kernel.
Real
Diffusion::computeQpResidual()
{
  return _grad_u[_qp] * _grad_test[_i][_qp];
}
This object also overrides the computeQpJacobian method to define Jacobian term of (doc/jacobian) as shown in Listing 2.
Listing 2: The C++ weak-form Jacobian statement of (doc/jacobian) as implemented in the Diffusion kernel.
Real
Diffusion::computeQpJacobian()
{
  return _grad_phi[_j][_qp] * _grad_test[_i][_qp];
}
The AD version of this object, ADDiffusion, relies on an optimized kernel object (see Optimized Kernel Objects), as such it overrides precomputeQpResidual as follows.
Listing 3: The C++ pre-computed portions of the weak-form residual statement of Eq. (2) as implemented in the ADDiffusion kernel.
ADDiffusion::precomputeQpResidual()
{
  return _grad_u[_qp];
}
Time Derivative Kernels
You can create a time-derivative term/kernel by subclassing TimeKernel instead of Kernel.  For example, the residual contribution for a time derivative term is:
where is the finite element solution, and
(4)because you can interchange the order of differentiation and summation.
In the equation above, is the time derivative of the th finite element coefficient of . While the exact form of this derivative depends on the time stepping scheme, without much loss of generality, we can assume the following form for the time derivative:
for some constants , which depend on and the timestepping method.
The derivative of equation Eq. (4) with respect to is then:
So that the Jacobian term for equation Eq. (4) is
where  is what we call du_dot_du in MOOSE.
Therefore the computeQpResidual() function for our time-derivative term kernel looks like:
return _test[_i][_qp] * _u_dot[_qp];
And the corresponding computeQpJacobian() is:
return _test[_i][_qp] * _phi[_j][_qp] * _du_dot_du[_qp];
Further Kernel Documentation
Several specialized kernel types exist in MOOSE each with useful functionality. Details for each are in the sections below.
Available Objects
- Moose App
- ADBodyForceDemonstrates the multiple ways that scalar values can be introduced into kernels, e.g. (controllable) constants, functions, and postprocessors. Implements the weak form .
- ADCoupledTimeDerivativeTime derivative Kernel that acts on a coupled variable. Weak form: .
- ADDiffusionSame as Diffusionin terms of physics/residual, but the Jacobian is computed using forward automatic differentiation
- ADMatDiffusionDiffusion equation kernel that takes an isotropic diffusivity from a material property
- ADMaterialPropertyValueResidual term (u - prop) to set variable u equal to a given material property prop
- ADTimeDerivativeThe time derivative operator with the weak form of .
- ADVectorDiffusionThe Laplacian operator (), with the weak form of . The Jacobian is computed using automatic differentiation
- ADVectorTimeDerivativeThe time derivative operator with the weak form of .
- AnisotropicDiffusionAnisotropic diffusion kernel with weak form given by .
- ArrayBodyForceApplies body forces specified with functions to an array variable.
- ArrayDiffusionThe array Laplacian operator (), with the weak form of .
- ArrayReactionThe array reaction operator with the weak form of .
- ArrayTimeDerivativeArray time derivative operator with the weak form of .
- BodyForceDemonstrates the multiple ways that scalar values can be introduced into kernels, e.g. (controllable) constants, functions, and postprocessors. Implements the weak form .
- CoefReactionImplements the residual term (p*u, test)
- CoefTimeDerivativeThe time derivative operator with the weak form of .
- ConservativeAdvectionConservative form of which in its weak form is given by: .
- CoupledForceImplements a source term proportional to the value of a coupled variable. Weak form: .
- CoupledTimeDerivativeTime derivative Kernel that acts on a coupled variable. Weak form: .
- DiffusionThe Laplacian operator (), with the weak form of .
- MassEigenKernelAn eigenkernel with weak form where is the eigenvalue.
- MassLumpedTimeDerivativeLumped formulation of the time derivative . Its corresponding weak form is where denotes the time derivative of the solution coefficient associated with node .
- MatCoupledForceImplements a forcing term RHS of the form PDE = RHS, where RHS = Sum_j c_j * m_j * v_j. c_j, m_j, and v_j are provided as real coefficients, material properties, and coupled variables, respectively.
- MatDiffusionDiffusion equation Kernel that takes an isotropic Diffusivity from a material property
- MatReactionKernel to add -L*v, where L=reaction rate, v=variable
- MaterialDerivativeRankFourTestKernelClass used for testing derivatives of a rank four tensor material property.
- MaterialDerivativeRankTwoTestKernelClass used for testing derivatives of a rank two tensor material property.
- MaterialDerivativeTestKernelClass used for testing derivatives of a scalar material property.
- MaterialPropertyValueResidual term (u - prop) to set variable u equal to a given material property prop
- NullKernelKernel that sets a zero residual.
- ReactionImplements a simple consuming reaction term with weak form .
- ScalarLagrangeMultiplierThis class is used to enforce integral of phi = V_0 with a Lagrange multiplier approach.
- TimeDerivativeThe time derivative operator with the weak form of .
- UserForcingFunctionDemonstrates the multiple ways that scalar values can be introduced into kernels, e.g. (controllable) constants, functions, and postprocessors. Implements the weak form .
- VectorBodyForceDemonstrates the multiple ways that scalar values can be introduced into kernels, e.g. (controllable) constants, functions, and postprocessors. Implements the weak form .
- VectorCoupledTimeDerivativeTime derivative Kernel that acts on a coupled vector variable. Weak form: .
- VectorDiffusionThe Laplacian operator (), with the weak form of .
- VectorTimeDerivativeThe time derivative operator with the weak form of .
- Tensor Mechanics App
- ADDynamicStressDivergenceTensorsResidual due to stress related Rayleigh damping and HHT time integration terms
- ADGravityApply gravity. Value is in units of acceleration.
- ADInertialForceShellCalculates the residual for the inertial force/moment and the contribution of mass dependent Rayleigh damping and HHT time integration scheme.
- ADStressDivergenceRSphericalTensorsCalculate stress divergence for a spherically symmetric 1D problem in polar coordinates.
- ADStressDivergenceRZTensorsCalculate stress divergence for an axisymmetric problem in cylindrical coordinates.
- ADStressDivergenceShellQuasi-static stress divergence kernel for Shell element
- ADStressDivergenceTensorsStress divergence kernel with automatic differentiation for the Cartesian coordinate system
- ADWeakPlaneStressPlane stress kernel to provide out-of-plane strain contribution.
- AsymptoticExpansionHomogenizationKernelKernel for asymptotic expansion homogenization for elasticity
- CosseratStressDivergenceTensorsStress divergence kernel for the Cartesian coordinate system
- DynamicStressDivergenceTensorsResidual due to stress related Rayleigh damping and HHT time integration terms
- GeneralizedPlaneStrainOffDiagGeneralized Plane Strain kernel to provide contribution of the out-of-plane strain to other kernels
- GravityApply gravity. Value is in units of acceleration.
- InertialForceCalculates the residual for the inertial force () and the contribution of mass dependent Rayleigh damping and HHT time integration scheme ($\eta \cdot M \cdot ((1+\alpha)velq2-\alpha \cdot vel-old) $)
- InertialForceBeamCalculates the residual for the inertial force/moment and the contribution of mass dependent Rayleigh damping and HHT time integration scheme.
- InertialTorqueKernel for inertial torque: density * displacement x acceleration
- MomentBalancing
- OutOfPlanePressureApply pressure in the out-of-plane direction in 2D plane stress or generalized plane strain models
- PhaseFieldFractureMechanicsOffDiagStress divergence kernel for phase-field fracture: Computes off diagonal damage dependent Jacobian components. To be used with StressDivergenceTensors or DynamicStressDivergenceTensors.
- PlasticHeatEnergyPlastic heat energy density = coeff * stress * plastic_strain_rate
- PoroMechanicsCouplingAdds , where the subscript is the component.
- StressDivergenceBeamQuasi-static and dynamic stress divergence kernel for Beam element
- StressDivergenceRSphericalTensorsCalculate stress divergence for a spherically symmetric 1D problem in polar coordinates.
- StressDivergenceRZTensorsCalculate stress divergence for an axisymmetric problem in cylindrical coordinates.
- StressDivergenceTensorsStress divergence kernel for the Cartesian coordinate system
- StressDivergenceTensorsTrussKernel for truss element
- WeakPlaneStressPlane stress kernel to provide out-of-plane strain contribution.
- XFEMApp
- CrackTipEnrichmentStressDivergenceTensorsEnrich stress divergence kernel for small-strain simulations
- Misc App
- ADThermoDiffusionCalculates diffusion due to temperature gradient and Soret Coefficient
- CoefDiffusionKernel for diffusion with diffusivity = coef + function
- ThermoDiffusionKernel for thermo-diffusion (Soret effect, thermophoresis, etc.)
- Black Bear App
- ConcreteLatentHeatLatent heat term for heat transfer in concrete.
- ConcreteMoistureDehydrationSource term for dehydrated water for moisture transfer in concrete.
- ConcreteMoistureDiffusionFickian and Soret diffusion terms for moisture transfer in concrete.
- ConcreteMoistureTimeIntegrationTime derivative term for moisture transport in concrete.
- ConcreteThermalConductionConduction term for thermal transport in concrete.
- ConcreteThermalConvectionConvective transport term for heat transfer due to fluid flow in concrete.
- ConcreteThermalTimeIntegrationTime derivative term for heat transfer in concrete.
- Heat Conduction App
- ADHeatConductionSame as Diffusionin terms of physics/residual, but the Jacobian is computed using forward automatic differentiation
- ADHeatConductionTimeDerivativeAD Time derivative term of the heat equation for quasi-constant specific heat and the density .
- ADJouleHeatingSourceCalculates the heat source term corresponding to electrostatic Joule heating, with Jacobian contributions calculated using the automatic differentiation system.
- ADMatHeatSourceForce term in thermal transport to represent a heat source
- AnisoHeatConduction
- HeatCapacityConductionTimeDerivativeTime derivative term of the heat equation with the heat capacity as an argument.
- HeatConductionComputes residual/Jacobian contribution for term.
- HeatConductionTimeDerivativeTime derivative term of the heat equation for quasi-constant specific heat and the density .
- HeatSourceDemonstrates the multiple ways that scalar values can be introduced into kernels, e.g. (controllable) constants, functions, and postprocessors. Implements the weak form .
- HomogenizedHeatConductionKernel for asymptotic expansion homogenization for thermal conductivity
- JouleHeatingSourceCalculates the heat source term corresponding to electrostatic Joule heating.
- SpecificHeatConductionTimeDerivativeTime derivative term of the heat equation with the specific heat and the density as arguments.