Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1326)

Side by Side Diff: webrtc/modules/audio_processing/aec/system_delay_unittest.cc

Issue 1211053006: Rename APM Config ReportedDelay to DelayAgnostic (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Fix error in android test Created 5 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2012 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 118 matching lines...) Expand 10 before | Expand all | Expand 10 after
129 } 129 }
130 return buffer_size; 130 return buffer_size;
131 } 131 }
132 132
133 void SystemDelayTest::RunStableStartup() { 133 void SystemDelayTest::RunStableStartup() {
134 // To make sure we have a full buffer when we verify stability we first fill 134 // To make sure we have a full buffer when we verify stability we first fill
135 // up the far-end buffer with the same amount as we will report in through 135 // up the far-end buffer with the same amount as we will report in through
136 // Process(). 136 // Process().
137 int buffer_size = BufferFillUp(); 137 int buffer_size = BufferFillUp();
138 138
139 if (WebRtcAec_reported_delay_enabled(self_->aec) == 0) { 139 if (WebRtcAec_delay_agnostic_enabled(self_->aec) == 1) {
140 // In extended_filter mode we set the buffer size after the first processed 140 // In extended_filter mode we set the buffer size after the first processed
141 // 10 ms chunk. Hence, we don't need to wait for the reported system delay 141 // 10 ms chunk. Hence, we don't need to wait for the reported system delay
142 // values to become stable. 142 // values to become stable.
143 RenderAndCapture(kDeviceBufMs); 143 RenderAndCapture(kDeviceBufMs);
144 buffer_size += samples_per_frame_; 144 buffer_size += samples_per_frame_;
145 EXPECT_EQ(0, self_->startup_phase); 145 EXPECT_EQ(0, self_->startup_phase);
146 } else { 146 } else {
147 // A stable device should be accepted and put in a regular process mode 147 // A stable device should be accepted and put in a regular process mode
148 // within |kStableConvergenceMs|. 148 // within |kStableConvergenceMs|.
149 int process_time_ms = 0; 149 int process_time_ms = 0;
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after
191 // 8) The system delay should never become negative. 191 // 8) The system delay should never become negative.
192 192
193 TEST_F(SystemDelayTest, CorrectIncreaseWhenBufferFarend) { 193 TEST_F(SystemDelayTest, CorrectIncreaseWhenBufferFarend) {
194 // When we add data to the AEC buffer the internal system delay should be 194 // When we add data to the AEC buffer the internal system delay should be
195 // incremented with the same amount as the size of data. 195 // incremented with the same amount as the size of data.
196 // This process should be independent of DA-AEC and extended_filter mode. 196 // This process should be independent of DA-AEC and extended_filter mode.
197 for (int extended_filter = 0; extended_filter <= 1; ++extended_filter) { 197 for (int extended_filter = 0; extended_filter <= 1; ++extended_filter) {
198 WebRtcAec_enable_extended_filter(self_->aec, extended_filter); 198 WebRtcAec_enable_extended_filter(self_->aec, extended_filter);
199 EXPECT_EQ(extended_filter, WebRtcAec_extended_filter_enabled(self_->aec)); 199 EXPECT_EQ(extended_filter, WebRtcAec_extended_filter_enabled(self_->aec));
200 for (int da_aec = 0; da_aec <= 1; ++da_aec) { 200 for (int da_aec = 0; da_aec <= 1; ++da_aec) {
201 WebRtcAec_enable_reported_delay(self_->aec, 1 - da_aec); 201 WebRtcAec_enable_delay_agnostic(self_->aec, da_aec);
202 EXPECT_EQ(1 - da_aec, WebRtcAec_reported_delay_enabled(self_->aec)); 202 EXPECT_EQ(da_aec, WebRtcAec_delay_agnostic_enabled(self_->aec));
203 for (size_t i = 0; i < kNumSampleRates; i++) { 203 for (size_t i = 0; i < kNumSampleRates; i++) {
204 Init(kSampleRateHz[i]); 204 Init(kSampleRateHz[i]);
205 // Loop through a couple of calls to make sure the system delay 205 // Loop through a couple of calls to make sure the system delay
206 // increments correctly. 206 // increments correctly.
207 for (int j = 1; j <= 5; j++) { 207 for (int j = 1; j <= 5; j++) {
208 EXPECT_EQ(0, 208 EXPECT_EQ(0,
209 WebRtcAec_BufferFarend(handle_, far_, samples_per_frame_)); 209 WebRtcAec_BufferFarend(handle_, far_, samples_per_frame_));
210 EXPECT_EQ(j * samples_per_frame_, WebRtcAec_system_delay(self_->aec)); 210 EXPECT_EQ(j * samples_per_frame_, WebRtcAec_system_delay(self_->aec));
211 } 211 }
212 } 212 }
213 } 213 }
214 } 214 }
215 } 215 }
216 216
217 // TODO(bjornv): Add a test to verify behavior if the far-end buffer is full 217 // TODO(bjornv): Add a test to verify behavior if the far-end buffer is full
218 // when adding new data. 218 // when adding new data.
219 219
220 TEST_F(SystemDelayTest, CorrectDelayAfterStableStartup) { 220 TEST_F(SystemDelayTest, CorrectDelayAfterStableStartup) {
221 // We run the system in a stable startup. After that we verify that the system 221 // We run the system in a stable startup. After that we verify that the system
222 // delay meets the requirements. 222 // delay meets the requirements.
223 // This process should be independent of DA-AEC and extended_filter mode. 223 // This process should be independent of DA-AEC and extended_filter mode.
224 for (int extended_filter = 0; extended_filter <= 1; ++extended_filter) { 224 for (int extended_filter = 0; extended_filter <= 1; ++extended_filter) {
225 WebRtcAec_enable_extended_filter(self_->aec, extended_filter); 225 WebRtcAec_enable_extended_filter(self_->aec, extended_filter);
226 EXPECT_EQ(extended_filter, WebRtcAec_extended_filter_enabled(self_->aec)); 226 EXPECT_EQ(extended_filter, WebRtcAec_extended_filter_enabled(self_->aec));
227 for (int da_aec = 0; da_aec <= 1; ++da_aec) { 227 for (int da_aec = 0; da_aec <= 1; ++da_aec) {
228 WebRtcAec_enable_reported_delay(self_->aec, 1 - da_aec); 228 WebRtcAec_enable_delay_agnostic(self_->aec, da_aec);
229 EXPECT_EQ(1 - da_aec, WebRtcAec_reported_delay_enabled(self_->aec)); 229 EXPECT_EQ(da_aec, WebRtcAec_delay_agnostic_enabled(self_->aec));
230 for (size_t i = 0; i < kNumSampleRates; i++) { 230 for (size_t i = 0; i < kNumSampleRates; i++) {
231 Init(kSampleRateHz[i]); 231 Init(kSampleRateHz[i]);
232 RunStableStartup(); 232 RunStableStartup();
233 233
234 // Verify system delay with respect to requirements, i.e., the 234 // Verify system delay with respect to requirements, i.e., the
235 // |system_delay| is in the interval [75%, 100%] of what's reported on 235 // |system_delay| is in the interval [75%, 100%] of what's reported on
236 // the average. 236 // the average.
237 // In extended_filter mode we target 50% and measure after one processed 237 // In extended_filter mode we target 50% and measure after one processed
238 // 10 ms chunk. 238 // 10 ms chunk.
239 int average_reported_delay = kDeviceBufMs * samples_per_frame_ / 10; 239 int average_reported_delay = kDeviceBufMs * samples_per_frame_ / 10;
240 EXPECT_GE(average_reported_delay, WebRtcAec_system_delay(self_->aec)); 240 EXPECT_GE(average_reported_delay, WebRtcAec_system_delay(self_->aec));
241 int lower_bound = WebRtcAec_extended_filter_enabled(self_->aec) 241 int lower_bound = WebRtcAec_extended_filter_enabled(self_->aec)
242 ? average_reported_delay / 2 - samples_per_frame_ 242 ? average_reported_delay / 2 - samples_per_frame_
243 : average_reported_delay * 3 / 4; 243 : average_reported_delay * 3 / 4;
244 EXPECT_LE(lower_bound, WebRtcAec_system_delay(self_->aec)); 244 EXPECT_LE(lower_bound, WebRtcAec_system_delay(self_->aec));
245 } 245 }
246 } 246 }
247 } 247 }
248 } 248 }
249 249
250 TEST_F(SystemDelayTest, CorrectDelayAfterUnstableStartup) { 250 TEST_F(SystemDelayTest, CorrectDelayAfterUnstableStartup) {
251 // This test does not apply in extended_filter mode, since we only use the 251 // This test does not apply in extended_filter mode, since we only use the
252 // the first 10 ms chunk to determine a reasonable buffer size. Neither does 252 // the first 10 ms chunk to determine a reasonable buffer size. Neither does
253 // it apply if DA-AEC is on because that overrides the startup procedure. 253 // it apply if DA-AEC is on because that overrides the startup procedure.
254 WebRtcAec_enable_extended_filter(self_->aec, 0); 254 WebRtcAec_enable_extended_filter(self_->aec, 0);
255 EXPECT_EQ(0, WebRtcAec_extended_filter_enabled(self_->aec)); 255 EXPECT_EQ(0, WebRtcAec_extended_filter_enabled(self_->aec));
256 WebRtcAec_enable_reported_delay(self_->aec, 1); 256 WebRtcAec_enable_delay_agnostic(self_->aec, 0);
257 EXPECT_EQ(1, WebRtcAec_reported_delay_enabled(self_->aec)); 257 EXPECT_EQ(0, WebRtcAec_delay_agnostic_enabled(self_->aec));
258 258
259 // In an unstable system we would start processing after |kMaxConvergenceMs|. 259 // In an unstable system we would start processing after |kMaxConvergenceMs|.
260 // On the last frame the AEC buffer is adjusted to 60% of the last reported 260 // On the last frame the AEC buffer is adjusted to 60% of the last reported
261 // device buffer size. 261 // device buffer size.
262 // We construct an unstable system by altering the device buffer size between 262 // We construct an unstable system by altering the device buffer size between
263 // two values |kDeviceBufMs| +- 25 ms. 263 // two values |kDeviceBufMs| +- 25 ms.
264 for (size_t i = 0; i < kNumSampleRates; i++) { 264 for (size_t i = 0; i < kNumSampleRates; i++) {
265 Init(kSampleRateHz[i]); 265 Init(kSampleRateHz[i]);
266 266
267 // To make sure we have a full buffer when we verify stability we first fill 267 // To make sure we have a full buffer when we verify stability we first fill
(...skipping 27 matching lines...) Expand all
295 WebRtcAec_system_delay(self_->aec)); 295 WebRtcAec_system_delay(self_->aec));
296 } 296 }
297 } 297 }
298 298
299 TEST_F(SystemDelayTest, CorrectDelayAfterStableBufferBuildUp) { 299 TEST_F(SystemDelayTest, CorrectDelayAfterStableBufferBuildUp) {
300 // This test does not apply in extended_filter mode, since we only use the 300 // This test does not apply in extended_filter mode, since we only use the
301 // the first 10 ms chunk to determine a reasonable buffer size. Neither does 301 // the first 10 ms chunk to determine a reasonable buffer size. Neither does
302 // it apply if DA-AEC is on because that overrides the startup procedure. 302 // it apply if DA-AEC is on because that overrides the startup procedure.
303 WebRtcAec_enable_extended_filter(self_->aec, 0); 303 WebRtcAec_enable_extended_filter(self_->aec, 0);
304 EXPECT_EQ(0, WebRtcAec_extended_filter_enabled(self_->aec)); 304 EXPECT_EQ(0, WebRtcAec_extended_filter_enabled(self_->aec));
305 WebRtcAec_enable_reported_delay(self_->aec, 1); 305 WebRtcAec_enable_delay_agnostic(self_->aec, 0);
306 EXPECT_EQ(1, WebRtcAec_reported_delay_enabled(self_->aec)); 306 EXPECT_EQ(0, WebRtcAec_delay_agnostic_enabled(self_->aec));
307 307
308 // In this test we start by establishing the device buffer size during stable 308 // In this test we start by establishing the device buffer size during stable
309 // conditions, but with an empty internal far-end buffer. Once that is done we 309 // conditions, but with an empty internal far-end buffer. Once that is done we
310 // verify that the system delay is increased correctly until we have reach an 310 // verify that the system delay is increased correctly until we have reach an
311 // internal buffer size of 75% of what's been reported. 311 // internal buffer size of 75% of what's been reported.
312 for (size_t i = 0; i < kNumSampleRates; i++) { 312 for (size_t i = 0; i < kNumSampleRates; i++) {
313 Init(kSampleRateHz[i]); 313 Init(kSampleRateHz[i]);
314 314
315 // We assume that running |kStableConvergenceMs| calls will put the 315 // We assume that running |kStableConvergenceMs| calls will put the
316 // algorithm in a state where the device buffer size has been determined. We 316 // algorithm in a state where the device buffer size has been determined. We
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after
360 TEST_F(SystemDelayTest, CorrectDelayWhenBufferUnderrun) { 360 TEST_F(SystemDelayTest, CorrectDelayWhenBufferUnderrun) {
361 // Here we test a buffer under run scenario. If we keep on calling 361 // Here we test a buffer under run scenario. If we keep on calling
362 // WebRtcAec_Process() we will finally run out of data, but should 362 // WebRtcAec_Process() we will finally run out of data, but should
363 // automatically stuff the buffer. We verify this behavior by checking if the 363 // automatically stuff the buffer. We verify this behavior by checking if the
364 // system delay goes negative. 364 // system delay goes negative.
365 // This process should be independent of DA-AEC and extended_filter mode. 365 // This process should be independent of DA-AEC and extended_filter mode.
366 for (int extended_filter = 0; extended_filter <= 1; ++extended_filter) { 366 for (int extended_filter = 0; extended_filter <= 1; ++extended_filter) {
367 WebRtcAec_enable_extended_filter(self_->aec, extended_filter); 367 WebRtcAec_enable_extended_filter(self_->aec, extended_filter);
368 EXPECT_EQ(extended_filter, WebRtcAec_extended_filter_enabled(self_->aec)); 368 EXPECT_EQ(extended_filter, WebRtcAec_extended_filter_enabled(self_->aec));
369 for (int da_aec = 0; da_aec <= 1; ++da_aec) { 369 for (int da_aec = 0; da_aec <= 1; ++da_aec) {
370 WebRtcAec_enable_reported_delay(self_->aec, 1 - da_aec); 370 WebRtcAec_enable_delay_agnostic(self_->aec, da_aec);
371 EXPECT_EQ(1 - da_aec, WebRtcAec_reported_delay_enabled(self_->aec)); 371 EXPECT_EQ(da_aec, WebRtcAec_delay_agnostic_enabled(self_->aec));
372 for (size_t i = 0; i < kNumSampleRates; i++) { 372 for (size_t i = 0; i < kNumSampleRates; i++) {
373 Init(kSampleRateHz[i]); 373 Init(kSampleRateHz[i]);
374 RunStableStartup(); 374 RunStableStartup();
375 375
376 // The AEC has now left the Startup phase. We now have at most 376 // The AEC has now left the Startup phase. We now have at most
377 // |kStableConvergenceMs| in the buffer. Keep on calling Process() until 377 // |kStableConvergenceMs| in the buffer. Keep on calling Process() until
378 // we run out of data and verify that the system delay is non-negative. 378 // we run out of data and verify that the system delay is non-negative.
379 for (int j = 0; j <= kStableConvergenceMs; j += 10) { 379 for (int j = 0; j <= kStableConvergenceMs; j += 10) {
380 EXPECT_EQ(0, WebRtcAec_Process(handle_, &near_ptr_, 1, &out_ptr_, 380 EXPECT_EQ(0, WebRtcAec_Process(handle_, &near_ptr_, 1, &out_ptr_,
381 samples_per_frame_, kDeviceBufMs, 0)); 381 samples_per_frame_, kDeviceBufMs, 0));
382 EXPECT_LE(0, WebRtcAec_system_delay(self_->aec)); 382 EXPECT_LE(0, WebRtcAec_system_delay(self_->aec));
383 } 383 }
384 } 384 }
385 } 385 }
386 } 386 }
387 } 387 }
388 388
389 TEST_F(SystemDelayTest, CorrectDelayDuringDrift) { 389 TEST_F(SystemDelayTest, CorrectDelayDuringDrift) {
390 // This drift test should verify that the system delay is never exceeding the 390 // This drift test should verify that the system delay is never exceeding the
391 // device buffer. The drift is simulated by decreasing the reported device 391 // device buffer. The drift is simulated by decreasing the reported device
392 // buffer size by 1 ms every 100 ms. If the device buffer size goes below 30 392 // buffer size by 1 ms every 100 ms. If the device buffer size goes below 30
393 // ms we jump (add) 10 ms to give a repeated pattern. 393 // ms we jump (add) 10 ms to give a repeated pattern.
394 394
395 // This process should be independent of DA-AEC and extended_filter mode. 395 // This process should be independent of DA-AEC and extended_filter mode.
396 for (int extended_filter = 0; extended_filter <= 1; ++extended_filter) { 396 for (int extended_filter = 0; extended_filter <= 1; ++extended_filter) {
397 WebRtcAec_enable_extended_filter(self_->aec, extended_filter); 397 WebRtcAec_enable_extended_filter(self_->aec, extended_filter);
398 EXPECT_EQ(extended_filter, WebRtcAec_extended_filter_enabled(self_->aec)); 398 EXPECT_EQ(extended_filter, WebRtcAec_extended_filter_enabled(self_->aec));
399 for (int da_aec = 0; da_aec <= 1; ++da_aec) { 399 for (int da_aec = 0; da_aec <= 1; ++da_aec) {
400 WebRtcAec_enable_reported_delay(self_->aec, 1 - da_aec); 400 WebRtcAec_enable_delay_agnostic(self_->aec, da_aec);
401 EXPECT_EQ(1 - da_aec, WebRtcAec_reported_delay_enabled(self_->aec)); 401 EXPECT_EQ(da_aec, WebRtcAec_delay_agnostic_enabled(self_->aec));
402 for (size_t i = 0; i < kNumSampleRates; i++) { 402 for (size_t i = 0; i < kNumSampleRates; i++) {
403 Init(kSampleRateHz[i]); 403 Init(kSampleRateHz[i]);
404 RunStableStartup(); 404 RunStableStartup();
405 405
406 // We have left the startup phase and proceed with normal processing. 406 // We have left the startup phase and proceed with normal processing.
407 int jump = 0; 407 int jump = 0;
408 for (int j = 0; j < 1000; j++) { 408 for (int j = 0; j < 1000; j++) {
409 // Drift = -1 ms per 100 ms of data. 409 // Drift = -1 ms per 100 ms of data.
410 int device_buf_ms = kDeviceBufMs - (j / 10) + jump; 410 int device_buf_ms = kDeviceBufMs - (j / 10) + jump;
411 int device_buf = MapBufferSizeToSamples(device_buf_ms, 411 int device_buf = MapBufferSizeToSamples(device_buf_ms,
(...skipping 22 matching lines...) Expand all
434 // after which the stable procedure continues. The glitch is never reported by 434 // after which the stable procedure continues. The glitch is never reported by
435 // the device. 435 // the device.
436 // The system is said to be in a non-causal state if the difference between 436 // The system is said to be in a non-causal state if the difference between
437 // the device buffer and system delay is less than a block (64 samples). 437 // the device buffer and system delay is less than a block (64 samples).
438 438
439 // This process should be independent of DA-AEC and extended_filter mode. 439 // This process should be independent of DA-AEC and extended_filter mode.
440 for (int extended_filter = 0; extended_filter <= 1; ++extended_filter) { 440 for (int extended_filter = 0; extended_filter <= 1; ++extended_filter) {
441 WebRtcAec_enable_extended_filter(self_->aec, extended_filter); 441 WebRtcAec_enable_extended_filter(self_->aec, extended_filter);
442 EXPECT_EQ(extended_filter, WebRtcAec_extended_filter_enabled(self_->aec)); 442 EXPECT_EQ(extended_filter, WebRtcAec_extended_filter_enabled(self_->aec));
443 for (int da_aec = 0; da_aec <= 1; ++da_aec) { 443 for (int da_aec = 0; da_aec <= 1; ++da_aec) {
444 WebRtcAec_enable_reported_delay(self_->aec, 1 - da_aec); 444 WebRtcAec_enable_delay_agnostic(self_->aec, da_aec);
445 EXPECT_EQ(1 - da_aec, WebRtcAec_reported_delay_enabled(self_->aec)); 445 EXPECT_EQ(da_aec, WebRtcAec_delay_agnostic_enabled(self_->aec));
446 for (size_t i = 0; i < kNumSampleRates; i++) { 446 for (size_t i = 0; i < kNumSampleRates; i++) {
447 Init(kSampleRateHz[i]); 447 Init(kSampleRateHz[i]);
448 RunStableStartup(); 448 RunStableStartup();
449 int device_buf = MapBufferSizeToSamples(kDeviceBufMs, 449 int device_buf = MapBufferSizeToSamples(kDeviceBufMs,
450 extended_filter == 1); 450 extended_filter == 1);
451 // Glitch state. 451 // Glitch state.
452 for (int j = 0; j < 20; j++) { 452 for (int j = 0; j < 20; j++) {
453 EXPECT_EQ(0, 453 EXPECT_EQ(0,
454 WebRtcAec_BufferFarend(handle_, far_, samples_per_frame_)); 454 WebRtcAec_BufferFarend(handle_, far_, samples_per_frame_));
455 // No need to verify system delay, since that is done in a separate 455 // No need to verify system delay, since that is done in a separate
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after
491 491
492 TEST_F(SystemDelayTest, UnaffectedWhenSpuriousDeviceBufferValues) { 492 TEST_F(SystemDelayTest, UnaffectedWhenSpuriousDeviceBufferValues) {
493 // This test does not apply in extended_filter mode, since we only use the 493 // This test does not apply in extended_filter mode, since we only use the
494 // the first 10 ms chunk to determine a reasonable buffer size. 494 // the first 10 ms chunk to determine a reasonable buffer size.
495 const int extended_filter = 0; 495 const int extended_filter = 0;
496 WebRtcAec_enable_extended_filter(self_->aec, extended_filter); 496 WebRtcAec_enable_extended_filter(self_->aec, extended_filter);
497 EXPECT_EQ(extended_filter, WebRtcAec_extended_filter_enabled(self_->aec)); 497 EXPECT_EQ(extended_filter, WebRtcAec_extended_filter_enabled(self_->aec));
498 498
499 // Should be DA-AEC independent. 499 // Should be DA-AEC independent.
500 for (int da_aec = 0; da_aec <= 1; ++da_aec) { 500 for (int da_aec = 0; da_aec <= 1; ++da_aec) {
501 WebRtcAec_enable_reported_delay(self_->aec, 1 - da_aec); 501 WebRtcAec_enable_delay_agnostic(self_->aec, da_aec);
502 EXPECT_EQ(1 - da_aec, WebRtcAec_reported_delay_enabled(self_->aec)); 502 EXPECT_EQ(da_aec, WebRtcAec_delay_agnostic_enabled(self_->aec));
503 // This spurious device buffer data test aims at verifying that the system 503 // This spurious device buffer data test aims at verifying that the system
504 // delay is unaffected by large outliers. 504 // delay is unaffected by large outliers.
505 // The system is said to be in a non-causal state if the difference between 505 // The system is said to be in a non-causal state if the difference between
506 // the device buffer and system delay is less than a block (64 samples). 506 // the device buffer and system delay is less than a block (64 samples).
507 for (size_t i = 0; i < kNumSampleRates; i++) { 507 for (size_t i = 0; i < kNumSampleRates; i++) {
508 Init(kSampleRateHz[i]); 508 Init(kSampleRateHz[i]);
509 RunStableStartup(); 509 RunStableStartup();
510 int device_buf = MapBufferSizeToSamples(kDeviceBufMs, 510 int device_buf = MapBufferSizeToSamples(kDeviceBufMs,
511 extended_filter == 1); 511 extended_filter == 1);
512 512
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after
545 // TODO(bjornv): This test will have a better impact if we verified that the 545 // TODO(bjornv): This test will have a better impact if we verified that the
546 // delay estimate goes up when the system delay goes down to meet the average 546 // delay estimate goes up when the system delay goes down to meet the average
547 // device buffer size. 547 // device buffer size.
548 548
549 // This test does not apply if DA-AEC is enabled and extended_filter mode 549 // This test does not apply if DA-AEC is enabled and extended_filter mode
550 // disabled. 550 // disabled.
551 for (int extended_filter = 0; extended_filter <= 1; ++extended_filter) { 551 for (int extended_filter = 0; extended_filter <= 1; ++extended_filter) {
552 WebRtcAec_enable_extended_filter(self_->aec, extended_filter); 552 WebRtcAec_enable_extended_filter(self_->aec, extended_filter);
553 EXPECT_EQ(extended_filter, WebRtcAec_extended_filter_enabled(self_->aec)); 553 EXPECT_EQ(extended_filter, WebRtcAec_extended_filter_enabled(self_->aec));
554 for (int da_aec = 0; da_aec <= 1; ++da_aec) { 554 for (int da_aec = 0; da_aec <= 1; ++da_aec) {
555 WebRtcAec_enable_reported_delay(self_->aec, 1 - da_aec); 555 WebRtcAec_enable_delay_agnostic(self_->aec, da_aec);
556 EXPECT_EQ(1 - da_aec, WebRtcAec_reported_delay_enabled(self_->aec)); 556 EXPECT_EQ(da_aec, WebRtcAec_delay_agnostic_enabled(self_->aec));
557 if (extended_filter == 0 && da_aec == 1) { 557 if (extended_filter == 0 && da_aec == 1) {
558 continue; 558 continue;
559 } 559 }
560 for (size_t i = 0; i < kNumSampleRates; i++) { 560 for (size_t i = 0; i < kNumSampleRates; i++) {
561 Init(kSampleRateHz[i]); 561 Init(kSampleRateHz[i]);
562 RunStableStartup(); 562 RunStableStartup();
563 const int device_buf = MapBufferSizeToSamples(kDeviceBufMs, 563 const int device_buf = MapBufferSizeToSamples(kDeviceBufMs,
564 extended_filter == 1); 564 extended_filter == 1);
565 565
566 // Normal state. We are currently not in a non-causal state. 566 // Normal state. We are currently not in a non-causal state.
(...skipping 18 matching lines...) Expand all
585 EXPECT_LE(0, WebRtcAec_system_delay(self_->aec)); 585 EXPECT_LE(0, WebRtcAec_system_delay(self_->aec));
586 } 586 }
587 // Verify we are not in a non-causal state. 587 // Verify we are not in a non-causal state.
588 EXPECT_FALSE(non_causal); 588 EXPECT_FALSE(non_causal);
589 } 589 }
590 } 590 }
591 } 591 }
592 } 592 }
593 593
594 } // namespace 594 } // namespace
OLDNEW
« no previous file with comments | « webrtc/modules/audio_processing/aec/echo_cancellation.c ('k') | webrtc/modules/audio_processing/echo_cancellation_impl.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698