https://mooseframework.inl.gov
GradDiv.C
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 #include "GradDiv.h"
11 
12 registerMooseObject("NavierStokesApp", GradDiv);
13 
16 {
18  params.addRequiredCoupledVar("u", "The x-velocity");
19  params.addRequiredCoupledVar("v", "The y-velocity");
20  params.addRequiredParam<unsigned short>("component",
21  "The velocity component this object is being applied to");
22  params.addParam<Real>("gamma", 1, "The penalty parameter");
23  params.addClassDescription("Adds grad-div stabilization for scalar field velocity component "
24  "Navier-Stokes implementations.");
25  return params;
26 }
27 
28 GradDiv::GradDiv(const InputParameters & parameters)
29  : ADKernel(parameters),
30  _grad_vel_x(adCoupledGradient("u")),
31  _grad_vel_y(adCoupledGradient("v")),
32  _comp(getParam<unsigned short>("component")),
33  _matrix_only(getParam<bool>("matrix_only")),
34  _gamma(getParam<Real>("gamma"))
35 {
36 }
37 
38 void
40 {
41  if (!_matrix_only)
43 }
44 
45 ADReal
47 {
48  return _gamma * (_grad_vel_x[_qp](0) + _grad_vel_y[_qp](1)) * _grad_test[_i][_qp](_comp);
49 }
void computeResidual() override
static InputParameters validParams()
Definition: GradDiv.C:15
const ADTemplateVariableTestGradient< T > & _grad_test
virtual void computeResidual() override
Definition: GradDiv.C:39
GradDiv(const InputParameters &parameters)
Definition: GradDiv.C:28
void addParam(const std::string &name, const std::initializer_list< typename T::value_type > &value, const std::string &doc_string)
registerMooseObject("NavierStokesApp", GradDiv)
This class implements an augmented Lagrange term, whose weak form is given by: where is the stabili...
Definition: GradDiv.h:22
virtual ADReal computeQpResidual() override
Definition: GradDiv.C:46
const unsigned short _comp
Definition: GradDiv.h:36
DualNumber< Real, DNDerivativeType, true > ADReal
void addRequiredParam(const std::string &name, const std::string &doc_string)
const ADVariableGradient & _grad_vel_x
Definition: GradDiv.h:34
unsigned int _i
static InputParameters validParams()
void addRequiredCoupledVar(const std::string &name, const std::string &doc_string)
const Real _gamma
Definition: GradDiv.h:38
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
void addClassDescription(const std::string &doc_string)
const ADVariableGradient & _grad_vel_y
Definition: GradDiv.h:35
const bool _matrix_only
Definition: GradDiv.h:37
unsigned int _qp