andrew@webrtc.org | 1760a17 | 2013-09-25 23:17:38 +0000 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (c) 2013 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 | |
kwiberg | 88788ad | 2016-02-19 07:04:49 -0800 | [diff] [blame] | 11 | #include <memory> |
| 12 | |
Mirko Bonadei | 92ea95e | 2017-09-15 06:47:31 +0200 | [diff] [blame] | 13 | #include "modules/audio_processing/aec/aec_core.h" |
Sam Zackrisson | cdf0e6d | 2018-09-17 11:05:17 +0200 | [diff] [blame] | 14 | #include "modules/audio_processing/echo_cancellation_impl.h" |
Mirko Bonadei | 92ea95e | 2017-09-15 06:47:31 +0200 | [diff] [blame] | 15 | #include "modules/audio_processing/include/audio_processing.h" |
Steve Anton | 10542f2 | 2019-01-11 09:11:00 -0800 | [diff] [blame^] | 16 | #include "rtc_base/critical_section.h" |
Mirko Bonadei | 92ea95e | 2017-09-15 06:47:31 +0200 | [diff] [blame] | 17 | #include "test/gtest.h" |
andrew@webrtc.org | 1760a17 | 2013-09-25 23:17:38 +0000 | [diff] [blame] | 18 | |
| 19 | namespace webrtc { |
Henrik Lundin | 441f634 | 2015-06-09 16:03:13 +0200 | [diff] [blame] | 20 | TEST(EchoCancellationInternalTest, ExtendedFilter) { |
Sam Zackrisson | 7f4dfa4 | 2018-11-01 08:59:29 +0100 | [diff] [blame] | 21 | EchoCancellationImpl echo_canceller; |
Sam Zackrisson | cdf0e6d | 2018-09-17 11:05:17 +0200 | [diff] [blame] | 22 | echo_canceller.Initialize(AudioProcessing::kSampleRate32kHz, 2, 2, 2); |
andrew@webrtc.org | 1760a17 | 2013-09-25 23:17:38 +0000 | [diff] [blame] | 23 | |
Sam Zackrisson | cdf0e6d | 2018-09-17 11:05:17 +0200 | [diff] [blame] | 24 | EXPECT_TRUE(echo_canceller.aec_core() == nullptr); |
andrew@webrtc.org | 1760a17 | 2013-09-25 23:17:38 +0000 | [diff] [blame] | 25 | |
Sam Zackrisson | cdf0e6d | 2018-09-17 11:05:17 +0200 | [diff] [blame] | 26 | echo_canceller.Enable(true); |
| 27 | |
| 28 | AecCore* aec_core = echo_canceller.aec_core(); |
andrew@webrtc.org | 1760a17 | 2013-09-25 23:17:38 +0000 | [diff] [blame] | 29 | ASSERT_TRUE(aec_core != NULL); |
| 30 | // Disabled by default. |
Henrik Lundin | 441f634 | 2015-06-09 16:03:13 +0200 | [diff] [blame] | 31 | EXPECT_EQ(0, WebRtcAec_extended_filter_enabled(aec_core)); |
andrew@webrtc.org | 1760a17 | 2013-09-25 23:17:38 +0000 | [diff] [blame] | 32 | |
| 33 | Config config; |
Henrik Lundin | 441f634 | 2015-06-09 16:03:13 +0200 | [diff] [blame] | 34 | config.Set<ExtendedFilter>(new ExtendedFilter(true)); |
Sam Zackrisson | cdf0e6d | 2018-09-17 11:05:17 +0200 | [diff] [blame] | 35 | echo_canceller.SetExtraOptions(config); |
Henrik Lundin | 441f634 | 2015-06-09 16:03:13 +0200 | [diff] [blame] | 36 | EXPECT_EQ(1, WebRtcAec_extended_filter_enabled(aec_core)); |
andrew@webrtc.org | 1760a17 | 2013-09-25 23:17:38 +0000 | [diff] [blame] | 37 | |
| 38 | // Retains setting after initialization. |
Sam Zackrisson | cdf0e6d | 2018-09-17 11:05:17 +0200 | [diff] [blame] | 39 | echo_canceller.Initialize(AudioProcessing::kSampleRate16kHz, 2, 2, 2); |
Henrik Lundin | 441f634 | 2015-06-09 16:03:13 +0200 | [diff] [blame] | 40 | EXPECT_EQ(1, WebRtcAec_extended_filter_enabled(aec_core)); |
andrew@webrtc.org | 1760a17 | 2013-09-25 23:17:38 +0000 | [diff] [blame] | 41 | |
Henrik Lundin | 441f634 | 2015-06-09 16:03:13 +0200 | [diff] [blame] | 42 | config.Set<ExtendedFilter>(new ExtendedFilter(false)); |
Sam Zackrisson | cdf0e6d | 2018-09-17 11:05:17 +0200 | [diff] [blame] | 43 | echo_canceller.SetExtraOptions(config); |
Henrik Lundin | 441f634 | 2015-06-09 16:03:13 +0200 | [diff] [blame] | 44 | EXPECT_EQ(0, WebRtcAec_extended_filter_enabled(aec_core)); |
andrew@webrtc.org | 1760a17 | 2013-09-25 23:17:38 +0000 | [diff] [blame] | 45 | |
| 46 | // Retains setting after initialization. |
Sam Zackrisson | cdf0e6d | 2018-09-17 11:05:17 +0200 | [diff] [blame] | 47 | echo_canceller.Initialize(AudioProcessing::kSampleRate16kHz, 1, 1, 1); |
Henrik Lundin | 441f634 | 2015-06-09 16:03:13 +0200 | [diff] [blame] | 48 | EXPECT_EQ(0, WebRtcAec_extended_filter_enabled(aec_core)); |
andrew@webrtc.org | 1760a17 | 2013-09-25 23:17:38 +0000 | [diff] [blame] | 49 | } |
| 50 | |
henrik.lundin | 0f133b9 | 2015-07-02 00:17:55 -0700 | [diff] [blame] | 51 | TEST(EchoCancellationInternalTest, DelayAgnostic) { |
Sam Zackrisson | 7f4dfa4 | 2018-11-01 08:59:29 +0100 | [diff] [blame] | 52 | EchoCancellationImpl echo_canceller; |
Sam Zackrisson | cdf0e6d | 2018-09-17 11:05:17 +0200 | [diff] [blame] | 53 | echo_canceller.Initialize(AudioProcessing::kSampleRate32kHz, 1, 1, 1); |
bjornv@webrtc.org | 3f83072 | 2014-06-11 04:48:11 +0000 | [diff] [blame] | 54 | |
Sam Zackrisson | cdf0e6d | 2018-09-17 11:05:17 +0200 | [diff] [blame] | 55 | EXPECT_TRUE(echo_canceller.aec_core() == NULL); |
bjornv@webrtc.org | 3f83072 | 2014-06-11 04:48:11 +0000 | [diff] [blame] | 56 | |
Sam Zackrisson | cdf0e6d | 2018-09-17 11:05:17 +0200 | [diff] [blame] | 57 | EXPECT_EQ(0, echo_canceller.Enable(true)); |
| 58 | EXPECT_TRUE(echo_canceller.is_enabled()); |
| 59 | |
| 60 | AecCore* aec_core = echo_canceller.aec_core(); |
bjornv@webrtc.org | 3f83072 | 2014-06-11 04:48:11 +0000 | [diff] [blame] | 61 | ASSERT_TRUE(aec_core != NULL); |
| 62 | // Enabled by default. |
henrik.lundin | 0f133b9 | 2015-07-02 00:17:55 -0700 | [diff] [blame] | 63 | EXPECT_EQ(0, WebRtcAec_delay_agnostic_enabled(aec_core)); |
bjornv@webrtc.org | 3f83072 | 2014-06-11 04:48:11 +0000 | [diff] [blame] | 64 | |
| 65 | Config config; |
henrik.lundin | 0f133b9 | 2015-07-02 00:17:55 -0700 | [diff] [blame] | 66 | config.Set<DelayAgnostic>(new DelayAgnostic(true)); |
Sam Zackrisson | cdf0e6d | 2018-09-17 11:05:17 +0200 | [diff] [blame] | 67 | echo_canceller.SetExtraOptions(config); |
henrik.lundin | 0f133b9 | 2015-07-02 00:17:55 -0700 | [diff] [blame] | 68 | EXPECT_EQ(1, WebRtcAec_delay_agnostic_enabled(aec_core)); |
bjornv@webrtc.org | 3f83072 | 2014-06-11 04:48:11 +0000 | [diff] [blame] | 69 | |
| 70 | // Retains setting after initialization. |
Sam Zackrisson | cdf0e6d | 2018-09-17 11:05:17 +0200 | [diff] [blame] | 71 | echo_canceller.Initialize(AudioProcessing::kSampleRate32kHz, 2, 2, 2); |
henrik.lundin | 0f133b9 | 2015-07-02 00:17:55 -0700 | [diff] [blame] | 72 | EXPECT_EQ(1, WebRtcAec_delay_agnostic_enabled(aec_core)); |
bjornv@webrtc.org | 3f83072 | 2014-06-11 04:48:11 +0000 | [diff] [blame] | 73 | |
henrik.lundin | 0f133b9 | 2015-07-02 00:17:55 -0700 | [diff] [blame] | 74 | config.Set<DelayAgnostic>(new DelayAgnostic(false)); |
Sam Zackrisson | cdf0e6d | 2018-09-17 11:05:17 +0200 | [diff] [blame] | 75 | echo_canceller.SetExtraOptions(config); |
henrik.lundin | 0f133b9 | 2015-07-02 00:17:55 -0700 | [diff] [blame] | 76 | EXPECT_EQ(0, WebRtcAec_delay_agnostic_enabled(aec_core)); |
bjornv@webrtc.org | 3f83072 | 2014-06-11 04:48:11 +0000 | [diff] [blame] | 77 | |
| 78 | // Retains setting after initialization. |
Sam Zackrisson | cdf0e6d | 2018-09-17 11:05:17 +0200 | [diff] [blame] | 79 | echo_canceller.Initialize(AudioProcessing::kSampleRate16kHz, 2, 2, 2); |
henrik.lundin | 0f133b9 | 2015-07-02 00:17:55 -0700 | [diff] [blame] | 80 | EXPECT_EQ(0, WebRtcAec_delay_agnostic_enabled(aec_core)); |
bjornv@webrtc.org | 3f83072 | 2014-06-11 04:48:11 +0000 | [diff] [blame] | 81 | } |
| 82 | |
Sam Zackrisson | cdf0e6d | 2018-09-17 11:05:17 +0200 | [diff] [blame] | 83 | TEST(EchoCancellationInternalTest, InterfaceConfiguration) { |
Sam Zackrisson | 7f4dfa4 | 2018-11-01 08:59:29 +0100 | [diff] [blame] | 84 | EchoCancellationImpl echo_canceller; |
Sam Zackrisson | cdf0e6d | 2018-09-17 11:05:17 +0200 | [diff] [blame] | 85 | echo_canceller.Initialize(AudioProcessing::kSampleRate16kHz, 1, 1, 1); |
| 86 | |
| 87 | EXPECT_EQ(0, echo_canceller.enable_drift_compensation(true)); |
| 88 | EXPECT_TRUE(echo_canceller.is_drift_compensation_enabled()); |
| 89 | EXPECT_EQ(0, echo_canceller.enable_drift_compensation(false)); |
| 90 | EXPECT_FALSE(echo_canceller.is_drift_compensation_enabled()); |
| 91 | |
saza | be490b2 | 2018-10-03 17:03:13 +0200 | [diff] [blame] | 92 | EchoCancellationImpl::SuppressionLevel level[] = { |
| 93 | EchoCancellationImpl::kLowSuppression, |
| 94 | EchoCancellationImpl::kModerateSuppression, |
| 95 | EchoCancellationImpl::kHighSuppression, |
Sam Zackrisson | cdf0e6d | 2018-09-17 11:05:17 +0200 | [diff] [blame] | 96 | }; |
| 97 | for (size_t i = 0; i < arraysize(level); i++) { |
| 98 | EXPECT_EQ(0, echo_canceller.set_suppression_level(level[i])); |
| 99 | EXPECT_EQ(level[i], echo_canceller.suppression_level()); |
| 100 | } |
| 101 | |
saza | be490b2 | 2018-10-03 17:03:13 +0200 | [diff] [blame] | 102 | EchoCancellationImpl::Metrics metrics; |
Sam Zackrisson | cdf0e6d | 2018-09-17 11:05:17 +0200 | [diff] [blame] | 103 | EXPECT_EQ(AudioProcessing::kNotEnabledError, |
| 104 | echo_canceller.GetMetrics(&metrics)); |
| 105 | |
| 106 | EXPECT_EQ(0, echo_canceller.Enable(true)); |
| 107 | EXPECT_TRUE(echo_canceller.is_enabled()); |
| 108 | |
| 109 | EXPECT_EQ(0, echo_canceller.enable_metrics(true)); |
| 110 | EXPECT_TRUE(echo_canceller.are_metrics_enabled()); |
| 111 | EXPECT_EQ(0, echo_canceller.enable_metrics(false)); |
| 112 | EXPECT_FALSE(echo_canceller.are_metrics_enabled()); |
| 113 | |
| 114 | EXPECT_EQ(0, echo_canceller.enable_delay_logging(true)); |
| 115 | EXPECT_TRUE(echo_canceller.is_delay_logging_enabled()); |
| 116 | EXPECT_EQ(0, echo_canceller.enable_delay_logging(false)); |
| 117 | EXPECT_FALSE(echo_canceller.is_delay_logging_enabled()); |
| 118 | |
| 119 | EXPECT_EQ(0, echo_canceller.Enable(false)); |
| 120 | EXPECT_FALSE(echo_canceller.is_enabled()); |
| 121 | |
| 122 | int median = 0; |
| 123 | int std = 0; |
| 124 | float poor_fraction = 0; |
| 125 | EXPECT_EQ(AudioProcessing::kNotEnabledError, |
| 126 | echo_canceller.GetDelayMetrics(&median, &std, &poor_fraction)); |
| 127 | |
| 128 | EXPECT_EQ(0, echo_canceller.Enable(true)); |
| 129 | EXPECT_TRUE(echo_canceller.is_enabled()); |
| 130 | EXPECT_EQ(0, echo_canceller.Enable(false)); |
| 131 | EXPECT_FALSE(echo_canceller.is_enabled()); |
| 132 | |
| 133 | EXPECT_EQ(0, echo_canceller.Enable(true)); |
| 134 | EXPECT_TRUE(echo_canceller.is_enabled()); |
| 135 | EXPECT_TRUE(echo_canceller.aec_core() != NULL); |
| 136 | EXPECT_EQ(0, echo_canceller.Enable(false)); |
| 137 | EXPECT_FALSE(echo_canceller.is_enabled()); |
| 138 | EXPECT_FALSE(echo_canceller.aec_core() != NULL); |
| 139 | } |
| 140 | |
andrew@webrtc.org | 1760a17 | 2013-09-25 23:17:38 +0000 | [diff] [blame] | 141 | } // namespace webrtc |