def test_idft_3d(): runtime = get_runtime() expected_results = get_data() complex_input_data = np.fft.fft2(np.squeeze( expected_results.view(dtype=np.complex64), axis=-1), axes=[0, 1, 2]).astype(np.complex64) input_data = np.stack((complex_input_data.real, complex_input_data.imag), axis=-1) input_tensor = ov.constant(input_data) input_axes = ov.constant(np.array([0, 1, 2], dtype=np.int64)) dft_node = ov.idft(input_tensor, input_axes) computation = runtime.computation(dft_node) dft_results = computation() assert np.allclose(dft_results, expected_results, atol=0.000003)
def test_idft_2d_signal_size_1(): runtime = get_runtime() input_data = get_data() input_tensor = ov.constant(input_data) input_axes = ov.constant(np.array([0, 2], dtype=np.int64)) input_signal_size = ov.constant(np.array([4, 5], dtype=np.int64)) dft_node = ov.idft(input_tensor, input_axes, input_signal_size) computation = runtime.computation(dft_node) dft_results = computation() np_results = np.fft.ifft2(np.squeeze(input_data.view(dtype=np.complex64), axis=-1), s=[4, 5], axes=[0, 2]).astype(np.complex64) expected_results = np.stack((np_results.real, np_results.imag), axis=-1) assert np.allclose(dft_results, expected_results, atol=0.000002)