https://mooseframework.inl.gov
KokkosReaction.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 "KokkosKernel.h"
13 
18 {
19 public:
21 
23 
24  template <typename Derived>
25  KOKKOS_FUNCTION Real computeQpResidual(const unsigned int i,
26  const unsigned int qp,
27  AssemblyDatum & datum) const;
28  template <typename Derived>
29  KOKKOS_FUNCTION Real computeQpJacobian(const unsigned int i,
30  const unsigned int j,
31  const unsigned int qp,
32  AssemblyDatum & datum) const;
33 
34 protected:
37 };
38 
39 template <typename Derived>
40 KOKKOS_FUNCTION Real
41 KokkosReaction::computeQpResidual(const unsigned int i,
42  const unsigned int qp,
43  AssemblyDatum & datum) const
44 {
45  return _test(datum, i, qp) * _rate * _u(datum, qp);
46 }
47 
48 template <typename Derived>
49 KOKKOS_FUNCTION Real
50 KokkosReaction::computeQpJacobian(const unsigned int i,
51  const unsigned int j,
52  const unsigned int qp,
53  AssemblyDatum & datum) const
54 {
55  return _test(datum, i, qp) * _rate * _phi(datum, j, qp);
56 }
KOKKOS_FUNCTION Real computeQpResidual(const unsigned int i, const unsigned int qp, AssemblyDatum &datum) const
const VariableValue _u
Current solution at quadrature points.
Definition: KokkosKernel.h:189
const InputParameters & parameters() const
Get the parameters of the object.
Definition: MooseBase.h:131
const VariableTestValue _test
Current test function.
Definition: KokkosKernel.h:173
The main MOOSE class responsible for handling user-defined parameters in almost every MOOSE system...
KokkosReaction(const InputParameters &parameters)
Implements a simple consuming reaction term with weak form $(\psi_i, \lambda u_h)$.
KOKKOS_FUNCTION Real computeQpJacobian(const unsigned int i, const unsigned int j, const unsigned int qp, AssemblyDatum &datum) const
DIE A HORRIBLE DEATH HERE typedef LIBMESH_DEFAULT_SCALAR_TYPE Real
The Kokkos object that holds thread-private data in the parallel operations of Kokkos kernels...
Definition: KokkosDatum.h:364
static InputParameters validParams()
const VariablePhiValue _phi
Current shape function.
Definition: KokkosKernel.h:181
The base class for a user to derive their own Kokkos kernels.
Definition: KokkosKernel.h:39
const Moose::Kokkos::Scalar< const Real > _rate
Scalar coefficient representing the relative amount consumed per unit time.