- coupled_groupsList multiple space separated groups of comma separated variables. Off-diagonal jacobians will be generated for all pairs within a group.C++ Type:std::vector<NonlinearVariableName> Unit:(no unit assumed) Controllable:No Description:List multiple space separated groups of comma separated variables. Off-diagonal jacobians will be generated for all pairs within a group. 
- fullFalseSet to true if you want the full set of couplings between variables simply for convenience so you don't have to set every off_diag_row and off_diag_column combination.Default:False C++ Type:bool Controllable:No Description:Set to true if you want the full set of couplings between variables simply for convenience so you don't have to set every off_diag_row and off_diag_column combination. 
- ksp_normunpreconditionedSets the norm that is used for convergence testingDefault:unpreconditioned C++ Type:MooseEnum Controllable:No Description:Sets the norm that is used for convergence testing 
- nl_sysThe nonlinear system whose linearization this preconditioner should be applied to.C++ Type:NonlinearSystemName Controllable:No Description:The nonlinear system whose linearization this preconditioner should be applied to. 
- off_diag_columnThe variable names for the off-diagonal columns you want to add into the matrix; they will be associated with an off-diagonal row from the same position in off_diag_row.C++ Type:std::vector<NonlinearVariableName> Unit:(no unit assumed) Controllable:No Description:The variable names for the off-diagonal columns you want to add into the matrix; they will be associated with an off-diagonal row from the same position in off_diag_row. 
- off_diag_rowThe variable names for the off-diagonal rows you want to add into the matrix; they will be associated with an off-diagonal column from the same position in off_diag_column.C++ Type:std::vector<NonlinearVariableName> Unit:(no unit assumed) Controllable:No Description:The variable names for the off-diagonal rows you want to add into the matrix; they will be associated with an off-diagonal column from the same position in off_diag_column. 
- pc_sidedefaultPreconditioning sideDefault:default C++ Type:MooseEnum Controllable:No Description:Preconditioning side 
- trust_my_couplingFalseWhether to trust my coupling even if the framework wants to be paranoid and create a full coupling matrix, which can happen when using global AD indexing for example.Default:False C++ Type:bool Controllable:No Description:Whether to trust my coupling even if the framework wants to be paranoid and create a full coupling matrix, which can happen when using global AD indexing for example. 
SMP
Single matrix preconditioner (SMP) builds a preconditioner using user defined off-diagonal parts of the Jacobian.
Overview
The Single Matrix Preconditioner (SMP) builds one matrix for preconditioning. As an example, consider the system:
Users can then specify which off-diagonal blocks of the matrix to use like
off_diag_row    = 's'
off_diag_column = 'T'
Which would produce a preconditioning matrix like this:
In order for this to work, the computeQpOffDiagJacobian() function must be provided in the kernels that computes the required partial derivatives. To use all off diagonal blocks, you can use the following input file syntax:
full = true
Example Input File Syntax
[Preconditioning<<<{"href": "../../syntax/Preconditioning/index.html"}>>>]
  active<<<{"description": "If specified only the blocks named will be visited and made active"}>>> = 'SMP_jfnk'
  [./SMP_jfnk]
    type = SMP<<<{"description": "Single matrix preconditioner (SMP) builds a preconditioner using user defined off-diagonal parts of the Jacobian.", "href": "SingleMatrixPreconditioner.html"}>>>
    off_diag_row<<<{"description": "The variable names for the off-diagonal rows you want to add into the matrix; they will be associated with an off-diagonal column from the same position in off_diag_column."}>>> = 'forced'
    off_diag_column<<<{"description": "The variable names for the off-diagonal columns you want to add into the matrix; they will be associated with an off-diagonal row from the same position in off_diag_row."}>>> = 'diffused'
    #Preconditioned JFNK (default)
    solve_type<<<{"description": "PJFNK: Preconditioned Jacobian-Free Newton Krylov JFNK: Jacobian-Free Newton Krylov NEWTON: Full Newton Solve FD: Use finite differences to compute Jacobian LINEAR: Solving a linear problem"}>>> = 'PJFNK'
    petsc_options_iname<<<{"description": "Names of PETSc name/value pairs"}>>> = '-pc_type'
    petsc_options_value<<<{"description": "Values of PETSc name/value pairs (must correspond with \"petsc_options_iname\""}>>> = 'lu'
  [../]
  [./SMP_jfnk_full]
    type = SMP<<<{"description": "Single matrix preconditioner (SMP) builds a preconditioner using user defined off-diagonal parts of the Jacobian.", "href": "SingleMatrixPreconditioner.html"}>>>
    full<<<{"description": "Set to true if you want the full set of couplings between variables simply for convenience so you don't have to set every off_diag_row and off_diag_column combination."}>>> = true
    #Preconditioned JFNK (default)
    solve_type<<<{"description": "PJFNK: Preconditioned Jacobian-Free Newton Krylov JFNK: Jacobian-Free Newton Krylov NEWTON: Full Newton Solve FD: Use finite differences to compute Jacobian LINEAR: Solving a linear problem"}>>> = 'PJFNK'
    petsc_options_iname<<<{"description": "Names of PETSc name/value pairs"}>>> = '-pc_type'
    petsc_options_value<<<{"description": "Values of PETSc name/value pairs (must correspond with \"petsc_options_iname\""}>>> = 'lu'
  [../]
  [./SMP_n]
    type = SMP<<<{"description": "Single matrix preconditioner (SMP) builds a preconditioner using user defined off-diagonal parts of the Jacobian.", "href": "SingleMatrixPreconditioner.html"}>>>
    off_diag_row<<<{"description": "The variable names for the off-diagonal rows you want to add into the matrix; they will be associated with an off-diagonal column from the same position in off_diag_column."}>>> = 'forced'
    off_diag_column<<<{"description": "The variable names for the off-diagonal columns you want to add into the matrix; they will be associated with an off-diagonal row from the same position in off_diag_row."}>>> = 'diffused'
    solve_type<<<{"description": "PJFNK: Preconditioned Jacobian-Free Newton Krylov JFNK: Jacobian-Free Newton Krylov NEWTON: Full Newton Solve FD: Use finite differences to compute Jacobian LINEAR: Solving a linear problem"}>>> = 'NEWTON'
    petsc_options_iname<<<{"description": "Names of PETSc name/value pairs"}>>> = '-pc_type'
    petsc_options_value<<<{"description": "Values of PETSc name/value pairs (must correspond with \"petsc_options_iname\""}>>> = 'lu'
  [../]
[]Input Parameters
- control_tagsAdds user-defined labels for accessing object parameters via control logic.C++ Type:std::vector<std::string> 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 Controllable:No Description:Set the enabled status of the MooseObject. 
Advanced Parameters
- mffd_typewpSpecifies the finite differencing type for Jacobian-free solve types. Note that the default is wp (for Walker and Pernice).Default:wp C++ Type:MooseEnum Controllable:No Description:Specifies the finite differencing type for Jacobian-free solve types. Note that the default is wp (for Walker and Pernice). 
- petsc_optionsSingleton PETSc optionsC++ Type:MultiMooseEnum Controllable:No Description:Singleton PETSc options 
- petsc_options_inameNames of PETSc name/value pairsC++ Type:MultiMooseEnum Controllable:No Description:Names of PETSc name/value pairs 
- petsc_options_valueValues of PETSc name/value pairs (must correspond with "petsc_options_iname"C++ Type:std::vector<std::string> Controllable:No Description:Values of PETSc name/value pairs (must correspond with "petsc_options_iname" 
- solve_typePJFNK: Preconditioned Jacobian-Free Newton Krylov JFNK: Jacobian-Free Newton Krylov NEWTON: Full Newton Solve FD: Use finite differences to compute Jacobian LINEAR: Solving a linear problemC++ Type:MooseEnum Controllable:No Description:PJFNK: Preconditioned Jacobian-Free Newton Krylov JFNK: Jacobian-Free Newton Krylov NEWTON: Full Newton Solve FD: Use finite differences to compute Jacobian LINEAR: Solving a linear problem