-
Notifications
You must be signed in to change notification settings - Fork 6
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add simple examples and reference numpy scripts
- Loading branch information
Yuuichi Asahi
committed
Dec 7, 2023
1 parent
1e34961
commit d485e71
Showing
14 changed files
with
259 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,43 @@ | ||
#include <Kokkos_Core.hpp> | ||
#include <Kokkos_Complex.hpp> | ||
#include <Kokkos_Random.hpp> | ||
#include <KokkosFFT.hpp> | ||
|
||
using execution_space = Kokkos::DefaultExecutionSpace; | ||
template <typename T> using View1D = Kokkos::View<T*, execution_space>; | ||
|
||
int main( int argc, char* argv[] ) { | ||
Kokkos::initialize( argc, argv ); | ||
{ | ||
constexpr int n0 = 128; | ||
const Kokkos::complex<double> I(1.0, 1.0); | ||
|
||
// 1D C2C FFT (Forward and Backward) | ||
View1D<Kokkos::complex<double> > xc2c("xc2c", n0); | ||
View1D<Kokkos::complex<double> > xc2c_hat("xc2c_hat", n0); | ||
View1D<Kokkos::complex<double> > xc2c_inv("xc2c_inv", n0); | ||
|
||
Kokkos::Random_XorShift64_Pool<> random_pool(12345); | ||
Kokkos::fill_random(xc2c, random_pool, I); | ||
|
||
KokkosFFT::fft(xc2c, xc2c_hat); | ||
KokkosFFT::ifft(xc2c_hat, xc2c_inv); | ||
|
||
// 1D R2C FFT | ||
View1D<double> xr2c("xr2c", n0); | ||
View1D<Kokkos::complex<double> > xr2c_hat("xr2c_hat", n0/2+1); | ||
Kokkos::fill_random(xr2c, random_pool, 1); | ||
|
||
KokkosFFT::rfft(xr2c, xr2c_hat); | ||
|
||
// 1D C2R FFT | ||
View1D<Kokkos::complex<double> > xc2r("xr2c_hat", n0/2+1); | ||
View1D<double> xc2r_hat("xc2r", n0); | ||
Kokkos::fill_random(xc2r, random_pool, I); | ||
|
||
KokkosFFT::irfft(xc2r, xc2r_hat); | ||
} | ||
Kokkos::finalize(); | ||
|
||
return 0; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
add_executable(01_1DFFT 01_1DFFT.cpp) | ||
target_link_libraries(01_1DFFT PUBLIC Kokkos::fft) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
import numpy as np | ||
|
||
if __name__ == '__main__': | ||
n0 = 128 | ||
|
||
# 1D C2C FFT (Forward and Backward) | ||
xc2c = np.random.rand(n0) + 1j * np.random.rand(n0) | ||
xc2c_hat = np.fft.fft(xc2c) | ||
xc2c_inv = np.fft.ifft(xc2c_hat) | ||
|
||
# 1D R2C FFT | ||
xr2c = np.random.rand(n0) | ||
xr2c_hat = np.fft.rfft(xr2c) | ||
|
||
# 1D C2R FFT | ||
xc2r = np.random.rand(n0//2+1) | ||
xc2r_hat = np.fft.irfft(xc2r) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,43 @@ | ||
#include <Kokkos_Core.hpp> | ||
#include <Kokkos_Complex.hpp> | ||
#include <Kokkos_Random.hpp> | ||
#include <KokkosFFT.hpp> | ||
|
||
using execution_space = Kokkos::DefaultExecutionSpace; | ||
template <typename T> using View2D = Kokkos::View<T**, execution_space>; | ||
|
||
int main( int argc, char* argv[] ) { | ||
Kokkos::initialize( argc, argv ); | ||
{ | ||
constexpr int n0 = 128, n1 = 128; | ||
const Kokkos::complex<double> I(1.0, 1.0); | ||
|
||
// 2D C2C FFT (Forward and Backward) | ||
View2D<Kokkos::complex<double> > xc2c("xc2c", n0, n1); | ||
View2D<Kokkos::complex<double> > xc2c_hat("xc2c_hat", n0, n1); | ||
View2D<Kokkos::complex<double> > xc2c_inv("xc2c_inv", n0, n1); | ||
|
||
Kokkos::Random_XorShift64_Pool<> random_pool(12345); | ||
Kokkos::fill_random(xc2c, random_pool, I); | ||
|
||
KokkosFFT::fft2(xc2c, xc2c_hat); | ||
KokkosFFT::ifft2(xc2c_hat, xc2c_inv); | ||
|
||
// 2D R2C FFT | ||
View2D<double> xr2c("xr2c", n0, n1); | ||
View2D<Kokkos::complex<double> > xr2c_hat("xr2c_hat", n0, n1/2+1); | ||
Kokkos::fill_random(xr2c, random_pool, 1); | ||
|
||
KokkosFFT::rfft2(xr2c, xr2c_hat); | ||
|
||
// 2D C2R FFT | ||
View2D<Kokkos::complex<double> > xc2r("xr2c_hat", n0, n1/2+1); | ||
View2D<double> xc2r_hat("xc2r", n0, n1); | ||
Kokkos::fill_random(xc2r, random_pool, I); | ||
|
||
KokkosFFT::irfft2(xc2r, xc2r_hat); | ||
} | ||
Kokkos::finalize(); | ||
|
||
return 0; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
add_executable(02_2DFFT 02_2DFFT.cpp) | ||
target_link_libraries(02_2DFFT PUBLIC Kokkos::fft) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
import numpy as np | ||
|
||
if __name__ == '__main__': | ||
n0, n1 = 128, 128 | ||
|
||
# 2D C2C FFT (Forward and Backward) | ||
xc2c = np.random.rand(n0, n1) + 1j * np.random.rand(n0, n1) | ||
xc2c_hat = np.fft.fft2(xc2c) | ||
xc2c_inv = np.fft.ifft2(xc2c_hat) | ||
|
||
# 2D R2C FFT | ||
xr2c = np.random.rand(n0, n1) | ||
xr2c_hat = np.fft.rfft2(xr2c) | ||
|
||
# 2D C2R FFT | ||
xc2r = np.random.rand(n0, n1//2+1) | ||
xc2r_hat = np.fft.irfft2(xc2r) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,43 @@ | ||
#include <Kokkos_Core.hpp> | ||
#include <Kokkos_Complex.hpp> | ||
#include <Kokkos_Random.hpp> | ||
#include <KokkosFFT.hpp> | ||
|
||
using execution_space = Kokkos::DefaultExecutionSpace; | ||
template <typename T> using View3D = Kokkos::View<T***, execution_space>; | ||
|
||
int main( int argc, char* argv[] ) { | ||
Kokkos::initialize( argc, argv ); | ||
{ | ||
constexpr int n0 = 128, n1 = 128, n2 = 16; | ||
const Kokkos::complex<double> I(1.0, 1.0); | ||
|
||
// 3D C2C FFT (Forward and Backward) | ||
View3D<Kokkos::complex<double> > xc2c("xc2c", n0, n1, n2); | ||
View3D<Kokkos::complex<double> > xc2c_hat("xc2c_hat", n0, n1, n2); | ||
View3D<Kokkos::complex<double> > xc2c_inv("xc2c_inv", n0, n1, n2); | ||
|
||
Kokkos::Random_XorShift64_Pool<> random_pool(12345); | ||
Kokkos::fill_random(xc2c, random_pool, I); | ||
|
||
KokkosFFT::fftn(xc2c, xc2c_hat); | ||
KokkosFFT::ifftn(xc2c_hat, xc2c_inv); | ||
|
||
// 3D R2C FFT | ||
View3D<double> xr2c("xr2c", n0, n1, n2); | ||
View3D<Kokkos::complex<double> > xr2c_hat("xr2c_hat", n0, n1, n2/2+1); | ||
Kokkos::fill_random(xr2c, random_pool, 1); | ||
|
||
KokkosFFT::rfftn(xr2c, xr2c_hat); | ||
|
||
// 3D C2R FFT | ||
View3D<Kokkos::complex<double> > xc2r("xr2c_hat", n0, n1, n2/2+1); | ||
View3D<double> xc2r_hat("xc2r", n0, n1, n2); | ||
Kokkos::fill_random(xc2r, random_pool, I); | ||
|
||
KokkosFFT::irfftn(xc2r, xc2r_hat); | ||
} | ||
Kokkos::finalize(); | ||
|
||
return 0; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
add_executable(03_NDFFT 03_NDFFT.cpp) | ||
target_link_libraries(03_NDFFT PUBLIC Kokkos::fft) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
import numpy as np | ||
|
||
if __name__ == '__main__': | ||
n0, n1, n2 = 128, 128, 16 | ||
|
||
# 3D C2C FFT (Forward and Backward) | ||
xc2c = np.random.rand(n0, n1, n2) + 1j * np.random.rand(n0, n1, n2) | ||
xc2c_hat = np.fft.fftn(xc2c) | ||
xc2c_inv = np.fft.ifftn(xc2c_hat) | ||
|
||
# 3D R2C FFT | ||
xr2c = np.random.rand(n0, n1, n2) | ||
xr2c_hat = np.fft.rfftn(xr2c) | ||
|
||
# 3D C2R FFT | ||
xc2r = np.random.rand(n0, n1, n2//2+1) | ||
xc2r_hat = np.fft.irfftn(xc2r) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,43 @@ | ||
#include <Kokkos_Core.hpp> | ||
#include <Kokkos_Complex.hpp> | ||
#include <Kokkos_Random.hpp> | ||
#include <KokkosFFT.hpp> | ||
|
||
using execution_space = Kokkos::DefaultExecutionSpace; | ||
template <typename T> using View3D = Kokkos::View<T***, execution_space>; | ||
|
||
int main( int argc, char* argv[] ) { | ||
Kokkos::initialize( argc, argv ); | ||
{ | ||
constexpr int n0 = 128, n1 = 128, n2 = 16; | ||
const Kokkos::complex<double> I(1.0, 1.0); | ||
|
||
// 1D batched C2C FFT (Forward and Backward) | ||
View3D<Kokkos::complex<double> > xc2c("xc2c", n0, n1, n2); | ||
View3D<Kokkos::complex<double> > xc2c_hat("xc2c_hat", n0, n1, n2); | ||
View3D<Kokkos::complex<double> > xc2c_inv("xc2c_inv", n0, n1, n2); | ||
|
||
Kokkos::Random_XorShift64_Pool<> random_pool(12345); | ||
Kokkos::fill_random(xc2c, random_pool, I); | ||
|
||
KokkosFFT::fft(xc2c, xc2c_hat, KokkosFFT::FFT_Normalization::BACKWARD, /*axis=*/-1); | ||
KokkosFFT::ifft(xc2c_hat, xc2c_inv, KokkosFFT::FFT_Normalization::BACKWARD, /*axis=*/-1); | ||
|
||
// 1D batched R2C FFT | ||
View3D<double> xr2c("xr2c", n0, n1, n2); | ||
View3D<Kokkos::complex<double> > xr2c_hat("xr2c_hat", n0, n1, n2/2+1); | ||
Kokkos::fill_random(xr2c, random_pool, 1); | ||
|
||
KokkosFFT::rfft(xr2c, xr2c_hat, KokkosFFT::FFT_Normalization::BACKWARD, /*axis=*/-1); | ||
|
||
// 1D batched C2R FFT | ||
View3D<Kokkos::complex<double> > xc2r("xr2c_hat", n0, n1, n2/2+1); | ||
View3D<double> xc2r_hat("xc2r", n0, n1, n2); | ||
Kokkos::fill_random(xc2r, random_pool, I); | ||
|
||
KokkosFFT::irfft(xc2r, xc2r_hat, KokkosFFT::FFT_Normalization::BACKWARD, /*axis=*/-1); | ||
} | ||
Kokkos::finalize(); | ||
|
||
return 0; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
add_executable(04_batchedFFT 04_batchedFFT.cpp) | ||
target_link_libraries(04_batchedFFT PUBLIC Kokkos::fft) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
import numpy as np | ||
|
||
if __name__ == '__main__': | ||
n0, n1, n2 = 128, 128, 16 | ||
|
||
# 1D batched C2C FFT (Forward and Backward) | ||
xc2c = np.random.rand(n0, n1, n2) + 1j * np.random.rand(n0, n1, n2) | ||
xc2c_hat = np.fft.fft(xc2c, axis=-1) | ||
xc2c_inv = np.fft.ifft(xc2c_hat, axis=-1) | ||
|
||
# 1D batched R2C FFT | ||
xr2c = np.random.rand(n0, n1, n2) | ||
xr2c_hat = np.fft.rfft(xr2c, axis=-1) | ||
|
||
# 1D batched C2R FFT | ||
xc2r = np.random.rand(n0, n1, n2//2+1) | ||
xc2r_hat = np.fft.irfft(xc2r, axis=-1) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
add_subdirectory(01_1DFFT) | ||
add_subdirectory(02_2DFFT) | ||
add_subdirectory(03_NDFFT) | ||
add_subdirectory(04_batchedFFT) |