https://mooseframework.inl.gov
KokkosNeumannBC.h
Go to the documentation of this file.
1 //* This file is part of the MOOSE framework
2 //* https://www.mooseframework.org
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 "KokkosIntegratedBC.h"
13 
14 class KokkosNeumannBC final : public Moose::Kokkos::IntegratedBC<KokkosNeumannBC>
15 {
16 public:
18 
20 
21  KOKKOS_FUNCTION Real computeQpResidual(const unsigned int i,
22  const unsigned int qp,
23  ResidualDatum & datum) const;
24 
25 private:
27  const Real _value;
28 };
29 
30 KOKKOS_FUNCTION inline Real
32  const unsigned int qp,
33  ResidualDatum & datum) const
34 {
35  return -_test(datum, i, qp) * _value;
36 }
const Real _value
Value of grad(u) on the boundary.
The base class for a user to derive their own Kokkos integrated boundary conditions.
const InputParameters & parameters() const
Get the parameters of the object.
Definition: MooseBase.h:131
static InputParameters validParams()
The main MOOSE class responsible for handling user-defined parameters in almost every MOOSE system...
const VariableTestValue _test
Current test function.
KokkosNeumannBC(const InputParameters &parameters)
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
KOKKOS_FUNCTION Real computeQpResidual(const unsigned int i, const unsigned int qp, ResidualDatum &datum) const
The Kokkos object that holds thread-private data in the parallel operations of Kokkos residual object...
Definition: KokkosDatum.h:222