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

Unified Diff: webrtc/modules/audio_processing/aec3/echo_path_delay_estimator_unittest.cc

Issue 2644123002: Adding full initial version of delay estimation functionality in echo canceller 3 (Closed)
Patch Set: Rebase Created 3 years, 10 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 side-by-side diff with in-line comments
Download patch
Index: webrtc/modules/audio_processing/aec3/echo_path_delay_estimator_unittest.cc
diff --git a/webrtc/modules/audio_processing/aec3/echo_path_delay_estimator_unittest.cc b/webrtc/modules/audio_processing/aec3/echo_path_delay_estimator_unittest.cc
index c3146ed7b8d592a6bb7562ef7c4ffe4a98502ca4..ba9ff23540c7e148f0ee36643b0a1f99f111784c 100644
--- a/webrtc/modules/audio_processing/aec3/echo_path_delay_estimator_unittest.cc
+++ b/webrtc/modules/audio_processing/aec3/echo_path_delay_estimator_unittest.cc
@@ -10,19 +10,22 @@
#include "webrtc/modules/audio_processing/aec3/echo_path_delay_estimator.h"
+#include <algorithm>
#include <sstream>
#include <string>
+#include "webrtc/base/random.h"
#include "webrtc/modules/audio_processing/aec3/aec3_constants.h"
#include "webrtc/modules/audio_processing/logging/apm_data_dumper.h"
+#include "webrtc/modules/audio_processing/test/echo_canceller_test_tools.h"
#include "webrtc/test/gtest.h"
namespace webrtc {
namespace {
-std::string ProduceDebugText(int sample_rate_hz) {
+std::string ProduceDebugText(size_t delay) {
std::ostringstream ss;
- ss << "Sample rate: " << sample_rate_hz;
+ ss << "Delay: " << delay;
return ss.str();
}
@@ -30,57 +33,120 @@ std::string ProduceDebugText(int sample_rate_hz) {
// Verifies that the basic API calls work.
TEST(EchoPathDelayEstimator, BasicApiCalls) {
- for (auto rate : {8000, 16000, 32000, 48000}) {
- ProduceDebugText(rate);
- ApmDataDumper data_dumper(0);
- EchoPathDelayEstimator estimator(&data_dumper, rate);
- std::vector<float> render(kBlockSize, 0.f);
- std::vector<float> capture(kBlockSize, 0.f);
- for (size_t k = 0; k < 100; ++k) {
- estimator.EstimateDelay(render, capture);
+ ApmDataDumper data_dumper(0);
+ EchoPathDelayEstimator estimator(&data_dumper);
+ std::vector<float> render(kBlockSize, 0.f);
+ std::vector<float> capture(kBlockSize, 0.f);
+ for (size_t k = 0; k < 100; ++k) {
+ estimator.EstimateDelay(render, capture);
+ }
+}
+
+// Verifies that the delay estimator produces correct delay for artificially
+// delayed signals.
+TEST(EchoPathDelayEstimator, DelayEstimation) {
+ Random random_generator(42U);
+ std::vector<float> render(kBlockSize, 0.f);
+ std::vector<float> capture(kBlockSize, 0.f);
+ ApmDataDumper data_dumper(0);
+ for (size_t delay_samples : {0, 64, 150, 200, 800, 4000}) {
+ SCOPED_TRACE(ProduceDebugText(delay_samples));
+ DelayBuffer<float> signal_delay_buffer(delay_samples);
+ EchoPathDelayEstimator estimator(&data_dumper);
+
+ rtc::Optional<size_t> estimated_delay_samples;
+ for (size_t k = 0; k < (100 + delay_samples / kBlockSize); ++k) {
+ RandomizeSampleVector(&random_generator, render);
+ signal_delay_buffer.Delay(render, capture);
+ estimated_delay_samples = estimator.EstimateDelay(render, capture);
+ }
+ if (estimated_delay_samples) {
+ // Due to the internal down-sampling by 4 done inside the delay estimator
+ // the estimated delay cannot be expected to be closer than 4 samples to
+ // the true delay.
+ EXPECT_NEAR(delay_samples, *estimated_delay_samples, 4);
+ } else {
+ ADD_FAILURE();
}
}
}
-#if RTC_DCHECK_IS_ON && GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID)
+// Verifies that the delay estimator does not produce delay estimates too
+// quickly.
+TEST(EchoPathDelayEstimator, NoInitialDelayestimates) {
+ Random random_generator(42U);
+ std::vector<float> render(kBlockSize, 0.f);
+ std::vector<float> capture(kBlockSize, 0.f);
+ ApmDataDumper data_dumper(0);
+
+ EchoPathDelayEstimator estimator(&data_dumper);
+ for (size_t k = 0; k < 19; ++k) {
+ RandomizeSampleVector(&random_generator, render);
+ std::copy(render.begin(), render.end(), capture.begin());
+ EXPECT_FALSE(estimator.EstimateDelay(render, capture));
+ }
+}
-// Verifies the check for correct sample rate.
-TEST(EchoPathDelayEstimator, WrongSampleRate) {
+// Verifies that the delay estimator does not produce delay estimates for render
+// signals of low level.
+TEST(EchoPathDelayEstimator, NoDelayEstimatesForLowLevelRenderSignals) {
+ Random random_generator(42U);
+ std::vector<float> render(kBlockSize, 0.f);
+ std::vector<float> capture(kBlockSize, 0.f);
ApmDataDumper data_dumper(0);
- EXPECT_DEATH(EchoPathDelayEstimator remover(&data_dumper, 8001), "");
+ EchoPathDelayEstimator estimator(&data_dumper);
+ for (size_t k = 0; k < 100; ++k) {
+ RandomizeSampleVector(&random_generator, render);
+ for (auto& render_k : render) {
+ render_k *= 100.f / 32767.f;
+ }
+ std::copy(render.begin(), render.end(), capture.begin());
+ EXPECT_FALSE(estimator.EstimateDelay(render, capture));
+ }
+}
+
+// Verifies that the delay estimator does not produce delay estimates for
+// uncorrelated signals.
+TEST(EchoPathDelayEstimator, NoDelayEstimatesForUncorrelatedSignals) {
+ Random random_generator(42U);
+ std::vector<float> render(kBlockSize, 0.f);
+ std::vector<float> capture(kBlockSize, 0.f);
+ ApmDataDumper data_dumper(0);
+ EchoPathDelayEstimator estimator(&data_dumper);
+ for (size_t k = 0; k < 100; ++k) {
+ RandomizeSampleVector(&random_generator, render);
+ RandomizeSampleVector(&random_generator, capture);
+ EXPECT_FALSE(estimator.EstimateDelay(render, capture));
+ }
}
+#if RTC_DCHECK_IS_ON && GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID)
+
// Verifies the check for the render blocksize.
// TODO(peah): Re-enable the test once the issue with memory leaks during DEATH
// tests on test bots has been fixed.
TEST(EchoPathDelayEstimator, DISABLED_WrongRenderBlockSize) {
- for (auto rate : {8000, 16000, 32000, 48000}) {
- ProduceDebugText(rate);
- ApmDataDumper data_dumper(0);
- EchoPathDelayEstimator estimator(&data_dumper, rate);
- std::vector<float> render(kBlockSize - 1, 0.f);
- std::vector<float> capture(kBlockSize, 0.f);
- EXPECT_DEATH(estimator.EstimateDelay(render, capture), "");
- }
+ ApmDataDumper data_dumper(0);
+ EchoPathDelayEstimator estimator(&data_dumper);
+ std::vector<float> render(std::vector<float>(kBlockSize - 1, 0.f));
+ std::vector<float> capture(std::vector<float>(kBlockSize, 0.f));
+ EXPECT_DEATH(estimator.EstimateDelay(render, capture), "");
}
// Verifies the check for the capture blocksize.
// TODO(peah): Re-enable the test once the issue with memory leaks during DEATH
// tests on test bots has been fixed.
-TEST(EchoPathDelayEstimator, DISABLED_WrongCaptureBlockSize) {
- for (auto rate : {8000, 16000, 32000, 48000}) {
- ProduceDebugText(rate);
- ApmDataDumper data_dumper(0);
- EchoPathDelayEstimator estimator(&data_dumper, rate);
- std::vector<float> render(kBlockSize, 0.f);
- std::vector<float> capture(kBlockSize - 1, 0.f);
- EXPECT_DEATH(estimator.EstimateDelay(render, capture), "");
- }
+TEST(EchoPathDelayEstimator, WrongCaptureBlockSize) {
+ ApmDataDumper data_dumper(0);
+ EchoPathDelayEstimator estimator(&data_dumper);
+ std::vector<float> render(std::vector<float>(kBlockSize, 0.f));
+ std::vector<float> capture(std::vector<float>(kBlockSize - 1, 0.f));
+ EXPECT_DEATH(estimator.EstimateDelay(render, capture), "");
}
// Verifies the check for non-null data dumper.
TEST(EchoPathDelayEstimator, NullDataDumper) {
- EXPECT_DEATH(EchoPathDelayEstimator(nullptr, 8000), "");
+ EXPECT_DEATH(EchoPathDelayEstimator(nullptr), "");
}
#endif

Powered by Google App Engine
This is Rietveld 408576698