| OLD | NEW |
| 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 Loading... |
| 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 Loading... |
| 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 Loading... |
| 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 Loading... |
| 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 Loading... |
| 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 Loading... |
| 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 Loading... |
| 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 Loading... |
| 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 |
| OLD | NEW |