- neighbor_varThe variable on the other side of the interface.
C++ Type:std::vector
Description:The variable on the other side of the interface.
- variableThe name of the variable that this boundary condition applies to
C++ Type:NonlinearVariableName
Description:The name of the variable that this boundary condition applies to
InterfaceDiffusionBoundaryTerm

The InterfaceDiffusionBoundaryTerm has not been documented. The content listed below should be used as a starting point for documenting the class, which includes the typical automatic documentation associated with a MooseObject; however, what is contained is ultimately determined by what is necessary to make the documentation clear for users.
# InterfaceDiffusionBoundaryTerm
!syntax description /InterfaceKernels/InterfaceDiffusionBoundaryTerm
## Overview
!! Replace these lines with information regarding the InterfaceDiffusionBoundaryTerm object.
## Example Input File Syntax
!! Describe and include an example of how to use the InterfaceDiffusionBoundaryTerm object.
!syntax parameters /InterfaceKernels/InterfaceDiffusionBoundaryTerm
!syntax inputs /InterfaceKernels/InterfaceDiffusionBoundaryTerm
!syntax children /InterfaceKernels/InterfaceDiffusionBoundaryTerm
Add weak form surface terms of the Diffusion equation for two different variables across a subdomain boundary
Input Parameters
- D1Diffusion coefficient
Default:1
C++ Type:double
Description:Diffusion coefficient
- D_neighbor1Neighbor variable diffusion coefficient
Default:1
C++ Type:double
Description:Neighbor variable diffusion coefficient
- boundaryThe list of boundary IDs from the mesh where this boundary condition applies
C++ Type:std::vector
Description:The list of boundary IDs from the mesh where this boundary condition applies
- diag_save_inThe name of auxiliary variables to save this Kernel's diagonal Jacobian contributions to. Everything about that variable must match everything about this variable (the type, what blocks it's on, etc.)
C++ Type:std::vector
Description:The name of auxiliary variables to save this Kernel's diagonal Jacobian contributions to. Everything about that variable must match everything about this variable (the type, what blocks it's on, etc.)
- diag_save_in_var_sideThis parameter must exist if diag_save_in variables are specified and must have the same length as diag_save_in. This vector specifies whether the corresponding aux_var should save-in jacobian contributions from the master ('m') or slave side ('s').
C++ Type:MultiMooseEnum
Description:This parameter must exist if diag_save_in variables are specified and must have the same length as diag_save_in. This vector specifies whether the corresponding aux_var should save-in jacobian contributions from the master ('m') or slave side ('s').
- save_inThe name of auxiliary variables to save this Kernel's residual contributions to. Everything about that variable must match everything about this variable (the type, what blocks it's on, etc.)
C++ Type:std::vector
Description:The name of auxiliary variables to save this Kernel's residual contributions to. Everything about that variable must match everything about this variable (the type, what blocks it's on, etc.)
- save_in_var_sideThis parameter must exist if save_in variables are specified and must have the same length as save_in. This vector specifies whether the corresponding aux_var should save-in residual contributions from the master ('m') or slave side ('s').
C++ Type:MultiMooseEnum
Description:This parameter must exist if save_in variables are specified and must have the same length as save_in. This vector specifies whether the corresponding aux_var should save-in residual contributions from the master ('m') or slave side ('s').
Optional Parameters
- control_tagsAdds user-defined labels for accessing object parameters via control logic.
C++ Type:std::vector
Description:Adds user-defined labels for accessing object parameters via control logic.
- enableTrueSet the enabled status of the MooseObject.
Default:True
C++ Type:bool
Description:Set the enabled status of the MooseObject.
- implicitTrueDetermines whether this object is calculated using an implicit or explicit form
Default:True
C++ Type:bool
Description:Determines whether this object is calculated using an implicit or explicit form
- use_displaced_meshFalseWhether or not this object should use the displaced mesh for computation. Note that in the case this is true but no displacements are provided in the Mesh block the undisplaced mesh will still be used.
Default:False
C++ Type:bool
Description:Whether or not this object should use the displaced mesh for computation. Note that in the case this is true but no displacements are provided in the Mesh block the undisplaced mesh will still be used.
Advanced Parameters
- extra_matrix_tagsThe extra tags for the matrices this Kernel should fill
C++ Type:std::vector
Description:The extra tags for the matrices this Kernel should fill
- extra_vector_tagsThe extra tags for the vectors this Kernel should fill
C++ Type:std::vector
Description:The extra tags for the vectors this Kernel should fill
- matrix_tagssystemThe tag for the matrices this Kernel should fill
Default:system
C++ Type:MultiMooseEnum
Description:The tag for the matrices this Kernel should fill
- vector_tagsnontimeThe tag for the vectors this Kernel should fill
Default:nontime
C++ Type:MultiMooseEnum
Description:The tag for the vectors this Kernel should fill
Tagging Parameters
Input Files
- modules/phase_field/examples/interfacekernels/interface_gradient.i
- modules/phase_field/examples/interfacekernels/interface_fluxbc.i
- modules/phase_field/test/tests/misc/interface_flux.i
- modules/phase_field/test/tests/misc/equal_gradient_lagrange.i