https://mooseframework.inl.gov
LowerBoundNodalKernel.h
Go to the documentation of this file.
1 //* This file is part of the MOOSE framework
2 //* https://mooseframework.inl.gov
3 //*
4 //* All rights reserved, see COPYRIGHT for full restrictions
5 //* https://github.com/idaholab/moose/blob/master/COPYRIGHT
6 //*
7 //* Licensed under LGPL 2.1, please see LICENSE for details
8 //* https://www.gnu.org/licenses/lgpl-2.1.html
9 
10 #pragma once
11 
12 #include "NodalKernel.h"
13 
18 {
19 public:
21 
23 
24 protected:
25  virtual Real computeQpResidual() override;
26  virtual Real computeQpJacobian() override;
27  virtual Real computeQpOffDiagJacobian(unsigned int jvar) override;
28 
29 private:
31  const unsigned int _v_var;
32 
34  const VariableValue & _v;
35 
37  std::set<BoundaryID> _bnd_ids;
38 
41 };
const unsigned int _v_var
The number of the coupled variable.
const VariableValue & _v
The value of the coupled variable.
virtual Real computeQpResidual() override
The user can override this function to compute the residual at a node.
The main MOOSE class responsible for handling user-defined parameters in almost every MOOSE system...
virtual Real computeQpJacobian() override
The user can override this function to compute the "on-diagonal" Jacobian contribution.
const Real _lower_bound
The lower bound on the coupled variable.
static InputParameters validParams()
std::set< BoundaryID > _bnd_ids
Boundaries on which we should not execute this object.
forward declarations
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
Class used to enforce a lower bound on a coupled variable.
const InputParameters & parameters() const
Get the parameters of the object.
Base class for creating nodal kernels with hand-coded Jacobians.
Definition: NodalKernel.h:17
LowerBoundNodalKernel(const InputParameters &parameters)
virtual Real computeQpOffDiagJacobian(unsigned int jvar) override
This is the virtual that derived classes should override for computing an off-diagonal jacobian compo...