Line data Source code
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 "KokkosNodalKernel.h" 13 : 14 : class KokkosCoupledForceNodalKernel : public Moose::Kokkos::NodalKernel 15 : { 16 : public: 17 : static InputParameters validParams(); 18 : 19 : KokkosCoupledForceNodalKernel(const InputParameters & parameters); 20 : 21 : KOKKOS_FUNCTION Real computeQpResidual(const unsigned int qp, AssemblyDatum & datum) const; 22 : KOKKOS_FUNCTION Real computeQpOffDiagJacobian(const unsigned int jvar, 23 : const unsigned int qp, 24 : AssemblyDatum & datum) const; 25 : 26 : private: 27 : /// The number of the coupled variable 28 : const unsigned int _v_var; 29 : 30 : /// The value of the coupled variable 31 : const Moose::Kokkos::VariableValue _v; 32 : 33 : /// A multiplicative factor for computing the coupled force 34 : const Real _coef; 35 : }; 36 : 37 : KOKKOS_FUNCTION inline Real 38 117744 : KokkosCoupledForceNodalKernel::computeQpResidual(const unsigned int qp, AssemblyDatum & datum) const 39 : { 40 117744 : return -_coef * _v(datum, qp); 41 : } 42 : 43 : KOKKOS_FUNCTION inline Real 44 124550 : KokkosCoupledForceNodalKernel::computeQpOffDiagJacobian(const unsigned int jvar, 45 : const unsigned int /* qp */, 46 : AssemblyDatum & /* datum */) const 47 : { 48 124550 : if (jvar == _v_var) 49 91816 : return -_coef; 50 32734 : return 0; 51 : }