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