diff --git a/common/src/KokkosFFT_Extents.hpp b/common/src/KokkosFFT_Extents.hpp index 95a4dc34..e3bea237 100644 --- a/common/src/KokkosFFT_Extents.hpp +++ b/common/src/KokkosFFT_Extents.hpp @@ -33,7 +33,7 @@ namespace Impl { template auto get_extents(const InViewType& in, const OutViewType& out, axis_type axes, shape_type shape = {}, - bool is_inplace = false) { + [[maybe_unused]] bool is_inplace = false) { using in_value_type = typename InViewType::non_const_value_type; using out_value_type = typename OutViewType::non_const_value_type; using array_layout_type = typename InViewType::array_layout; diff --git a/examples/08_inplace_FFT/08_inplace_FFT.cpp b/examples/08_inplace_FFT/08_inplace_FFT.cpp new file mode 100644 index 00000000..7e17904d --- /dev/null +++ b/examples/08_inplace_FFT/08_inplace_FFT.cpp @@ -0,0 +1,75 @@ +// SPDX-FileCopyrightText: (C) The kokkos-fft development team, see COPYRIGHT.md file +// +// SPDX-License-Identifier: MIT OR Apache-2.0 WITH LLVM-exception + +#include +#include +#include +#include + +using execution_space = Kokkos::DefaultExecutionSpace; + +template +using RightView2D = Kokkos::View; + +int main(int argc, char *argv[]) { + Kokkos::initialize(argc, argv); + { + const int n0 = 128, n1 = 128; + const Kokkos::complex z(1.0, 1.0); + + // Forward and backward complex to complex transform + // Define a 2D complex view to handle data + RightView2D> xc2c("xc2c", n0, n1); + + // Fill the input view with random data + Kokkos::Random_XorShift64_Pool<> random_pool(12345); + execution_space exec; + Kokkos::fill_random(exec, xc2c, random_pool, z); + + KokkosFFT::fft2(exec, xc2c, xc2c); + KokkosFFT::ifft2(exec, xc2c, xc2c); + + // Real to complex transform + // Define a 2D complex view to handle data + RightView2D> xr2c_hat("xr2c", n0, n1 / 2 + 1); + + // Create unmanaged views on the same data with the FFT shape, + // that is (n0, n1) -> (n0, n1/2+1) R2C transform + // The shape is incorrect from the view point of casting to real + // For casting, the shape should be (n0, (n0/2+1) * 2) + RightView2D xr2c(reinterpret_cast(xr2c_hat.data()), n0, + n1), + xr2c_padded(reinterpret_cast(xr2c_hat.data()), n0, + (n0 / 2 + 1) * 2); + + // Fill the input view with random data in real space through xr2c_padded + auto sub_xr2c_padded = + Kokkos::subview(xr2c_padded, Kokkos::ALL, Kokkos::make_pair(0, n1)); + Kokkos::fill_random(exec, sub_xr2c_padded, random_pool, 1.0); + + // Perform the real to complex transform + // [Important] You must use xr2c to define the FFT shape correctly + KokkosFFT::rfft2(exec, xr2c, xr2c_hat); + + // Complex to real transform + // Define a 2D complex view to handle data + RightView2D> xc2r("xc2r", n0, n1 / 2 + 1); + + // Create an unmanaged view on the same data with the FFT shape + RightView2D xc2r_hat(reinterpret_cast(xc2r.data()), n0, + n1); + + // Fill the input view with random data in complex space + Kokkos::fill_random(exec, xc2r, random_pool, z); + + // Perform the complex to real transform + // [Important] You must use xc2r_hat to define the FFT shape correctly + KokkosFFT::irfft2(exec, xc2r, xc2r_hat); + + exec.fence(); + } + Kokkos::finalize(); + + return 0; +} diff --git a/examples/08_inplace_FFT/CMakeLists.txt b/examples/08_inplace_FFT/CMakeLists.txt new file mode 100644 index 00000000..20faadaf --- /dev/null +++ b/examples/08_inplace_FFT/CMakeLists.txt @@ -0,0 +1,6 @@ +# SPDX-FileCopyrightText: (C) The kokkos-fft development team, see COPYRIGHT.md file +# +# SPDX-License-Identifier: MIT OR Apache-2.0 WITH LLVM-exception + +add_executable(08_inplace_FFT 08_inplace_FFT.cpp) +target_link_libraries(08_inplace_FFT PUBLIC KokkosFFT::fft) diff --git a/examples/CMakeLists.txt b/examples/CMakeLists.txt index 919fef76..94b3c84a 100644 --- a/examples/CMakeLists.txt +++ b/examples/CMakeLists.txt @@ -9,3 +9,4 @@ add_subdirectory(04_batchedFFT) add_subdirectory(05_1DFFT_HOST_DEVICE) add_subdirectory(06_1DFFT_reuse_plans) add_subdirectory(07_unmanaged_views) +add_subdirectory(08_inplace_FFT)