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 <stdlib.h>
12
13 #include "testing/gtest/include/gtest/gtest.h"
14 #include "webrtc/common_audio/vad/vad_unittest.h"
15 #include "webrtc/typedefs.h"
16
17 extern "C" {
18 #include "webrtc/common_audio/vad/vad_core.h"
19 }
20
21 namespace {
22
TEST_F(VadTest,InitCore)23 TEST_F(VadTest, InitCore) {
24 // Test WebRtcVad_InitCore().
25 VadInstT* self = reinterpret_cast<VadInstT*>(malloc(sizeof(VadInstT)));
26
27 // NULL pointer test.
28 EXPECT_EQ(-1, WebRtcVad_InitCore(NULL));
29
30 // Verify return = 0 for non-NULL pointer.
31 EXPECT_EQ(0, WebRtcVad_InitCore(self));
32 // Verify init_flag is set.
33 EXPECT_EQ(42, self->init_flag);
34
35 free(self);
36 }
37
TEST_F(VadTest,set_mode_core)38 TEST_F(VadTest, set_mode_core) {
39 VadInstT* self = reinterpret_cast<VadInstT*>(malloc(sizeof(VadInstT)));
40
41 // TODO(bjornv): Add NULL pointer check if we take care of it in
42 // vad_core.c
43
44 ASSERT_EQ(0, WebRtcVad_InitCore(self));
45 // Test WebRtcVad_set_mode_core().
46 // Invalid modes should return -1.
47 EXPECT_EQ(-1, WebRtcVad_set_mode_core(self, -1));
48 EXPECT_EQ(-1, WebRtcVad_set_mode_core(self, 1000));
49 // Valid modes should return 0.
50 for (size_t j = 0; j < kModesSize; ++j) {
51 EXPECT_EQ(0, WebRtcVad_set_mode_core(self, kModes[j]));
52 }
53
54 free(self);
55 }
56
TEST_F(VadTest,CalcVad)57 TEST_F(VadTest, CalcVad) {
58 VadInstT* self = reinterpret_cast<VadInstT*>(malloc(sizeof(VadInstT)));
59 int16_t speech[kMaxFrameLength];
60
61 // TODO(bjornv): Add NULL pointer check if we take care of it in
62 // vad_core.c
63
64 // Test WebRtcVad_CalcVadXXkhz()
65 // Verify that all zeros in gives VAD = 0 out.
66 memset(speech, 0, sizeof(speech));
67 ASSERT_EQ(0, WebRtcVad_InitCore(self));
68 for (size_t j = 0; j < kFrameLengthsSize; ++j) {
69 if (ValidRatesAndFrameLengths(8000, kFrameLengths[j])) {
70 EXPECT_EQ(0, WebRtcVad_CalcVad8khz(self, speech, kFrameLengths[j]));
71 }
72 if (ValidRatesAndFrameLengths(16000, kFrameLengths[j])) {
73 EXPECT_EQ(0, WebRtcVad_CalcVad16khz(self, speech, kFrameLengths[j]));
74 }
75 if (ValidRatesAndFrameLengths(32000, kFrameLengths[j])) {
76 EXPECT_EQ(0, WebRtcVad_CalcVad32khz(self, speech, kFrameLengths[j]));
77 }
78 if (ValidRatesAndFrameLengths(48000, kFrameLengths[j])) {
79 EXPECT_EQ(0, WebRtcVad_CalcVad48khz(self, speech, kFrameLengths[j]));
80 }
81 }
82
83 // Construct a speech signal that will trigger the VAD in all modes. It is
84 // known that (i * i) will wrap around, but that doesn't matter in this case.
85 for (size_t i = 0; i < kMaxFrameLength; ++i) {
86 speech[i] = static_cast<int16_t>(i * i);
87 }
88 for (size_t j = 0; j < kFrameLengthsSize; ++j) {
89 if (ValidRatesAndFrameLengths(8000, kFrameLengths[j])) {
90 EXPECT_EQ(1, WebRtcVad_CalcVad8khz(self, speech, kFrameLengths[j]));
91 }
92 if (ValidRatesAndFrameLengths(16000, kFrameLengths[j])) {
93 EXPECT_EQ(1, WebRtcVad_CalcVad16khz(self, speech, kFrameLengths[j]));
94 }
95 if (ValidRatesAndFrameLengths(32000, kFrameLengths[j])) {
96 EXPECT_EQ(1, WebRtcVad_CalcVad32khz(self, speech, kFrameLengths[j]));
97 }
98 if (ValidRatesAndFrameLengths(48000, kFrameLengths[j])) {
99 EXPECT_EQ(1, WebRtcVad_CalcVad48khz(self, speech, kFrameLengths[j]));
100 }
101 }
102
103 free(self);
104 }
105 } // namespace
106