1 /*
2  *  Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
3  *
4  *  Use of this source code is governed by a BSD-style license
5  *  that can be found in the LICENSE file in the root of the source
6  *  tree. An additional intellectual property rights grant can be found
7  *  in the file PATENTS.  All contributing project authors may
8  *  be found in the AUTHORS file in the root of the source tree.
9  */
10 
11 #include "testing/gtest/include/gtest/gtest.h"
12 #include "webrtc/common_audio/signal_processing/include/signal_processing_library.h"
13 
14 static const size_t kVector16Size = 9;
15 static const int16_t vector16[kVector16Size] = {1, -15511, 4323, 1963,
16   WEBRTC_SPL_WORD16_MAX, 0, WEBRTC_SPL_WORD16_MIN + 5, -3333, 345};
17 
18 class SplTest : public testing::Test {
19  protected:
SplTest()20    SplTest() {
21      WebRtcSpl_Init();
22    }
~SplTest()23    virtual ~SplTest() {
24    }
25 };
26 
TEST_F(SplTest,MacroTest)27 TEST_F(SplTest, MacroTest) {
28     // Macros with inputs.
29     int A = 10;
30     int B = 21;
31     int a = -3;
32     int b = WEBRTC_SPL_WORD32_MAX;
33 
34     EXPECT_EQ(10, WEBRTC_SPL_MIN(A, B));
35     EXPECT_EQ(21, WEBRTC_SPL_MAX(A, B));
36 
37     EXPECT_EQ(3, WEBRTC_SPL_ABS_W16(a));
38     EXPECT_EQ(3, WEBRTC_SPL_ABS_W32(a));
39 
40     EXPECT_EQ(-63, WEBRTC_SPL_MUL(a, B));
41     EXPECT_EQ(-2147483645, WEBRTC_SPL_MUL(a, b));
42     EXPECT_EQ(2147483651u, WEBRTC_SPL_UMUL(a, b));
43     b = WEBRTC_SPL_WORD16_MAX >> 1;
44     EXPECT_EQ(4294918147u, WEBRTC_SPL_UMUL_32_16(a, b));
45     EXPECT_EQ(-49149, WEBRTC_SPL_MUL_16_U16(a, b));
46 
47     a = b;
48     b = -3;
49 
50     EXPECT_EQ(-1, WEBRTC_SPL_MUL_16_32_RSFT16(a, b));
51     EXPECT_EQ(-1, WEBRTC_SPL_MUL_16_32_RSFT15(a, b));
52     EXPECT_EQ(-3, WEBRTC_SPL_MUL_16_32_RSFT14(a, b));
53     EXPECT_EQ(-24, WEBRTC_SPL_MUL_16_32_RSFT11(a, b));
54 
55     EXPECT_EQ(-12288, WEBRTC_SPL_MUL_16_16_RSFT(a, b, 2));
56     EXPECT_EQ(-12287, WEBRTC_SPL_MUL_16_16_RSFT_WITH_ROUND(a, b, 2));
57 
58     EXPECT_EQ(21, WEBRTC_SPL_SAT(a, A, B));
59     EXPECT_EQ(21, WEBRTC_SPL_SAT(a, B, A));
60 
61     // Shifting with negative numbers allowed
62     int shift_amount = 1;  // Workaround compiler warning using variable here.
63     // Positive means left shift
64     EXPECT_EQ(32766, WEBRTC_SPL_SHIFT_W32(a, shift_amount));
65 
66     // Shifting with negative numbers not allowed
67     // We cannot do casting here due to signed/unsigned problem
68     EXPECT_EQ(32766, WEBRTC_SPL_LSHIFT_W32(a, 1));
69 
70     EXPECT_EQ(8191u, WEBRTC_SPL_RSHIFT_U32(a, 1));
71 
72     EXPECT_EQ(1470, WEBRTC_SPL_RAND(A));
73 
74     EXPECT_EQ(-49149, WEBRTC_SPL_MUL_16_16(a, b));
75     EXPECT_EQ(1073676289, WEBRTC_SPL_MUL_16_16(WEBRTC_SPL_WORD16_MAX,
76                                                WEBRTC_SPL_WORD16_MAX));
77     EXPECT_EQ(1073709055, WEBRTC_SPL_MUL_16_32_RSFT16(WEBRTC_SPL_WORD16_MAX,
78                                                       WEBRTC_SPL_WORD32_MAX));
79     EXPECT_EQ(1073741824, WEBRTC_SPL_MUL_16_32_RSFT16(WEBRTC_SPL_WORD16_MIN,
80                                                       WEBRTC_SPL_WORD32_MIN));
81 #ifdef WEBRTC_ARCH_ARM_V7
82     EXPECT_EQ(-1073741824,
83               WEBRTC_SPL_MUL_16_32_RSFT16(WEBRTC_SPL_WORD16_MIN,
84                                           WEBRTC_SPL_WORD32_MAX));
85 #else
86     EXPECT_EQ(-1073741823,
87               WEBRTC_SPL_MUL_16_32_RSFT16(WEBRTC_SPL_WORD16_MIN,
88                                           WEBRTC_SPL_WORD32_MAX));
89 #endif
90 }
91 
TEST_F(SplTest,InlineTest)92 TEST_F(SplTest, InlineTest) {
93     int16_t a16 = 121;
94     int16_t b16 = -17;
95     int32_t a32 = 111121;
96     int32_t b32 = -1711;
97 
98     EXPECT_EQ(17, WebRtcSpl_GetSizeInBits(a32));
99 
100     EXPECT_EQ(0, WebRtcSpl_NormW32(0));
101     EXPECT_EQ(31, WebRtcSpl_NormW32(-1));
102     EXPECT_EQ(0, WebRtcSpl_NormW32(WEBRTC_SPL_WORD32_MIN));
103     EXPECT_EQ(14, WebRtcSpl_NormW32(a32));
104 
105     EXPECT_EQ(0, WebRtcSpl_NormW16(0));
106     EXPECT_EQ(15, WebRtcSpl_NormW16(-1));
107     EXPECT_EQ(0, WebRtcSpl_NormW16(WEBRTC_SPL_WORD16_MIN));
108     EXPECT_EQ(4, WebRtcSpl_NormW16(b32));
109     for (int ii = 0; ii < 15; ++ii) {
110       int16_t value = 1 << ii;
111       EXPECT_EQ(14 - ii, WebRtcSpl_NormW16(value));
112       EXPECT_EQ(15 - ii, WebRtcSpl_NormW16(-value));
113     }
114 
115     EXPECT_EQ(0, WebRtcSpl_NormU32(0u));
116     EXPECT_EQ(0, WebRtcSpl_NormU32(0xffffffff));
117     EXPECT_EQ(15, WebRtcSpl_NormU32(static_cast<uint32_t>(a32)));
118 
119     EXPECT_EQ(104, WebRtcSpl_AddSatW16(a16, b16));
120     EXPECT_EQ(138, WebRtcSpl_SubSatW16(a16, b16));
121 
122     EXPECT_EQ(109410, WebRtcSpl_AddSatW32(a32, b32));
123     EXPECT_EQ(112832, WebRtcSpl_SubSatW32(a32, b32));
124 
125     a32 = 0x80000000;
126     b32 = 0x80000000;
127     // Cast to signed int to avoid compiler complaint on gtest.h.
128     EXPECT_EQ(static_cast<int>(0x80000000), WebRtcSpl_AddSatW32(a32, b32));
129     a32 = 0x7fffffff;
130     b32 = 0x7fffffff;
131     EXPECT_EQ(0x7fffffff, WebRtcSpl_AddSatW32(a32, b32));
132     a32 = 0;
133     b32 = 0x80000000;
134     EXPECT_EQ(0x7fffffff, WebRtcSpl_SubSatW32(a32, b32));
135     a32 = 0x7fffffff;
136     b32 = 0x80000000;
137     EXPECT_EQ(0x7fffffff, WebRtcSpl_SubSatW32(a32, b32));
138     a32 = 0x80000000;
139     b32 = 0x7fffffff;
140     EXPECT_EQ(static_cast<int>(0x80000000), WebRtcSpl_SubSatW32(a32, b32));
141 }
142 
TEST_F(SplTest,MathOperationsTest)143 TEST_F(SplTest, MathOperationsTest) {
144     int A = 1134567892;
145     int32_t num = 117;
146     int32_t den = -5;
147     uint16_t denU = 5;
148     EXPECT_EQ(33700, WebRtcSpl_Sqrt(A));
149     EXPECT_EQ(33683, WebRtcSpl_SqrtFloor(A));
150 
151 
152     EXPECT_EQ(-91772805, WebRtcSpl_DivResultInQ31(den, num));
153     EXPECT_EQ(-23, WebRtcSpl_DivW32W16ResW16(num, (int16_t)den));
154     EXPECT_EQ(-23, WebRtcSpl_DivW32W16(num, (int16_t)den));
155     EXPECT_EQ(23u, WebRtcSpl_DivU32U16(num, denU));
156     EXPECT_EQ(0, WebRtcSpl_DivW32HiLow(128, 0, 256));
157 }
158 
TEST_F(SplTest,BasicArrayOperationsTest)159 TEST_F(SplTest, BasicArrayOperationsTest) {
160     const size_t kVectorSize = 4;
161     int B[] = {4, 12, 133, 1100};
162     int16_t b16[kVectorSize];
163     int32_t b32[kVectorSize];
164 
165     int16_t bTmp16[kVectorSize];
166     int32_t bTmp32[kVectorSize];
167 
168     WebRtcSpl_MemSetW16(b16, 3, kVectorSize);
169     for (size_t kk = 0; kk < kVectorSize; ++kk) {
170         EXPECT_EQ(3, b16[kk]);
171     }
172     WebRtcSpl_ZerosArrayW16(b16, kVectorSize);
173     for (size_t kk = 0; kk < kVectorSize; ++kk) {
174         EXPECT_EQ(0, b16[kk]);
175     }
176     WebRtcSpl_MemSetW32(b32, 3, kVectorSize);
177     for (size_t kk = 0; kk < kVectorSize; ++kk) {
178         EXPECT_EQ(3, b32[kk]);
179     }
180     WebRtcSpl_ZerosArrayW32(b32, kVectorSize);
181     for (size_t kk = 0; kk < kVectorSize; ++kk) {
182         EXPECT_EQ(0, b32[kk]);
183     }
184     for (size_t kk = 0; kk < kVectorSize; ++kk) {
185         bTmp16[kk] = (int16_t)kk;
186         bTmp32[kk] = (int32_t)kk;
187     }
188     WEBRTC_SPL_MEMCPY_W16(b16, bTmp16, kVectorSize);
189     for (size_t kk = 0; kk < kVectorSize; ++kk) {
190         EXPECT_EQ(b16[kk], bTmp16[kk]);
191     }
192 //    WEBRTC_SPL_MEMCPY_W32(b32, bTmp32, kVectorSize);
193 //    for (int kk = 0; kk < kVectorSize; ++kk) {
194 //        EXPECT_EQ(b32[kk], bTmp32[kk]);
195 //    }
196     WebRtcSpl_CopyFromEndW16(b16, kVectorSize, 2, bTmp16);
197     for (size_t kk = 0; kk < 2; ++kk) {
198         EXPECT_EQ(static_cast<int16_t>(kk+2), bTmp16[kk]);
199     }
200 
201     for (size_t kk = 0; kk < kVectorSize; ++kk) {
202         b32[kk] = B[kk];
203         b16[kk] = (int16_t)B[kk];
204     }
205     WebRtcSpl_VectorBitShiftW32ToW16(bTmp16, kVectorSize, b32, 1);
206     for (size_t kk = 0; kk < kVectorSize; ++kk) {
207         EXPECT_EQ((B[kk]>>1), bTmp16[kk]);
208     }
209     WebRtcSpl_VectorBitShiftW16(bTmp16, kVectorSize, b16, 1);
210     for (size_t kk = 0; kk < kVectorSize; ++kk) {
211         EXPECT_EQ((B[kk]>>1), bTmp16[kk]);
212     }
213     WebRtcSpl_VectorBitShiftW32(bTmp32, kVectorSize, b32, 1);
214     for (size_t kk = 0; kk < kVectorSize; ++kk) {
215         EXPECT_EQ((B[kk]>>1), bTmp32[kk]);
216     }
217 
218     WebRtcSpl_MemCpyReversedOrder(&bTmp16[3], b16, kVectorSize);
219     for (size_t kk = 0; kk < kVectorSize; ++kk) {
220         EXPECT_EQ(b16[3-kk], bTmp16[kk]);
221     }
222 }
223 
TEST_F(SplTest,MinMaxOperationsTest)224 TEST_F(SplTest, MinMaxOperationsTest) {
225   const size_t kVectorSize = 17;
226 
227   // Vectors to test the cases where minimum values have to be caught
228   // outside of the unrolled loops in ARM-Neon.
229   int16_t vector16[kVectorSize] = {-1, 7485, 0, 3333,
230       -18283, 0, 12334, -29871, 988, -3333,
231       345, -456, 222, 999,  888, 8774, WEBRTC_SPL_WORD16_MIN};
232   int32_t vector32[kVectorSize] = {-1, 0, 283211, 3333,
233       8712345, 0, -3333, 89345, -374585456, 222, 999, 122345334,
234       -12389756, -987329871, 888, -2, WEBRTC_SPL_WORD32_MIN};
235 
236   EXPECT_EQ(WEBRTC_SPL_WORD16_MIN,
237             WebRtcSpl_MinValueW16(vector16, kVectorSize));
238   EXPECT_EQ(WEBRTC_SPL_WORD32_MIN,
239             WebRtcSpl_MinValueW32(vector32, kVectorSize));
240   EXPECT_EQ(kVectorSize - 1, WebRtcSpl_MinIndexW16(vector16, kVectorSize));
241   EXPECT_EQ(kVectorSize - 1, WebRtcSpl_MinIndexW32(vector32, kVectorSize));
242 
243   // Test the cases where maximum values have to be caught
244   // outside of the unrolled loops in ARM-Neon.
245   vector16[kVectorSize - 1] = WEBRTC_SPL_WORD16_MAX;
246   vector32[kVectorSize - 1] = WEBRTC_SPL_WORD32_MAX;
247 
248   EXPECT_EQ(WEBRTC_SPL_WORD16_MAX,
249             WebRtcSpl_MaxAbsValueW16(vector16, kVectorSize));
250   EXPECT_EQ(WEBRTC_SPL_WORD16_MAX,
251             WebRtcSpl_MaxValueW16(vector16, kVectorSize));
252   EXPECT_EQ(WEBRTC_SPL_WORD32_MAX,
253             WebRtcSpl_MaxAbsValueW32(vector32, kVectorSize));
254   EXPECT_EQ(WEBRTC_SPL_WORD32_MAX,
255             WebRtcSpl_MaxValueW32(vector32, kVectorSize));
256   EXPECT_EQ(kVectorSize - 1, WebRtcSpl_MaxAbsIndexW16(vector16, kVectorSize));
257   EXPECT_EQ(kVectorSize - 1, WebRtcSpl_MaxIndexW16(vector16, kVectorSize));
258   EXPECT_EQ(kVectorSize - 1, WebRtcSpl_MaxIndexW32(vector32, kVectorSize));
259 
260   // Test the cases where multiple maximum and minimum values are present.
261   vector16[1] = WEBRTC_SPL_WORD16_MAX;
262   vector16[6] = WEBRTC_SPL_WORD16_MIN;
263   vector16[11] = WEBRTC_SPL_WORD16_MIN;
264   vector32[1] = WEBRTC_SPL_WORD32_MAX;
265   vector32[6] = WEBRTC_SPL_WORD32_MIN;
266   vector32[11] = WEBRTC_SPL_WORD32_MIN;
267 
268   EXPECT_EQ(WEBRTC_SPL_WORD16_MAX,
269             WebRtcSpl_MaxAbsValueW16(vector16, kVectorSize));
270   EXPECT_EQ(WEBRTC_SPL_WORD16_MAX,
271             WebRtcSpl_MaxValueW16(vector16, kVectorSize));
272   EXPECT_EQ(WEBRTC_SPL_WORD16_MIN,
273             WebRtcSpl_MinValueW16(vector16, kVectorSize));
274   EXPECT_EQ(WEBRTC_SPL_WORD32_MAX,
275             WebRtcSpl_MaxAbsValueW32(vector32, kVectorSize));
276   EXPECT_EQ(WEBRTC_SPL_WORD32_MAX,
277             WebRtcSpl_MaxValueW32(vector32, kVectorSize));
278   EXPECT_EQ(WEBRTC_SPL_WORD32_MIN,
279             WebRtcSpl_MinValueW32(vector32, kVectorSize));
280   EXPECT_EQ(6u, WebRtcSpl_MaxAbsIndexW16(vector16, kVectorSize));
281   EXPECT_EQ(1u, WebRtcSpl_MaxIndexW16(vector16, kVectorSize));
282   EXPECT_EQ(1u, WebRtcSpl_MaxIndexW32(vector32, kVectorSize));
283   EXPECT_EQ(6u, WebRtcSpl_MinIndexW16(vector16, kVectorSize));
284   EXPECT_EQ(6u, WebRtcSpl_MinIndexW32(vector32, kVectorSize));
285 }
286 
TEST_F(SplTest,VectorOperationsTest)287 TEST_F(SplTest, VectorOperationsTest) {
288     const size_t kVectorSize = 4;
289     int B[] = {4, 12, 133, 1100};
290     int16_t a16[kVectorSize];
291     int16_t b16[kVectorSize];
292     int16_t bTmp16[kVectorSize];
293 
294     for (size_t kk = 0; kk < kVectorSize; ++kk) {
295         a16[kk] = B[kk];
296         b16[kk] = B[kk];
297     }
298 
299     WebRtcSpl_AffineTransformVector(bTmp16, b16, 3, 7, 2, kVectorSize);
300     for (size_t kk = 0; kk < kVectorSize; ++kk) {
301         EXPECT_EQ((B[kk]*3+7)>>2, bTmp16[kk]);
302     }
303     WebRtcSpl_ScaleAndAddVectorsWithRound(b16, 3, b16, 2, 2, bTmp16, kVectorSize);
304     for (size_t kk = 0; kk < kVectorSize; ++kk) {
305         EXPECT_EQ((B[kk]*3+B[kk]*2+2)>>2, bTmp16[kk]);
306     }
307 
308     WebRtcSpl_AddAffineVectorToVector(bTmp16, b16, 3, 7, 2, kVectorSize);
309     for (size_t kk = 0; kk < kVectorSize; ++kk) {
310         EXPECT_EQ(((B[kk]*3+B[kk]*2+2)>>2)+((b16[kk]*3+7)>>2), bTmp16[kk]);
311     }
312 
313     WebRtcSpl_ScaleVector(b16, bTmp16, 13, kVectorSize, 2);
314     for (size_t kk = 0; kk < kVectorSize; ++kk) {
315         EXPECT_EQ((b16[kk]*13)>>2, bTmp16[kk]);
316     }
317     WebRtcSpl_ScaleVectorWithSat(b16, bTmp16, 13, kVectorSize, 2);
318     for (size_t kk = 0; kk < kVectorSize; ++kk) {
319         EXPECT_EQ((b16[kk]*13)>>2, bTmp16[kk]);
320     }
321     WebRtcSpl_ScaleAndAddVectors(a16, 13, 2, b16, 7, 2, bTmp16, kVectorSize);
322     for (size_t kk = 0; kk < kVectorSize; ++kk) {
323         EXPECT_EQ(((a16[kk]*13)>>2)+((b16[kk]*7)>>2), bTmp16[kk]);
324     }
325 
326     WebRtcSpl_AddVectorsAndShift(bTmp16, a16, b16, kVectorSize, 2);
327     for (size_t kk = 0; kk < kVectorSize; ++kk) {
328         EXPECT_EQ(B[kk] >> 1, bTmp16[kk]);
329     }
330     WebRtcSpl_ReverseOrderMultArrayElements(bTmp16, a16, &b16[3], kVectorSize, 2);
331     for (size_t kk = 0; kk < kVectorSize; ++kk) {
332         EXPECT_EQ((a16[kk]*b16[3-kk])>>2, bTmp16[kk]);
333     }
334     WebRtcSpl_ElementwiseVectorMult(bTmp16, a16, b16, kVectorSize, 6);
335     for (size_t kk = 0; kk < kVectorSize; ++kk) {
336         EXPECT_EQ((a16[kk]*b16[kk])>>6, bTmp16[kk]);
337     }
338 
339     WebRtcSpl_SqrtOfOneMinusXSquared(b16, kVectorSize, bTmp16);
340     for (size_t kk = 0; kk < kVectorSize - 1; ++kk) {
341         EXPECT_EQ(32767, bTmp16[kk]);
342     }
343     EXPECT_EQ(32749, bTmp16[kVectorSize - 1]);
344 
345     EXPECT_EQ(0, WebRtcSpl_GetScalingSquare(b16, kVectorSize, 1));
346 }
347 
TEST_F(SplTest,EstimatorsTest)348 TEST_F(SplTest, EstimatorsTest) {
349   const size_t kOrder = 2;
350   const int32_t unstable_filter[] = { 4, 12, 133, 1100 };
351   const int32_t stable_filter[] = { 1100, 133, 12, 4 };
352   int16_t lpc[kOrder + 2] = { 0 };
353   int16_t refl[kOrder + 2] = { 0 };
354   int16_t lpc_result[] = { 4096, -497, 15, 0 };
355   int16_t refl_result[] = { -3962, 123, 0, 0 };
356 
357   EXPECT_EQ(0, WebRtcSpl_LevinsonDurbin(unstable_filter, lpc, refl, kOrder));
358   EXPECT_EQ(1, WebRtcSpl_LevinsonDurbin(stable_filter, lpc, refl, kOrder));
359   for (size_t i = 0; i < kOrder + 2; ++i) {
360     EXPECT_EQ(lpc_result[i], lpc[i]);
361     EXPECT_EQ(refl_result[i], refl[i]);
362   }
363 }
364 
TEST_F(SplTest,FilterTest)365 TEST_F(SplTest, FilterTest) {
366     const size_t kVectorSize = 4;
367     const size_t kFilterOrder = 3;
368     int16_t A[] = {1, 2, 33, 100};
369     int16_t A5[] = {1, 2, 33, 100, -5};
370     int16_t B[] = {4, 12, 133, 110};
371     int16_t data_in[kVectorSize];
372     int16_t data_out[kVectorSize];
373     int16_t bTmp16Low[kVectorSize];
374     int16_t bState[kVectorSize];
375     int16_t bStateLow[kVectorSize];
376 
377     WebRtcSpl_ZerosArrayW16(bState, kVectorSize);
378     WebRtcSpl_ZerosArrayW16(bStateLow, kVectorSize);
379 
380     for (size_t kk = 0; kk < kVectorSize; ++kk) {
381         data_in[kk] = A[kk];
382         data_out[kk] = 0;
383     }
384 
385     // MA filters.
386     // Note that the input data has |kFilterOrder| states before the actual
387     // data (one sample).
388     WebRtcSpl_FilterMAFastQ12(&data_in[kFilterOrder], data_out, B,
389                               kFilterOrder + 1, 1);
390     EXPECT_EQ(0, data_out[0]);
391     // AR filters.
392     // Note that the output data has |kFilterOrder| states before the actual
393     // data (one sample).
394     WebRtcSpl_FilterARFastQ12(data_in, &data_out[kFilterOrder], A,
395                               kFilterOrder + 1, 1);
396     EXPECT_EQ(0, data_out[kFilterOrder]);
397 
398     EXPECT_EQ(kVectorSize, WebRtcSpl_FilterAR(A5,
399                                               5,
400                                               data_in,
401                                               kVectorSize,
402                                               bState,
403                                               kVectorSize,
404                                               bStateLow,
405                                               kVectorSize,
406                                               data_out,
407                                               bTmp16Low,
408                                               kVectorSize));
409 }
410 
TEST_F(SplTest,RandTest)411 TEST_F(SplTest, RandTest) {
412     const int kVectorSize = 4;
413     int16_t BU[] = {3653, 12446, 8525, 30691};
414     int16_t b16[kVectorSize];
415     uint32_t bSeed = 100000;
416 
417     EXPECT_EQ(7086, WebRtcSpl_RandU(&bSeed));
418     EXPECT_EQ(31565, WebRtcSpl_RandU(&bSeed));
419     EXPECT_EQ(-9786, WebRtcSpl_RandN(&bSeed));
420     EXPECT_EQ(kVectorSize, WebRtcSpl_RandUArray(b16, kVectorSize, &bSeed));
421     for (int kk = 0; kk < kVectorSize; ++kk) {
422         EXPECT_EQ(BU[kk], b16[kk]);
423     }
424 }
425 
TEST_F(SplTest,DotProductWithScaleTest)426 TEST_F(SplTest, DotProductWithScaleTest) {
427   EXPECT_EQ(605362796, WebRtcSpl_DotProductWithScale(vector16,
428       vector16, kVector16Size, 2));
429 }
430 
TEST_F(SplTest,CrossCorrelationTest)431 TEST_F(SplTest, CrossCorrelationTest) {
432   // Note the function arguments relation specificed by API.
433   const size_t kCrossCorrelationDimension = 3;
434   const int kShift = 2;
435   const int kStep = 1;
436   const size_t kSeqDimension = 6;
437 
438   const int16_t kVector16[kVector16Size] = {1, 4323, 1963,
439     WEBRTC_SPL_WORD16_MAX, WEBRTC_SPL_WORD16_MIN + 5, -3333, -876, 8483, 142};
440   int32_t vector32[kCrossCorrelationDimension] = {0};
441 
442   WebRtcSpl_CrossCorrelation(vector32, vector16, kVector16, kSeqDimension,
443                              kCrossCorrelationDimension, kShift, kStep);
444 
445   // WebRtcSpl_CrossCorrelationC() and WebRtcSpl_CrossCorrelationNeon()
446   // are not bit-exact.
447   const int32_t kExpected[kCrossCorrelationDimension] =
448       {-266947903, -15579555, -171282001};
449   const int32_t* expected = kExpected;
450 #if !defined(MIPS32_LE)
451   const int32_t kExpectedNeon[kCrossCorrelationDimension] =
452       {-266947901, -15579553, -171281999};
453   if (WebRtcSpl_CrossCorrelation != WebRtcSpl_CrossCorrelationC) {
454     expected = kExpectedNeon;
455   }
456 #endif
457   for (size_t i = 0; i < kCrossCorrelationDimension; ++i) {
458     EXPECT_EQ(expected[i], vector32[i]);
459   }
460 }
461 
TEST_F(SplTest,AutoCorrelationTest)462 TEST_F(SplTest, AutoCorrelationTest) {
463   int scale = 0;
464   int32_t vector32[kVector16Size];
465   const int32_t expected[kVector16Size] = {302681398, 14223410, -121705063,
466     -85221647, -17104971, 61806945, 6644603, -669329, 43};
467 
468   EXPECT_EQ(kVector16Size,
469             WebRtcSpl_AutoCorrelation(vector16, kVector16Size,
470                                       kVector16Size - 1, vector32, &scale));
471   EXPECT_EQ(3, scale);
472   for (size_t i = 0; i < kVector16Size; ++i) {
473     EXPECT_EQ(expected[i], vector32[i]);
474   }
475 }
476 
TEST_F(SplTest,SignalProcessingTest)477 TEST_F(SplTest, SignalProcessingTest) {
478     const size_t kVectorSize = 4;
479     int A[] = {1, 2, 33, 100};
480     const int16_t kHanning[4] = { 2399, 8192, 13985, 16384 };
481     int16_t b16[kVectorSize];
482 
483     int16_t bTmp16[kVectorSize];
484 
485     int bScale = 0;
486 
487     for (size_t kk = 0; kk < kVectorSize; ++kk) {
488         b16[kk] = A[kk];
489     }
490 
491     // TODO(bjornv): Activate the Reflection Coefficient tests when refactoring.
492 //    WebRtcSpl_ReflCoefToLpc(b16, kVectorSize, bTmp16);
493 ////    for (int kk = 0; kk < kVectorSize; ++kk) {
494 ////        EXPECT_EQ(aTmp16[kk], bTmp16[kk]);
495 ////    }
496 //    WebRtcSpl_LpcToReflCoef(bTmp16, kVectorSize, b16);
497 ////    for (int kk = 0; kk < kVectorSize; ++kk) {
498 ////        EXPECT_EQ(a16[kk], b16[kk]);
499 ////    }
500 //    WebRtcSpl_AutoCorrToReflCoef(b32, kVectorSize, bTmp16);
501 ////    for (int kk = 0; kk < kVectorSize; ++kk) {
502 ////        EXPECT_EQ(aTmp16[kk], bTmp16[kk]);
503 ////    }
504 
505     WebRtcSpl_GetHanningWindow(bTmp16, kVectorSize);
506     for (size_t kk = 0; kk < kVectorSize; ++kk) {
507         EXPECT_EQ(kHanning[kk], bTmp16[kk]);
508     }
509 
510     for (size_t kk = 0; kk < kVectorSize; ++kk) {
511         b16[kk] = A[kk];
512     }
513     EXPECT_EQ(11094 , WebRtcSpl_Energy(b16, kVectorSize, &bScale));
514     EXPECT_EQ(0, bScale);
515 }
516 
TEST_F(SplTest,FFTTest)517 TEST_F(SplTest, FFTTest) {
518     int16_t B[] = {1, 2, 33, 100,
519             2, 3, 34, 101,
520             3, 4, 35, 102,
521             4, 5, 36, 103};
522 
523     EXPECT_EQ(0, WebRtcSpl_ComplexFFT(B, 3, 1));
524 //    for (int kk = 0; kk < 16; ++kk) {
525 //        EXPECT_EQ(A[kk], B[kk]);
526 //    }
527     EXPECT_EQ(0, WebRtcSpl_ComplexIFFT(B, 3, 1));
528 //    for (int kk = 0; kk < 16; ++kk) {
529 //        EXPECT_EQ(A[kk], B[kk]);
530 //    }
531     WebRtcSpl_ComplexBitReverse(B, 3);
532     for (int kk = 0; kk < 16; ++kk) {
533         //EXPECT_EQ(A[kk], B[kk]);
534     }
535 }
536 
TEST_F(SplTest,Resample48WithSaturationTest)537 TEST_F(SplTest, Resample48WithSaturationTest) {
538   // The test resamples 3*kBlockSize number of samples to 2*kBlockSize number
539   // of samples.
540   const size_t kBlockSize = 16;
541 
542   // Saturated input vector of 48 samples.
543   const int32_t kVectorSaturated[3 * kBlockSize + 7] = {
544      -32768, -32768, -32768, -32768, -32768, -32768, -32768, -32768,
545      -32768, -32768, -32768, -32768, -32768, -32768, -32768, -32768,
546      -32768, -32768, -32768, -32768, -32768, -32768, -32768, -32768,
547      32767, 32767, 32767, 32767, 32767, 32767, 32767, 32767,
548      32767, 32767, 32767, 32767, 32767, 32767, 32767, 32767,
549      32767, 32767, 32767, 32767, 32767, 32767, 32767, 32767,
550      32767, 32767, 32767, 32767, 32767, 32767, 32767
551   };
552 
553   // All values in |out_vector| should be |kRefValue32kHz|.
554   const int32_t kRefValue32kHz1 = -1077493760;
555   const int32_t kRefValue32kHz2 = 1077493645;
556 
557   // After bit shift with saturation, |out_vector_w16| is saturated.
558 
559   const int16_t kRefValue16kHz1 = -32768;
560   const int16_t kRefValue16kHz2 = 32767;
561   // Vector for storing output.
562   int32_t out_vector[2 * kBlockSize];
563   int16_t out_vector_w16[2 * kBlockSize];
564 
565   WebRtcSpl_Resample48khzTo32khz(kVectorSaturated, out_vector, kBlockSize);
566   WebRtcSpl_VectorBitShiftW32ToW16(out_vector_w16, 2 * kBlockSize, out_vector,
567                                    15);
568 
569   // Comparing output values against references. The values at position
570   // 12-15 are skipped to account for the filter lag.
571   for (size_t i = 0; i < 12; ++i) {
572     EXPECT_EQ(kRefValue32kHz1, out_vector[i]);
573     EXPECT_EQ(kRefValue16kHz1, out_vector_w16[i]);
574   }
575   for (size_t i = 16; i < 2 * kBlockSize; ++i) {
576     EXPECT_EQ(kRefValue32kHz2, out_vector[i]);
577     EXPECT_EQ(kRefValue16kHz2, out_vector_w16[i]);
578   }
579 }
580