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