https://mooseframework.inl.gov
AdvectionIPHDGOutflowBC.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 
12 
14 
17 {
18  auto params = IPHDGBC::validParams();
20  params.addClassDescription("Implements an outflow boundary condition for use with a hybridized "
21  "discretization of the advection equation");
22  params.addRequiredParam<bool>("constrain_lm",
23  "Whether to constrain the Lagrange multiplier to weakly match the "
24  "interior solution on this boundary. This should be set to true "
25  "for pure advection problems and likely false otherwise.");
26  return params;
27 }
28 
30  : IPHDGBC(parameters),
31  _iphdg_helper(std::make_unique<AdvectionIPHDGAssemblyHelper>(
32  this, this, this, _sys, _assembly, _tid, std::set<SubdomainID>{}, boundaryIDs())),
33  _constrain_lm(getParam<bool>("constrain_lm"))
34 {
35 }
36 
37 void
39 {
40  auto & iphdg_helper = iphdgHelper();
41  iphdg_helper.resizeResiduals();
42 
43  // u, lm_u
44  iphdg_helper.scalarFace();
45  if (_constrain_lm)
46  iphdg_helper.lmOutflow();
47 }
48 
51 {
52  return *_iphdg_helper;
53 }
Implements a prescribed flux for an IP-HDG discretization.
Definition: IPHDGBC.h:19
virtual void compute() override
compute the AD residuals
Implements an outflow boundary condition for use with a hybridized discretization of the Advection eq...
static InputParameters validParams()
Definition: IPHDGBC.C:14
The main MOOSE class responsible for handling user-defined parameters in almost every MOOSE system...
Implements all the methods for assembling a hybridized interior penalty discontinuous Galerkin (IPDG-...
AdvectionIPHDGOutflowBC(const InputParameters &parameters)
virtual AdvectionIPHDGAssemblyHelper & iphdgHelper() override
const bool _constrain_lm
Whether to constrain the Lagrange multiplier to weakly match the interior solution on this boundary...
std::unique_ptr< AdvectionIPHDGAssemblyHelper > _iphdg_helper
The assembly helper providing the required IP-HDG method implementations.
registerMooseObject("MooseApp", AdvectionIPHDGOutflowBC)
static InputParameters validParams()