DOLFINx 0.10.0.0
DOLFINx C++ interface
Loading...
Searching...
No Matches
kernel.h
1// Copyright (C) 2025 Paul T. Kühner
2//
3// This file is part of DOLFINx (https://www.fenicsproject.org)
4//
5// SPDX-License-Identifier: LGPL-3.0-or-later
6
7#pragma once
8
9#include <dolfinx/common/defines.h>
10#include <dolfinx/common/types.h>
11#include <ufcx.h>
12
13namespace dolfinx::fem::impl
14{
18template <dolfinx::scalar T, std::floating_point U = scalar_value_t<T>>
19using kernelptr_t = void (*)(T*, const T*, const T*, const U*, const int*,
20 const std::uint8_t*, void*);
21
25template <dolfinx::scalar T, std::floating_point U = scalar_value_t<T>>
26using kernel_t = std::function<void(T*, const T*, const T*, const U*,
27 const int*, const std::uint8_t*, void*)>;
28
34template <dolfinx::scalar T, std::floating_point U = scalar_value_t<T>>
35constexpr kernel_t<T, U> extract_kernel(const ufcx_integral* integral)
36{
37 if constexpr (std::is_same_v<T, float>)
38 return integral->tabulate_tensor_float32;
39 else if constexpr (std::is_same_v<T, double>)
40 return integral->tabulate_tensor_float64;
41#ifndef DOLFINX_NO_STDC_COMPLEX_KERNELS
42 else if constexpr (std::is_same_v<T, std::complex<float>>
44 {
45 return reinterpret_cast<kernelptr_t<T, U>>(
46 integral->tabulate_tensor_complex64);
47 }
48 else if constexpr (std::is_same_v<T, std::complex<double>>
50 {
51 return reinterpret_cast<kernelptr_t<T, U>>(
52 integral->tabulate_tensor_complex128);
53 }
54#endif
55 else
56 throw std::runtime_error("Could not extract kernel from ufcx integral.");
57}
58
59} // namespace dolfinx::fem::impl
consteval bool has_complex_ufcx_kernels()
Definition defines.h:99