MFEM v4.8.0
Finite element discretization library
Loading...
Searching...
No Matches
grad_by_vdim.cpp
Go to the documentation of this file.
1// Copyright (c) 2010-2025, Lawrence Livermore National Security, LLC. Produced
2// at the Lawrence Livermore National Laboratory. All Rights reserved. See files
3// LICENSE and NOTICE for details. LLNL-CODE-806117.
4//
5// This file is part of the MFEM library. For more information and source code
6// availability visit https://mfem.org.
7//
8// MFEM is free software; you can redistribute it and/or modify it under the
9// terms of the BSD-3 license. We welcome feedback and contributions, see file
10// CONTRIBUTING.md for details.
11
13#include "grad.hpp"
14
15namespace mfem
16{
17namespace internal
18{
19namespace quadrature_interpolator
20{
21
22template <bool P>
23void InitGradByVDimKernels()
24{
25 using k = QuadratureInterpolator::GradKernels;
26 constexpr auto L = QVectorLayout::byVDIM;
27 // 2D
28 k::Specialization<2,L,P,1,3,4>::template Opt<8>::Add();
29 k::Specialization<2,L,P,1,4,6>::template Opt<4>::Add();
30 k::Specialization<2,L,P,1,5,8>::template Opt<2>::Add();
31
32 k::Specialization<2,L,P,2,3,3>::template Opt<8>::Add();
33 k::Specialization<2,L,P,2,3,4>::template Opt<8>::Add();
34 k::Specialization<2,L,P,2,4,6>::template Opt<4>::Add();
35 k::Specialization<2,L,P,2,5,8>::template Opt<2>::Add();
36 // 3D
37 k::Specialization<3,L,P,1,3,4>::Add();
38 k::Specialization<3,L,P,1,4,6>::Add();
39 k::Specialization<3,L,P,1,5,8>::Add();
40 k::Specialization<3,L,P,3,3,4>::Add();
41 k::Specialization<3,L,P,3,4,6>::Add();
42 k::Specialization<3,L,P,3,5,8>::Add();
43
44 using k2 = QuadratureInterpolator::CollocatedGradKernels;
45 // 2D
46 k2::Specialization<2,L,P,1,2>::template Opt<16>::Add();
47 k2::Specialization<2,L,P,1,3>::template Opt<16>::Add();
48 k2::Specialization<2,L,P,1,4>::template Opt<16>::Add();
49
50 k2::Specialization<2,L,P,2,2>::template Opt<16>::Add();
51 k2::Specialization<2,L,P,2,3>::template Opt<4>::Add();
52 k2::Specialization<2,L,P,2,4>::template Opt<2>::Add();
53
54 // 3D
55 k2::Specialization<3,L,P,1,2>::Add();
56 k2::Specialization<3,L,P,1,3>::Add();
57 k2::Specialization<3,L,P,1,4>::Add();
58
59 k2::Specialization<3,L,P,2,2>::Add();
60 k2::Specialization<3,L,P,2,3>::Add();
61 k2::Specialization<3,L,P,2,4>::Add();
62
63 k2::Specialization<3,L,P,3,2>::Add();
64 k2::Specialization<3,L,P,3,3>::Add();
65 k2::Specialization<3,L,P,3,4>::Add();
66}
67
68template void InitGradByVDimKernels<true>();
69template void InitGradByVDimKernels<false>();
70
71} // namespace quadrature_interpolator
72} // namespace internal
73} // namespace mfem