Gustaf Ullberg | bffa300 | 2018-02-14 15:12:00 +0100 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (c) 2018 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 | |
| 11 | #ifndef API_AUDIO_ECHO_CANCELLER3_CONFIG_H_ |
| 12 | #define API_AUDIO_ECHO_CANCELLER3_CONFIG_H_ |
| 13 | |
Gustaf Ullberg | 3646f97 | 2018-02-14 15:19:04 +0100 | [diff] [blame] | 14 | #include <stddef.h> // size_t |
| 15 | |
Mirko Bonadei | 3d25530 | 2018-10-11 10:50:45 +0200 | [diff] [blame] | 16 | #include "rtc_base/system/rtc_export.h" |
| 17 | |
Gustaf Ullberg | bffa300 | 2018-02-14 15:12:00 +0100 | [diff] [blame] | 18 | namespace webrtc { |
| 19 | |
| 20 | // Configuration struct for EchoCanceller3 |
Mirko Bonadei | 3d25530 | 2018-10-11 10:50:45 +0200 | [diff] [blame] | 21 | struct RTC_EXPORT EchoCanceller3Config { |
Sam Zackrisson | 877dc89 | 2018-10-23 14:17:38 +0200 | [diff] [blame] | 22 | // Checks and updates the config parameters to lie within (mostly) reasonable |
Sam Zackrisson | a4c8514 | 2018-10-10 10:44:43 +0200 | [diff] [blame] | 23 | // ranges. Returns true if and only of the config did not need to be changed. |
| 24 | static bool Validate(EchoCanceller3Config* config); |
| 25 | |
Per Åhgren | b6b00dc | 2018-02-20 22:18:27 +0100 | [diff] [blame] | 26 | EchoCanceller3Config(); |
Per Åhgren | 251c735 | 2018-03-28 16:31:57 +0200 | [diff] [blame] | 27 | EchoCanceller3Config(const EchoCanceller3Config& e); |
Gustaf Ullberg | 11539f0 | 2018-10-15 13:40:29 +0200 | [diff] [blame] | 28 | |
| 29 | struct Buffering { |
Gustaf Ullberg | 11539f0 | 2018-10-15 13:40:29 +0200 | [diff] [blame] | 30 | size_t excess_render_detection_interval_blocks = 250; |
| 31 | size_t max_allowed_excess_render_blocks = 8; |
| 32 | } buffering; |
| 33 | |
Gustaf Ullberg | bffa300 | 2018-02-14 15:12:00 +0100 | [diff] [blame] | 34 | struct Delay { |
Per Åhgren | 398689f | 2018-08-23 11:38:27 +0200 | [diff] [blame] | 35 | Delay(); |
| 36 | Delay(const Delay& e); |
Gustaf Ullberg | bffa300 | 2018-02-14 15:12:00 +0100 | [diff] [blame] | 37 | size_t default_delay = 5; |
Gustaf Ullberg | 2672874 | 2018-06-04 19:04:40 +0200 | [diff] [blame] | 38 | size_t down_sampling_factor = 4; |
Gustaf Ullberg | 11539f0 | 2018-10-15 13:40:29 +0200 | [diff] [blame] | 39 | size_t num_filters = 5; |
Gustaf Ullberg | 9249fbf | 2019-03-14 11:24:54 +0100 | [diff] [blame] | 40 | size_t delay_headroom_samples = 32; |
| 41 | size_t hysteresis_limit_blocks = 1; |
Per Åhgren | 398689f | 2018-08-23 11:38:27 +0200 | [diff] [blame] | 42 | size_t fixed_capture_delay_samples = 0; |
Per Åhgren | 6a4fd19 | 2018-09-07 00:13:03 +0200 | [diff] [blame] | 43 | float delay_estimate_smoothing = 0.7f; |
| 44 | float delay_candidate_detection_threshold = 0.2f; |
| 45 | struct DelaySelectionThresholds { |
| 46 | int initial; |
| 47 | int converged; |
Per Åhgren | 8b7d206 | 2018-10-30 23:44:40 +0100 | [diff] [blame] | 48 | } delay_selection_thresholds = {5, 20}; |
Gustaf Ullberg | 8f32b6c | 2019-04-05 16:23:50 +0200 | [diff] [blame] | 49 | bool use_external_delay_estimator = false; |
Gustaf Ullberg | ee84d39 | 2019-09-10 09:36:43 +0200 | [diff] [blame^] | 50 | bool downmix_before_delay_estimation = true; |
Gustaf Ullberg | bffa300 | 2018-02-14 15:12:00 +0100 | [diff] [blame] | 51 | } delay; |
| 52 | |
| 53 | struct Filter { |
| 54 | struct MainConfiguration { |
| 55 | size_t length_blocks; |
| 56 | float leakage_converged; |
| 57 | float leakage_diverged; |
| 58 | float error_floor; |
Gustaf Ullberg | 040f87f | 2018-10-09 15:02:39 +0200 | [diff] [blame] | 59 | float error_ceil; |
Gustaf Ullberg | bffa300 | 2018-02-14 15:12:00 +0100 | [diff] [blame] | 60 | float noise_gate; |
| 61 | }; |
| 62 | |
| 63 | struct ShadowConfiguration { |
| 64 | size_t length_blocks; |
| 65 | float rate; |
| 66 | float noise_gate; |
| 67 | }; |
| 68 | |
Gustaf Ullberg | 040f87f | 2018-10-09 15:02:39 +0200 | [diff] [blame] | 69 | MainConfiguration main = {13, 0.00005f, 0.05f, 0.001f, 2.f, 20075344.f}; |
Gustaf Ullberg | bffa300 | 2018-02-14 15:12:00 +0100 | [diff] [blame] | 70 | ShadowConfiguration shadow = {13, 0.7f, 20075344.f}; |
| 71 | |
Gustaf Ullberg | 040f87f | 2018-10-09 15:02:39 +0200 | [diff] [blame] | 72 | MainConfiguration main_initial = {12, 0.005f, 0.5f, |
| 73 | 0.001f, 2.f, 20075344.f}; |
Gustaf Ullberg | bffa300 | 2018-02-14 15:12:00 +0100 | [diff] [blame] | 74 | ShadowConfiguration shadow_initial = {12, 0.9f, 20075344.f}; |
Per Åhgren | 5f1a31c | 2018-03-08 15:54:41 +0100 | [diff] [blame] | 75 | |
| 76 | size_t config_change_duration_blocks = 250; |
Per Åhgren | c3da671 | 2018-08-17 00:09:15 +0200 | [diff] [blame] | 77 | float initial_state_seconds = 2.5f; |
Jesús de Vicente Peña | 8459b17 | 2018-08-21 16:09:49 +0200 | [diff] [blame] | 78 | bool conservative_initial_phase = false; |
Per Åhgren | 2402154 | 2018-08-31 07:34:29 +0200 | [diff] [blame] | 79 | bool enable_shadow_filter_output_usage = true; |
Gustaf Ullberg | 52caa0e | 2019-04-11 14:43:17 +0200 | [diff] [blame] | 80 | bool use_linear_filter = true; |
Gustaf Ullberg | bffa300 | 2018-02-14 15:12:00 +0100 | [diff] [blame] | 81 | } filter; |
| 82 | |
| 83 | struct Erle { |
| 84 | float min = 1.f; |
Per Åhgren | 5c532d3 | 2018-03-22 00:29:25 +0100 | [diff] [blame] | 85 | float max_l = 4.f; |
Gustaf Ullberg | bffa300 | 2018-02-14 15:12:00 +0100 | [diff] [blame] | 86 | float max_h = 1.5f; |
Jesús de Vicente Peña | a687812 | 2018-08-28 14:27:45 +0200 | [diff] [blame] | 87 | bool onset_detection = true; |
Jesús de Vicente Peña | 44974e1 | 2018-11-20 12:54:23 +0100 | [diff] [blame] | 88 | size_t num_sections = 1; |
Gustaf Ullberg | bffa300 | 2018-02-14 15:12:00 +0100 | [diff] [blame] | 89 | } erle; |
| 90 | |
| 91 | struct EpStrength { |
Per Åhgren | e8efbbd | 2019-03-14 11:29:39 +0100 | [diff] [blame] | 92 | float default_gain = 1.f; |
Per Åhgren | 7004571 | 2018-10-09 01:11:15 +0200 | [diff] [blame] | 93 | float default_len = 0.83f; |
Gustaf Ullberg | bffa300 | 2018-02-14 15:12:00 +0100 | [diff] [blame] | 94 | bool echo_can_saturate = true; |
| 95 | bool bounded_erl = false; |
| 96 | } ep_strength; |
| 97 | |
Gustaf Ullberg | bffa300 | 2018-02-14 15:12:00 +0100 | [diff] [blame] | 98 | struct EchoAudibility { |
| 99 | float low_render_limit = 4 * 64.f; |
| 100 | float normal_render_limit = 64.f; |
Per Åhgren | b02644f | 2018-04-17 11:52:17 +0200 | [diff] [blame] | 101 | float floor_power = 2 * 64.f; |
| 102 | float audibility_threshold_lf = 10; |
| 103 | float audibility_threshold_mf = 10; |
| 104 | float audibility_threshold_hf = 10; |
Jesús de Vicente Peña | 70a5963 | 2019-04-16 12:32:15 +0200 | [diff] [blame] | 105 | bool use_stationarity_properties = false; |
Per Åhgren | 1724a80 | 2018-11-14 16:01:45 +0100 | [diff] [blame] | 106 | bool use_stationarity_properties_at_init = false; |
Gustaf Ullberg | bffa300 | 2018-02-14 15:12:00 +0100 | [diff] [blame] | 107 | } echo_audibility; |
| 108 | |
| 109 | struct RenderLevels { |
| 110 | float active_render_limit = 100.f; |
| 111 | float poor_excitation_render_limit = 150.f; |
Gustaf Ullberg | c4b7f03 | 2018-06-01 11:22:05 +0200 | [diff] [blame] | 112 | float poor_excitation_render_limit_ds8 = 20.f; |
Gustaf Ullberg | bffa300 | 2018-02-14 15:12:00 +0100 | [diff] [blame] | 113 | } render_levels; |
| 114 | |
Per Åhgren | b6b00dc | 2018-02-20 22:18:27 +0100 | [diff] [blame] | 115 | struct EchoRemovalControl { |
Per Åhgren | 461cdf0 | 2018-02-27 01:59:37 +0100 | [diff] [blame] | 116 | bool has_clock_drift = false; |
Per Åhgren | e3ca991 | 2018-05-28 22:57:17 +0200 | [diff] [blame] | 117 | bool linear_and_stable_echo_path = false; |
Per Åhgren | b6b00dc | 2018-02-20 22:18:27 +0100 | [diff] [blame] | 118 | } echo_removal_control; |
Per Åhgren | 251c735 | 2018-03-28 16:31:57 +0200 | [diff] [blame] | 119 | |
| 120 | struct EchoModel { |
Jesús de Vicente Peña | dd09287 | 2018-05-25 16:55:11 +0200 | [diff] [blame] | 121 | EchoModel(); |
| 122 | EchoModel(const EchoModel& e); |
Per Åhgren | 251c735 | 2018-03-28 16:31:57 +0200 | [diff] [blame] | 123 | size_t noise_floor_hold = 50; |
| 124 | float min_noise_floor_power = 1638400.f; |
| 125 | float stationary_gate_slope = 10.f; |
| 126 | float noise_gate_power = 27509.42f; |
| 127 | float noise_gate_slope = 0.3f; |
| 128 | size_t render_pre_window_size = 1; |
Per Åhgren | 85eef49 | 2018-03-28 16:19:47 +0200 | [diff] [blame] | 129 | size_t render_post_window_size = 1; |
Per Åhgren | 251c735 | 2018-03-28 16:31:57 +0200 | [diff] [blame] | 130 | } echo_model; |
Per Åhgren | 47d7fbd | 2018-04-24 12:44:29 +0200 | [diff] [blame] | 131 | |
| 132 | struct Suppressor { |
Per Åhgren | 524e878 | 2018-08-24 22:48:49 +0200 | [diff] [blame] | 133 | Suppressor(); |
| 134 | Suppressor(const Suppressor& e); |
| 135 | |
Gustaf Ullberg | 8406c43 | 2018-06-19 12:31:33 +0200 | [diff] [blame] | 136 | size_t nearend_average_blocks = 4; |
Gustaf Ullberg | ec64217 | 2018-07-03 13:48:32 +0200 | [diff] [blame] | 137 | |
| 138 | struct MaskingThresholds { |
Per Åhgren | 524e878 | 2018-08-24 22:48:49 +0200 | [diff] [blame] | 139 | MaskingThresholds(float enr_transparent, |
| 140 | float enr_suppress, |
| 141 | float emr_transparent); |
| 142 | MaskingThresholds(const MaskingThresholds& e); |
Gustaf Ullberg | ec64217 | 2018-07-03 13:48:32 +0200 | [diff] [blame] | 143 | float enr_transparent; |
| 144 | float enr_suppress; |
| 145 | float emr_transparent; |
| 146 | }; |
Per Åhgren | 524e878 | 2018-08-24 22:48:49 +0200 | [diff] [blame] | 147 | |
| 148 | struct Tuning { |
| 149 | Tuning(MaskingThresholds mask_lf, |
| 150 | MaskingThresholds mask_hf, |
| 151 | float max_inc_factor, |
| 152 | float max_dec_factor_lf); |
| 153 | Tuning(const Tuning& e); |
| 154 | MaskingThresholds mask_lf; |
| 155 | MaskingThresholds mask_hf; |
| 156 | float max_inc_factor; |
| 157 | float max_dec_factor_lf; |
| 158 | }; |
| 159 | |
Per Åhgren | 0d8c100 | 2018-10-10 00:25:16 +0200 | [diff] [blame] | 160 | Tuning normal_tuning = Tuning(MaskingThresholds(.3f, .4f, .3f), |
Per Åhgren | 524e878 | 2018-08-24 22:48:49 +0200 | [diff] [blame] | 161 | MaskingThresholds(.07f, .1f, .3f), |
| 162 | 2.0f, |
| 163 | 0.25f); |
Per Åhgren | 13d392d | 2018-10-09 23:33:00 +0200 | [diff] [blame] | 164 | Tuning nearend_tuning = Tuning(MaskingThresholds(1.09f, 1.1f, .3f), |
| 165 | MaskingThresholds(.1f, .3f, .3f), |
Per Åhgren | 524e878 | 2018-08-24 22:48:49 +0200 | [diff] [blame] | 166 | 2.0f, |
| 167 | 0.25f); |
| 168 | |
| 169 | struct DominantNearendDetection { |
Gustaf Ullberg | de10eea | 2018-11-28 09:44:50 +0100 | [diff] [blame] | 170 | float enr_threshold = .25f; |
| 171 | float enr_exit_threshold = 10.f; |
Gustaf Ullberg | c9f9b87 | 2018-10-22 15:15:36 +0200 | [diff] [blame] | 172 | float snr_threshold = 30.f; |
| 173 | int hold_duration = 50; |
| 174 | int trigger_threshold = 12; |
Per Åhgren | 700b4a4 | 2018-10-23 21:21:37 +0200 | [diff] [blame] | 175 | bool use_during_initial_phase = true; |
Per Åhgren | 524e878 | 2018-08-24 22:48:49 +0200 | [diff] [blame] | 176 | } dominant_nearend_detection; |
| 177 | |
Per Åhgren | fde4aa9 | 2018-08-27 14:19:35 +0200 | [diff] [blame] | 178 | struct HighBandsSuppression { |
| 179 | float enr_threshold = 1.f; |
| 180 | float max_gain_during_echo = 1.f; |
| 181 | } high_bands_suppression; |
| 182 | |
Per Åhgren | 524e878 | 2018-08-24 22:48:49 +0200 | [diff] [blame] | 183 | float floor_first_increase = 0.00001f; |
Per Åhgren | 7343f56 | 2018-08-17 10:08:34 +0200 | [diff] [blame] | 184 | bool enforce_transparent = false; |
| 185 | bool enforce_empty_higher_bands = false; |
Per Åhgren | 47d7fbd | 2018-04-24 12:44:29 +0200 | [diff] [blame] | 186 | } suppressor; |
Gustaf Ullberg | bffa300 | 2018-02-14 15:12:00 +0100 | [diff] [blame] | 187 | }; |
| 188 | } // namespace webrtc |
| 189 | |
| 190 | #endif // API_AUDIO_ECHO_CANCELLER3_CONFIG_H_ |