- diffusivityThe diffusivity
C++ Type:MaterialPropertyName
Unit:(no unit assumed)
Controllable:No
Description:The diffusivity
- face_uThe concentration of the diffusing specie on faces
C++ Type:NonlinearVariableName
Unit:(no unit assumed)
Controllable:No
Description:The concentration of the diffusing specie on faces
- grad_uThe gradient of the diffusing specie concentration
C++ Type:AuxVariableName
Unit:(no unit assumed)
Controllable:No
Description:The gradient of the diffusing specie concentration
- uThe diffusing specie concentration
C++ Type:AuxVariableName
Unit:(no unit assumed)
Controllable:No
Description:The diffusing specie concentration
- variableThe name of the variable that this residual object operates on
C++ Type:NonlinearVariableName
Unit:(no unit assumed)
Controllable:No
Description:The name of the variable that this residual object operates on
DiffusionHDGKernel
This class implements the same physics as MatDiffusion (see note) but with a hybridized discontinuous Galerkin (HDG) discretization. For more information on HDG for a Poisson problem, please see (Cockburn et al., 2008). The weak forms implemented are a slight variation on the cited work in order to make them directly usable in downstream physics such as Navier-Stokes.
where is the gradient field, are its associated test functions, is the scalar field, are its associated test functions, is the trace of the scalar field (lives on the mesh skeleton), are its associated test functions, is a stabilization parameter, is a forcing function, is the diffusivity coefficient, and represents a prescribed gradient on a Neumann boundary, . As indicated by the test functions, the first equation is the equation for the variable , the second is for the variable , and the third is for the trace or Lagrange multiplier variable .
(the gradient) and (the values) are referred to as the primal variables. $\hat{u} is often referred to as the dual variable. Its equation is the only one that requires the use of a linear solver. For more information on HDG solves, see the HDGKernels page.
the forcing function can be used for method of manufactured solutions studies, or as a source term for the diffused quantity.
Unlike MatDiffusion, the dependence of the diffusion coefficient on nonlinear variables is not captured in the construction of the Jacobian.
Input Parameters
- blockThe list of blocks (ids or names) that this object will be applied
C++ Type:std::vector<SubdomainName>
Unit:(no unit assumed)
Controllable:No
Description:The list of blocks (ids or names) that this object will be applied
- displacementsThe displacements
C++ Type:std::vector<VariableName>
Unit:(no unit assumed)
Controllable:No
Description:The displacements
- prop_getter_suffixAn optional suffix parameter that can be appended to any attempt to retrieve/get material properties. The suffix will be prepended with a '_' character.
C++ Type:MaterialPropertyName
Unit:(no unit assumed)
Controllable:No
Description:An optional suffix parameter that can be appended to any attempt to retrieve/get material properties. The suffix will be prepended with a '_' character.
- source0Source for the diffusing species. A functor is any of the following: a variable, a functor material property, a function, a post-processor, or a number.
Default:0
C++ Type:MooseFunctorName
Unit:(no unit assumed)
Controllable:No
Description:Source for the diffusing species. A functor is any of the following: a variable, a functor material property, a function, a post-processor, or a number.
- tau1The stabilization coefficient required for discontinuous Galerkin schemes. This may be set to 0 for a mixed method with Raviart-Thomas.
Default:1
C++ Type:double
Unit:(no unit assumed)
Controllable:No
Description:The stabilization coefficient required for discontinuous Galerkin schemes. This may be set to 0 for a mixed method with Raviart-Thomas.
- use_interpolated_stateFalseFor the old and older state use projected material properties interpolated at the quadrature points. To set up projection use the ProjectedStatefulMaterialStorageAction.
Default:False
C++ Type:bool
Unit:(no unit assumed)
Controllable:No
Description:For the old and older state use projected material properties interpolated at the quadrature points. To set up projection use the ProjectedStatefulMaterialStorageAction.
Optional Parameters
- absolute_value_vector_tagsThe tags for the vectors this residual object should fill with the absolute value of the residual contribution
C++ Type:std::vector<TagName>
Unit:(no unit assumed)
Controllable:No
Description:The tags for the vectors this residual object should fill with the absolute value of the residual contribution
- extra_matrix_tagsThe extra tags for the matrices this Kernel should fill
C++ Type:std::vector<TagName>
Unit:(no unit assumed)
Controllable:No
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<TagName>
Unit:(no unit assumed)
Controllable:No
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
Unit:(no unit assumed)
Controllable:No
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
Unit:(no unit assumed)
Controllable:No
Description:The tag for the vectors this Kernel should fill
Tagging Parameters
- control_tagsAdds user-defined labels for accessing object parameters via control logic.
C++ Type:std::vector<std::string>
Unit:(no unit assumed)
Controllable:No
Description:Adds user-defined labels for accessing object parameters via control logic.
- enableTrueSet the enabled status of the MooseObject.
Default:True
C++ Type:bool
Unit:(no unit assumed)
Controllable:Yes
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
Unit:(no unit assumed)
Controllable:No
Description:Determines whether this object is calculated using an implicit or explicit form
- seed0The seed for the master random number generator
Default:0
C++ Type:unsigned int
Unit:(no unit assumed)
Controllable:No
Description:The seed for the master random number generator
- 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
Unit:(no unit assumed)
Controllable:No
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
References
- Bernardo Cockburn, Bo Dong, and Johnny Guzmán.
A superconvergent ldg-hybridizable galerkin method for second-order elliptic problems.
Mathematics of Computation, 77(264):1887–1916, 2008.[BibTeX]