summaryrefslogtreecommitdiff
path: root/hid-dials/Drivers/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/rfft_fast_tests.c
blob: d8a8e1758af4c9fa18715825700c06950c3df8af (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
#include "jtest.h"
#include "ref.h"
#include "arr_desc.h"
#include "transform_templates.h"
#include "transform_test_data.h"
#include "type_abbrev.h"

/*
FFT fast function test template. Arguments are: function configuration suffix
(q7/q15/q31/f32) and inverse-transform flag
*/
#define RFFT_FAST_DEFINE_TEST(config_suffix, ifft_flag)                 \
    JTEST_DEFINE_TEST(arm_rfft_fast_f32_##config_suffix##_test,         \
                      arm_fft_f32)                                      \
    {                                                                   \
        arm_rfft_fast_instance_f32 rfft_inst_fut = {{0}, 0, 0};         \
        arm_rfft_fast_instance_f32 rfft_inst_ref = {{0}, 0, 0};         \
                                                                        \
        /* Go through all FFT lengths */                                \
        TEMPLATE_DO_ARR_DESC(                                           \
            fftlen_idx, uint16_t, fftlen, transform_rfft_fast_fftlens   \
            ,                                                           \
                                                                        \
            /* Initialize the RFFT and CFFT Instances */                \
            arm_rfft_fast_init_f32(                                     \
                &rfft_inst_fut, fftlen);                                \
                                                                        \
            arm_rfft_fast_init_f32(                                     \
                &rfft_inst_ref, fftlen);                                \
                                                                        \
            TRANSFORM_COPY_INPUTS(                                      \
                transform_fft_f32_inputs,                               \
                fftlen *                                                \
                sizeof(float32_t));                                     \
                                                                        \
            /* Display parameter values */                              \
            JTEST_DUMP_STRF("Block Size: %d\n"                          \
                            "Inverse-transform flag: %d\n",             \
                         (int)fftlen,                                   \
                         (int)ifft_flag);                               \
                                                                        \
            /* Display cycle count and run test */                      \
            JTEST_COUNT_CYCLES(                                         \
                arm_rfft_fast_f32(                                      \
                    &rfft_inst_fut,                                     \
                    (void *) transform_fft_input_fut,                   \
                    (void *) transform_fft_output_fut,                  \
                    ifft_flag));                                        \
                                                                        \
            ref_rfft_fast_f32(                                          \
                &rfft_inst_ref,                                         \
                (void *) transform_fft_input_ref,                       \
                (void *) transform_fft_output_ref,                      \
                ifft_flag);                                             \
                                                                        \
            /* Test correctness */                                      \
            TRANSFORM_SNR_COMPARE_INTERFACE(                            \
                fftlen,                                                 \
                float32_t));                                            \
                                                                        \
        return JTEST_TEST_PASSED;                                       \
    }

RFFT_FAST_DEFINE_TEST(forward, 0U);
RFFT_FAST_DEFINE_TEST(inverse, 1U);

/*--------------------------------------------------------------------------------*/
/* Collect all tests in a group */
/*--------------------------------------------------------------------------------*/

JTEST_DEFINE_GROUP(rfft_fast_tests)
{
    JTEST_TEST_CALL(arm_rfft_fast_f32_forward_test);
    JTEST_TEST_CALL(arm_rfft_fast_f32_inverse_test);
}