diff options
author | giuros01 <giuseppe.rossini@arm.com> | 2019-03-26 17:44:40 +0000 |
---|---|---|
committer | Giuseppe Rossini <giuseppe.rossini@arm.com> | 2019-05-09 12:38:22 +0000 |
commit | 154bc1c3e6a0182e2130c7966af3944ee6ca20b3 (patch) | |
tree | 6cf717250870f311c99a4fbb6cdae4dfa84d5aae /arm_compute/core/NEON/kernels/NEFFTDigitReverseKernel.h | |
parent | ae1a89ed670956b9722fe57c2dc36c75e5f948ec (diff) | |
download | ComputeLibrary-154bc1c3e6a0182e2130c7966af3944ee6ca20b3.tar.gz |
COMPMID-1973: Implement FFTConvolutionLayer on NEON
Change-Id: I2e667c0411bda0164a616ffe44473a78de6752c9
Signed-off-by: giuros01 <giuseppe.rossini@arm.com>
Reviewed-on: https://review.mlplatform.org/c/1066
Reviewed-by: Gian Marco Iodice <gianmarco.iodice@arm.com>
Tested-by: Arm Jenkins <bsgcomp@arm.com>
Diffstat (limited to 'arm_compute/core/NEON/kernels/NEFFTDigitReverseKernel.h')
-rw-r--r-- | arm_compute/core/NEON/kernels/NEFFTDigitReverseKernel.h | 34 |
1 files changed, 22 insertions, 12 deletions
diff --git a/arm_compute/core/NEON/kernels/NEFFTDigitReverseKernel.h b/arm_compute/core/NEON/kernels/NEFFTDigitReverseKernel.h index 84d55fd8f4..0090c8cb14 100644 --- a/arm_compute/core/NEON/kernels/NEFFTDigitReverseKernel.h +++ b/arm_compute/core/NEON/kernels/NEFFTDigitReverseKernel.h @@ -24,6 +24,7 @@ #ifndef __ARM_COMPUTE_NEFFTDIGITREVERSEKERNEL_H__ #define __ARM_COMPUTE_NEFFTDIGITREVERSEKERNEL_H__ +#include "arm_compute/core/KernelDescriptors.h" #include "arm_compute/core/NEON/INEKernel.h" namespace arm_compute @@ -53,31 +54,40 @@ public: ~NEFFTDigitReverseKernel() = default; /** Set the input and output tensors. * - * @param[in] input Source tensor. Data types supported: F32. - * @param[out] output Destination tensor. Data type supported: same as @p input + * @param[in] input Source tensor. Data types supported: F32. Number of channels supported: 1 (real tensor) or 2 (complex tensor). + * @param[out] output Destination tensor. Data type supported: same as @p input. Number of channels supported: 2 (complex tensor). * @param[in] idx Digit reverse index tensor. Data type supported: U32 - * @param[in] axis Axis to perform digit reverse on. + * @param[in] config Kernel configuration. */ - void configure(const ITensor *input, ITensor *output, const ITensor *idx, unsigned int axis); + void configure(const ITensor *input, ITensor *output, const ITensor *idx, const FFTDigitReverseKernelInfo &config); + /** Static function to check if given info will lead to a valid configuration of @ref NEFFTDigitReverseKernel * - * @param[in] input Source tensor info. Data types supported: F32. - * @param[in] output Destination tensor info. Data type supported: same as @p input + * @param[in] input Source tensor info. Data types supported: F32. Number of channels supported: 1 (real tensor) or 2 (complex tensor). + * @param[in] output Destination tensor info. Data type supported: same as @p input. Number of channels supported: 2 (complex tensor). * @param[in] idx Digit reverse index tensor info. Data type supported: U32 - * @param[in] axis Axis to perform digit reverse on. + * @param[in] config Kernel configuration * * @return a status */ - static Status validate(const ITensorInfo *input, const ITensorInfo *output, const ITensorInfo *idx, unsigned int axis); + static Status validate(const ITensorInfo *input, const ITensorInfo *output, const ITensorInfo *idx, const FFTDigitReverseKernelInfo &config); // Inherited methods overridden: void run(const Window &window, const ThreadInfo &info) override; private: - const ITensor *_input; - ITensor *_output; - const ITensor *_idx; - unsigned int _axis; + using NEFFTDigitReverseKernelFunctionPtr = void (NEFFTDigitReverseKernel::*)(const Window &window); + + template <bool is_input_complex, bool is_conj> + void digit_reverse_kernel_axis_0(const Window &window); + + template <bool is_input_complex, bool is_conj> + void digit_reverse_kernel_axis_1(const Window &window); + + NEFFTDigitReverseKernelFunctionPtr _func; + const ITensor *_input; + ITensor *_output; + const ITensor *_idx; }; } // namespace arm_compute #endif /*__ARM_COMPUTE_NEFFTDIGITREVERSEKERNEL_H__ */ |