1 /*
2  * Copyright (c) 2021 Stephanos Ioannidis <root@stephanos.io>
3  * Copyright (C) 2010-2021 ARM Limited or its affiliates. All rights reserved.
4  *
5  * SPDX-License-Identifier: Apache-2.0
6  */
7 
8 #include <zephyr/ztest.h>
9 #include <zephyr/kernel.h>
10 #include <stdlib.h>
11 #include <arm_math.h>
12 #include "../../common/test_common.h"
13 
14 #include "q31.pat"
15 
16 #define SNR_ERROR_THRESH	((float32_t)100)
17 #define ABS_ERROR_THRESH_Q15	((q31_t)100)
18 #define ABS_ERROR_THRESH_Q63	((q63_t)(1 << 18))
19 
test_arm_max_q31(const q31_t * input1,int ref_index,size_t length)20 static void test_arm_max_q31(
21 	const q31_t *input1, int ref_index, size_t length)
22 {
23 	q31_t val;
24 	uint32_t index;
25 
26 	/* Run test function */
27 	arm_max_q31(input1, length, &val, &index);
28 
29 	/* Validate output */
30 	zassert_equal(val, ref_max_val[ref_index],
31 		ASSERT_MSG_INCORRECT_COMP_RESULT);
32 
33 	zassert_equal(index, ref_max_idx[ref_index],
34 		ASSERT_MSG_INCORRECT_COMP_RESULT);
35 }
36 
37 DEFINE_TEST_VARIANT3(statistics_q31, arm_max_q31, 3, in_com1, 0, 3);
38 DEFINE_TEST_VARIANT3(statistics_q31, arm_max_q31, 8, in_com1, 1, 8);
39 DEFINE_TEST_VARIANT3(statistics_q31, arm_max_q31, 11, in_com1, 2, 11);
40 
test_arm_min_q31(const q31_t * input1,int ref_index,size_t length)41 static void test_arm_min_q31(
42 	const q31_t *input1, int ref_index, size_t length)
43 {
44 	q31_t val;
45 	uint32_t index;
46 
47 	/* Run test function */
48 	arm_min_q31(input1, length, &val, &index);
49 
50 	/* Validate output */
51 	zassert_equal(val, ref_min_val[ref_index],
52 		ASSERT_MSG_INCORRECT_COMP_RESULT);
53 
54 	zassert_equal(index, ref_min_idx[ref_index],
55 		ASSERT_MSG_INCORRECT_COMP_RESULT);
56 }
57 
58 DEFINE_TEST_VARIANT3(statistics_q31, arm_min_q31, 3, in_com1, 0, 3);
59 DEFINE_TEST_VARIANT3(statistics_q31, arm_min_q31, 8, in_com1, 1, 8);
60 DEFINE_TEST_VARIANT3(statistics_q31, arm_min_q31, 11, in_com1, 2, 11);
61 
test_arm_absmax_q31(const q31_t * input1,int ref_index,size_t length)62 static void test_arm_absmax_q31(
63 	const q31_t *input1, int ref_index, size_t length)
64 {
65 	q31_t val;
66 	uint32_t index;
67 
68 	/* Run test function */
69 	arm_absmax_q31(input1, length, &val, &index);
70 
71 	/* Validate output */
72 	zassert_equal(val, ref_absmax_val[ref_index],
73 		ASSERT_MSG_INCORRECT_COMP_RESULT);
74 
75 	zassert_equal(index, ref_absmax_idx[ref_index],
76 		ASSERT_MSG_INCORRECT_COMP_RESULT);
77 }
78 
79 DEFINE_TEST_VARIANT3(statistics_q31, arm_absmax_q31, 3, in_absminmax, 0, 3);
80 DEFINE_TEST_VARIANT3(statistics_q31, arm_absmax_q31, 8, in_absminmax, 1, 8);
81 DEFINE_TEST_VARIANT3(statistics_q31, arm_absmax_q31, 11, in_absminmax, 2, 11);
82 
test_arm_absmin_q31(const q31_t * input1,int ref_index,size_t length)83 static void test_arm_absmin_q31(
84 	const q31_t *input1, int ref_index, size_t length)
85 {
86 	q31_t val;
87 	uint32_t index;
88 
89 	/* Run test function */
90 	arm_absmin_q31(input1, length, &val, &index);
91 
92 	/* Validate output */
93 	zassert_equal(val, ref_absmin_val[ref_index],
94 		ASSERT_MSG_INCORRECT_COMP_RESULT);
95 
96 	zassert_equal(index, ref_absmin_idx[ref_index],
97 		ASSERT_MSG_INCORRECT_COMP_RESULT);
98 }
99 
100 DEFINE_TEST_VARIANT3(statistics_q31, arm_absmin_q31, 3, in_absminmax, 0, 3);
101 DEFINE_TEST_VARIANT3(statistics_q31, arm_absmin_q31, 8, in_absminmax, 1, 8);
102 DEFINE_TEST_VARIANT3(statistics_q31, arm_absmin_q31, 11, in_absminmax, 2, 11);
103 
test_arm_mean_q31(const q31_t * input1,int ref_index,size_t length)104 static void test_arm_mean_q31(
105 	const q31_t *input1, int ref_index, size_t length)
106 {
107 	q31_t ref[1];
108 	q31_t *output;
109 
110 	/* Load reference */
111 	ref[0] = ref_mean[ref_index];
112 
113 	/* Allocate output buffer */
114 	output = malloc(1 * sizeof(q31_t));
115 	zassert_not_null(output, ASSERT_MSG_BUFFER_ALLOC_FAILED);
116 
117 	/* Run test function */
118 	arm_mean_q31(input1, length, &output[0]);
119 
120 	/* Validate output */
121 	zassert_true(
122 		test_snr_error_q31(1, output, ref, SNR_ERROR_THRESH),
123 		ASSERT_MSG_SNR_LIMIT_EXCEED);
124 
125 	zassert_true(
126 		test_near_equal_q31(1, output, ref, ABS_ERROR_THRESH_Q15),
127 		ASSERT_MSG_ABS_ERROR_LIMIT_EXCEED);
128 
129 	/* Free output buffer */
130 	free(output);
131 }
132 
133 DEFINE_TEST_VARIANT3(statistics_q31, arm_mean_q31, 3, in_com2, 0, 3);
134 DEFINE_TEST_VARIANT3(statistics_q31, arm_mean_q31, 8, in_com2, 1, 8);
135 DEFINE_TEST_VARIANT3(statistics_q31, arm_mean_q31, 11, in_com2, 2, 11);
136 
test_arm_power_q31(const q31_t * input1,int ref_index,size_t length)137 static void test_arm_power_q31(
138 	const q31_t *input1, int ref_index, size_t length)
139 {
140 	q63_t ref[1];
141 	q63_t *output;
142 
143 	/* Load reference */
144 	ref[0] = ref_power[ref_index];
145 
146 	/* Allocate output buffer */
147 	output = malloc(1 * sizeof(q63_t));
148 	zassert_not_null(output, ASSERT_MSG_BUFFER_ALLOC_FAILED);
149 
150 	/* Run test function */
151 	arm_power_q31(input1, length, &output[0]);
152 
153 	/* Validate output */
154 	zassert_true(
155 		test_snr_error_q63(1, output, ref, SNR_ERROR_THRESH),
156 		ASSERT_MSG_SNR_LIMIT_EXCEED);
157 
158 	zassert_true(
159 		test_near_equal_q63(1, output, ref, ABS_ERROR_THRESH_Q63),
160 		ASSERT_MSG_ABS_ERROR_LIMIT_EXCEED);
161 
162 	/* Free output buffer */
163 	free(output);
164 }
165 
166 DEFINE_TEST_VARIANT3(statistics_q31, arm_power_q31, 3, in_com1, 0, 3);
167 DEFINE_TEST_VARIANT3(statistics_q31, arm_power_q31, 8, in_com1, 1, 8);
168 DEFINE_TEST_VARIANT3(statistics_q31, arm_power_q31, 11, in_com1, 2, 11);
169 
test_arm_rms_q31(const q31_t * input1,int ref_index,size_t length)170 static void test_arm_rms_q31(
171 	const q31_t *input1, int ref_index, size_t length)
172 {
173 	q31_t ref[1];
174 	q31_t *output;
175 
176 	/* Load reference */
177 	ref[0] = ref_rms[ref_index];
178 
179 	/* Allocate output buffer */
180 	output = malloc(1 * sizeof(q31_t));
181 	zassert_not_null(output, ASSERT_MSG_BUFFER_ALLOC_FAILED);
182 
183 	/* Run test function */
184 	arm_rms_q31(input1, length, &output[0]);
185 
186 	/* Validate output */
187 	zassert_true(
188 		test_snr_error_q31(1, output, ref, SNR_ERROR_THRESH),
189 		ASSERT_MSG_SNR_LIMIT_EXCEED);
190 
191 	zassert_true(
192 		test_near_equal_q31(1, output, ref, ABS_ERROR_THRESH_Q15),
193 		ASSERT_MSG_ABS_ERROR_LIMIT_EXCEED);
194 
195 	/* Free output buffer */
196 	free(output);
197 }
198 
199 DEFINE_TEST_VARIANT3(statistics_q31, arm_rms_q31, 3, in_com1, 0, 3);
200 DEFINE_TEST_VARIANT3(statistics_q31, arm_rms_q31, 8, in_com1, 1, 8);
201 DEFINE_TEST_VARIANT3(statistics_q31, arm_rms_q31, 11, in_com1, 2, 11);
202 
test_arm_std_q31(const q31_t * input1,int ref_index,size_t length)203 static void test_arm_std_q31(
204 	const q31_t *input1, int ref_index, size_t length)
205 {
206 	q31_t ref[1];
207 	q31_t *output;
208 
209 	/* Load reference */
210 	ref[0] = ref_std[ref_index];
211 
212 	/* Allocate output buffer */
213 	output = malloc(1 * sizeof(q31_t));
214 	zassert_not_null(output, ASSERT_MSG_BUFFER_ALLOC_FAILED);
215 
216 	/* Run test function */
217 	arm_std_q31(input1, length, &output[0]);
218 
219 	/* Validate output */
220 	zassert_true(
221 		test_snr_error_q31(1, output, ref, SNR_ERROR_THRESH),
222 		ASSERT_MSG_SNR_LIMIT_EXCEED);
223 
224 	zassert_true(
225 		test_near_equal_q31(1, output, ref, ABS_ERROR_THRESH_Q15),
226 		ASSERT_MSG_ABS_ERROR_LIMIT_EXCEED);
227 
228 	/* Free output buffer */
229 	free(output);
230 }
231 
232 DEFINE_TEST_VARIANT3(statistics_q31, arm_std_q31, 3, in_com1, 0, 3);
233 DEFINE_TEST_VARIANT3(statistics_q31, arm_std_q31, 8, in_com1, 1, 8);
234 DEFINE_TEST_VARIANT3(statistics_q31, arm_std_q31, 11, in_com1, 2, 11);
235 
test_arm_var_q31(const q31_t * input1,int ref_index,size_t length)236 static void test_arm_var_q31(
237 	const q31_t *input1, int ref_index, size_t length)
238 {
239 	q31_t ref[1];
240 	q31_t *output;
241 
242 	/* Load reference */
243 	ref[0] = ref_var[ref_index];
244 
245 	/* Allocate output buffer */
246 	output = malloc(1 * sizeof(q31_t));
247 	zassert_not_null(output, ASSERT_MSG_BUFFER_ALLOC_FAILED);
248 
249 	/* Run test function */
250 	arm_var_q31(input1, length, &output[0]);
251 
252 	/* Validate output */
253 	zassert_true(
254 		test_snr_error_q31(1, output, ref, SNR_ERROR_THRESH),
255 		ASSERT_MSG_SNR_LIMIT_EXCEED);
256 
257 	zassert_true(
258 		test_near_equal_q31(1, output, ref, ABS_ERROR_THRESH_Q15),
259 		ASSERT_MSG_ABS_ERROR_LIMIT_EXCEED);
260 
261 	/* Free output buffer */
262 	free(output);
263 }
264 
265 DEFINE_TEST_VARIANT3(statistics_q31, arm_var_q31, 3, in_com1, 0, 3);
266 DEFINE_TEST_VARIANT3(statistics_q31, arm_var_q31, 8, in_com1, 1, 8);
267 DEFINE_TEST_VARIANT3(statistics_q31, arm_var_q31, 11, in_com1, 2, 11);
268 
269 ZTEST_SUITE(statistics_q31, NULL, NULL, NULL, NULL, NULL);
270