This repository has been archived on 2020-04-08. You can view files and clone it, but cannot push or open issues or pull requests.
Files
Indoor/lib/simple_fft/fft.hpp
2018-01-24 11:44:08 +01:00

156 lines
6.6 KiB
C++

#ifndef __SIMPLE_FFT__FFT_HPP__
#define __SIMPLE_FFT__FFT_HPP__
#include "copy_array.hpp"
#include "fft_impl.hpp"
namespace simple_fft {
// in-place, complex, forward
template <class TComplexArray1D>
bool FFT(TComplexArray1D & data, const size_t size, const char *& error_description)
{
return impl::CFFT<TComplexArray1D,1>::FFT_inplace(data, size, impl::FFT_FORWARD,
error_description);
}
template <class TComplexArray2D>
bool FFT(TComplexArray2D & data, const size_t size1, const size_t size2,
const char *& error_description)
{
return impl::CFFT<TComplexArray2D,2>::FFT_inplace(data, size1, size2, impl::FFT_FORWARD,
error_description);
}
template <class TComplexArray3D>
bool FFT(TComplexArray3D & data, const size_t size1, const size_t size2, const size_t size3,
const char *& error_description)
{
return impl::CFFT<TComplexArray3D,3>::FFT_inplace(data, size1, size2, size3,
impl::FFT_FORWARD,
error_description);
}
// in-place, complex, inverse
template <class TComplexArray1D>
bool IFFT(TComplexArray1D & data, const size_t size, const char *& error_description)
{
return impl::CFFT<TComplexArray1D,1>::FFT_inplace(data, size, impl::FFT_BACKWARD,
error_description);
}
template <class TComplexArray2D>
bool IFFT(TComplexArray2D & data, const size_t size1, const size_t size2,
const char *& error_description)
{
return impl::CFFT<TComplexArray2D,2>::FFT_inplace(data, size1, size2, impl::FFT_BACKWARD,
error_description);
}
template <class TComplexArray3D>
bool IFFT(TComplexArray3D & data, const size_t size1, const size_t size2, const size_t size3,
const char *& error_description)
{
return impl::CFFT<TComplexArray3D,3>::FFT_inplace(data, size1, size2, size3,
impl::FFT_BACKWARD,
error_description);
}
// not-in-place, complex, forward
template <class TComplexArray1D>
bool FFT(const TComplexArray1D & data_in, TComplexArray1D & data_out,
const size_t size, const char *& error_description)
{
copy_array::copyArray(data_in, data_out, size);
return impl::CFFT<TComplexArray1D,1>::FFT_inplace(data_out, size, impl::FFT_FORWARD,
error_description);
}
template <class TComplexArray2D>
bool FFT(const TComplexArray2D & data_in, TComplexArray2D & data_out,
const size_t size1, const size_t size2, const char *& error_description)
{
copy_array::copyArray(data_in, data_out, size1, size2);
return impl::CFFT<TComplexArray2D,2>::FFT_inplace(data_out, size1, size2,
impl::FFT_FORWARD,
error_description);
}
template <class TComplexArray3D>
bool FFT(const TComplexArray3D & data_in, TComplexArray3D & data_out,
const size_t size1, const size_t size2, const size_t size3,
const char *& error_description)
{
copy_array::copyArray(data_in, data_out, size1, size2, size3);
return impl::CFFT<TComplexArray3D,3>::FFT_inplace(data_out, size1, size2, size3,
impl::FFT_FORWARD,
error_description);
}
// not-in-place, complex, inverse
template <class TComplexArray1D>
bool IFFT(const TComplexArray1D & data_in, TComplexArray1D & data_out,
const size_t size, const char *& error_description)
{
copy_array::copyArray(data_in, data_out, size);
return impl::CFFT<TComplexArray1D,1>::FFT_inplace(data_out, size, impl::FFT_BACKWARD,
error_description);
}
template <class TComplexArray2D>
bool IFFT(const TComplexArray2D & data_in, TComplexArray2D & data_out,
const size_t size1, const size_t size2, const char *& error_description)
{
copy_array::copyArray(data_in, data_out, size1, size2);
return impl::CFFT<TComplexArray2D,2>::FFT_inplace(data_out, size1, size2,
impl::FFT_BACKWARD,
error_description);
}
template <class TComplexArray3D>
bool IFFT(const TComplexArray3D & data_in, TComplexArray3D & data_out,
const size_t size1, const size_t size2, const size_t size3,
const char *& error_description)
{
copy_array::copyArray(data_in, data_out, size1, size2, size3);
return impl::CFFT<TComplexArray3D,3>::FFT_inplace(data_out, size1, size2, size3,
impl::FFT_BACKWARD,
error_description);
}
// not-in-place, real, forward
template <class TRealArray1D, class TComplexArray1D>
bool FFT(const TRealArray1D & data_in, TComplexArray1D & data_out,
const size_t size, const char *& error_description)
{
copy_array::copyArray(data_in, data_out, size);
return impl::CFFT<TComplexArray1D,1>::FFT_inplace(data_out, size,
impl::FFT_FORWARD,
error_description);
}
template <class TRealArray2D, class TComplexArray2D>
bool FFT(const TRealArray2D & data_in, TComplexArray2D & data_out,
const size_t size1, const size_t size2, const char *& error_description)
{
copy_array::copyArray(data_in, data_out, size1, size2);
return impl::CFFT<TComplexArray2D,2>::FFT_inplace(data_out, size1, size2,
impl::FFT_FORWARD,
error_description);
}
template <class TRealArray3D, class TComplexArray3D>
bool FFT(const TRealArray3D & data_in, TComplexArray3D & data_out,
const size_t size1, const size_t size2, const size_t size3,
const char *& error_description)
{
copy_array::copyArray(data_in, data_out, size1, size2, size3);
return impl::CFFT<TComplexArray3D,3>::FFT_inplace(data_out, size1, size2, size3,
impl::FFT_FORWARD,
error_description);
}
} // simple_fft
#endif // __SIMPLE_FFT__FFT_HPP__