OLD | NEW |
1 /* | 1 /* |
2 * Copyright (c) 2017 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2017 The WebRTC project authors. All Rights Reserved. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license | 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 | 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 | 6 * tree. An additional intellectual property rights grant can be found |
7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
9 */ | 9 */ |
10 | 10 |
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
46 TEST(RenderDelayController, NoRenderSignal) { | 46 TEST(RenderDelayController, NoRenderSignal) { |
47 std::vector<float> block(kBlockSize, 0.f); | 47 std::vector<float> block(kBlockSize, 0.f); |
48 for (auto rate : {8000, 16000, 32000, 48000}) { | 48 for (auto rate : {8000, 16000, 32000, 48000}) { |
49 SCOPED_TRACE(ProduceDebugText(rate)); | 49 SCOPED_TRACE(ProduceDebugText(rate)); |
50 std::unique_ptr<RenderDelayBuffer> delay_buffer( | 50 std::unique_ptr<RenderDelayBuffer> delay_buffer( |
51 RenderDelayBuffer::Create(NumBandsForRate(rate))); | 51 RenderDelayBuffer::Create(NumBandsForRate(rate))); |
52 std::unique_ptr<RenderDelayController> delay_controller( | 52 std::unique_ptr<RenderDelayController> delay_controller( |
53 RenderDelayController::Create(AudioProcessing::Config::EchoCanceller3(), | 53 RenderDelayController::Create(AudioProcessing::Config::EchoCanceller3(), |
54 rate)); | 54 rate)); |
55 for (size_t k = 0; k < 100; ++k) { | 55 for (size_t k = 0; k < 100; ++k) { |
56 EXPECT_EQ(0u, delay_controller->GetDelay( | 56 EXPECT_EQ(kMinEchoPathDelayBlocks, |
57 delay_buffer->GetDownsampledRenderBuffer(), block)); | 57 delay_controller->GetDelay( |
| 58 delay_buffer->GetDownsampledRenderBuffer(), block)); |
58 } | 59 } |
59 } | 60 } |
60 } | 61 } |
61 | 62 |
62 // Verifies the basic API call sequence. | 63 // Verifies the basic API call sequence. |
63 TEST(RenderDelayController, BasicApiCalls) { | 64 TEST(RenderDelayController, BasicApiCalls) { |
64 std::vector<float> capture_block(kBlockSize, 0.f); | 65 std::vector<float> capture_block(kBlockSize, 0.f); |
65 size_t delay_blocks = 0; | 66 size_t delay_blocks = 0; |
66 for (auto rate : {8000, 16000, 32000, 48000}) { | 67 for (auto rate : {8000, 16000, 32000, 48000}) { |
67 std::vector<std::vector<float>> render_block( | 68 std::vector<std::vector<float>> render_block( |
68 NumBandsForRate(rate), std::vector<float>(kBlockSize, 0.f)); | 69 NumBandsForRate(rate), std::vector<float>(kBlockSize, 0.f)); |
69 std::unique_ptr<RenderDelayBuffer> render_delay_buffer( | 70 std::unique_ptr<RenderDelayBuffer> render_delay_buffer( |
70 RenderDelayBuffer::Create(NumBandsForRate(rate))); | 71 RenderDelayBuffer::Create(NumBandsForRate(rate))); |
71 std::unique_ptr<RenderDelayController> delay_controller( | 72 std::unique_ptr<RenderDelayController> delay_controller( |
72 RenderDelayController::Create(AudioProcessing::Config::EchoCanceller3(), | 73 RenderDelayController::Create(AudioProcessing::Config::EchoCanceller3(), |
73 rate)); | 74 rate)); |
74 for (size_t k = 0; k < 10; ++k) { | 75 for (size_t k = 0; k < 10; ++k) { |
75 render_delay_buffer->Insert(render_block); | 76 render_delay_buffer->Insert(render_block); |
76 render_delay_buffer->UpdateBuffers(); | 77 render_delay_buffer->UpdateBuffers(); |
77 delay_blocks = delay_controller->GetDelay( | 78 delay_blocks = delay_controller->GetDelay( |
78 render_delay_buffer->GetDownsampledRenderBuffer(), capture_block); | 79 render_delay_buffer->GetDownsampledRenderBuffer(), capture_block); |
79 } | 80 } |
80 EXPECT_FALSE(delay_controller->AlignmentHeadroomSamples()); | 81 EXPECT_FALSE(delay_controller->AlignmentHeadroomSamples()); |
81 EXPECT_EQ(0u, delay_blocks); | 82 EXPECT_EQ(kMinEchoPathDelayBlocks, delay_blocks); |
82 } | 83 } |
83 } | 84 } |
84 | 85 |
85 // Verifies that the RenderDelayController is able to align the signals for | 86 // Verifies that the RenderDelayController is able to align the signals for |
86 // simple timeshifts between the signals. | 87 // simple timeshifts between the signals. |
87 TEST(RenderDelayController, Alignment) { | 88 TEST(RenderDelayController, Alignment) { |
88 Random random_generator(42U); | 89 Random random_generator(42U); |
89 std::vector<float> capture_block(kBlockSize, 0.f); | 90 std::vector<float> capture_block(kBlockSize, 0.f); |
90 size_t delay_blocks = 0; | 91 size_t delay_blocks = 0; |
91 for (auto rate : {8000, 16000, 32000, 48000}) { | 92 for (auto rate : {8000, 16000, 32000, 48000}) { |
(...skipping 14 matching lines...) Expand all Loading... |
106 render_delay_buffer->Insert(render_block); | 107 render_delay_buffer->Insert(render_block); |
107 render_delay_buffer->UpdateBuffers(); | 108 render_delay_buffer->UpdateBuffers(); |
108 delay_blocks = delay_controller->GetDelay( | 109 delay_blocks = delay_controller->GetDelay( |
109 render_delay_buffer->GetDownsampledRenderBuffer(), capture_block); | 110 render_delay_buffer->GetDownsampledRenderBuffer(), capture_block); |
110 } | 111 } |
111 | 112 |
112 constexpr int kDelayHeadroomBlocks = 1; | 113 constexpr int kDelayHeadroomBlocks = 1; |
113 size_t expected_delay_blocks = | 114 size_t expected_delay_blocks = |
114 std::max(0, static_cast<int>(delay_samples / kBlockSize) - | 115 std::max(0, static_cast<int>(delay_samples / kBlockSize) - |
115 kDelayHeadroomBlocks); | 116 kDelayHeadroomBlocks); |
116 if (expected_delay_blocks < 2) { | |
117 expected_delay_blocks = 0; | |
118 } | |
119 | 117 |
120 EXPECT_EQ(expected_delay_blocks, delay_blocks); | 118 EXPECT_EQ(expected_delay_blocks, delay_blocks); |
121 | 119 |
122 const rtc::Optional<size_t> headroom_samples = | 120 const rtc::Optional<size_t> headroom_samples = |
123 delay_controller->AlignmentHeadroomSamples(); | 121 delay_controller->AlignmentHeadroomSamples(); |
124 ASSERT_TRUE(headroom_samples); | 122 ASSERT_TRUE(headroom_samples); |
125 EXPECT_NEAR(delay_samples - delay_blocks * kBlockSize, *headroom_samples, | 123 EXPECT_NEAR(delay_samples - delay_blocks * kBlockSize, *headroom_samples, |
126 4); | 124 4); |
127 } | 125 } |
128 } | 126 } |
(...skipping 99 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
228 EXPECT_DEATH( | 226 EXPECT_DEATH( |
229 std::unique_ptr<RenderDelayController>(RenderDelayController::Create( | 227 std::unique_ptr<RenderDelayController>(RenderDelayController::Create( |
230 AudioProcessing::Config::EchoCanceller3(), rate)), | 228 AudioProcessing::Config::EchoCanceller3(), rate)), |
231 ""); | 229 ""); |
232 } | 230 } |
233 } | 231 } |
234 | 232 |
235 #endif | 233 #endif |
236 | 234 |
237 } // namespace webrtc | 235 } // namespace webrtc |
OLD | NEW |