blob: 9d10da994948157c159c0464dd7e0df6c783e85a [file] [log] [blame]
Sam Zackrissona4c85142018-10-10 10:44:43 +02001/*
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#include "api/audio/echo_canceller3_config_json.h"
11
Yves Gerey3e707812018-11-28 16:47:49 +010012#include <stddef.h>
Jonas Olssona4d87372019-07-05 19:08:33 +020013
Sam Zackrissona4c85142018-10-10 10:44:43 +020014#include <string>
15#include <vector>
16
Yves Gerey3e707812018-11-28 16:47:49 +010017#include "rtc_base/checks.h"
Sam Zackrissona4c85142018-10-10 10:44:43 +020018#include "rtc_base/logging.h"
19#include "rtc_base/strings/json.h"
20#include "rtc_base/strings/string_builder.h"
21
22namespace webrtc {
23namespace {
24void ReadParam(const Json::Value& root, std::string param_name, bool* param) {
25 RTC_DCHECK(param);
26 bool v;
27 if (rtc::GetBoolFromJsonObject(root, param_name, &v)) {
28 *param = v;
29 }
30}
31
32void ReadParam(const Json::Value& root, std::string param_name, size_t* param) {
33 RTC_DCHECK(param);
34 int v;
Sam Zackrisson528a0342019-10-22 11:36:17 +020035 if (rtc::GetIntFromJsonObject(root, param_name, &v) && v >= 0) {
Sam Zackrissona4c85142018-10-10 10:44:43 +020036 *param = v;
37 }
38}
39
40void ReadParam(const Json::Value& root, std::string param_name, int* param) {
41 RTC_DCHECK(param);
42 int v;
43 if (rtc::GetIntFromJsonObject(root, param_name, &v)) {
44 *param = v;
45 }
46}
47
48void ReadParam(const Json::Value& root, std::string param_name, float* param) {
49 RTC_DCHECK(param);
50 double v;
51 if (rtc::GetDoubleFromJsonObject(root, param_name, &v)) {
52 *param = static_cast<float>(v);
53 }
54}
55
56void ReadParam(const Json::Value& root,
57 std::string param_name,
Per Åhgrenff045112020-03-20 11:20:39 +010058 EchoCanceller3Config::Filter::RefinedConfiguration* param) {
Sam Zackrisson703259c2018-10-10 17:17:43 +020059 RTC_DCHECK(param);
Sam Zackrissona4c85142018-10-10 10:44:43 +020060 Json::Value json_array;
61 if (rtc::GetValueFromJsonObject(root, param_name, &json_array)) {
62 std::vector<double> v;
63 rtc::JsonArrayToDoubleVector(json_array, &v);
64 if (v.size() != 6) {
65 RTC_LOG(LS_ERROR) << "Incorrect array size for " << param_name;
Sam Zackrisson703259c2018-10-10 17:17:43 +020066 return;
Sam Zackrissona4c85142018-10-10 10:44:43 +020067 }
68 param->length_blocks = static_cast<size_t>(v[0]);
69 param->leakage_converged = static_cast<float>(v[1]);
70 param->leakage_diverged = static_cast<float>(v[2]);
71 param->error_floor = static_cast<float>(v[3]);
72 param->error_ceil = static_cast<float>(v[4]);
73 param->noise_gate = static_cast<float>(v[5]);
74 }
75}
76
77void ReadParam(const Json::Value& root,
78 std::string param_name,
Per Åhgren9d661982020-03-20 11:26:48 +010079 EchoCanceller3Config::Filter::CoarseConfiguration* param) {
Sam Zackrisson703259c2018-10-10 17:17:43 +020080 RTC_DCHECK(param);
Sam Zackrissona4c85142018-10-10 10:44:43 +020081 Json::Value json_array;
82 if (rtc::GetValueFromJsonObject(root, param_name, &json_array)) {
83 std::vector<double> v;
84 rtc::JsonArrayToDoubleVector(json_array, &v);
85 if (v.size() != 3) {
86 RTC_LOG(LS_ERROR) << "Incorrect array size for " << param_name;
Sam Zackrisson703259c2018-10-10 17:17:43 +020087 return;
Sam Zackrissona4c85142018-10-10 10:44:43 +020088 }
89 param->length_blocks = static_cast<size_t>(v[0]);
90 param->rate = static_cast<float>(v[1]);
91 param->noise_gate = static_cast<float>(v[2]);
92 }
93}
94
Per Åhgren6a05bb12019-12-03 11:24:59 +010095void ReadParam(const Json::Value& root,
96 std::string param_name,
97 EchoCanceller3Config::Delay::AlignmentMixing* param) {
98 RTC_DCHECK(param);
99
100 Json::Value subsection;
101 if (rtc::GetValueFromJsonObject(root, param_name, &subsection)) {
102 ReadParam(subsection, "downmix", &param->downmix);
103 ReadParam(subsection, "adaptive_selection", &param->adaptive_selection);
104 ReadParam(subsection, "activity_power_threshold",
105 &param->activity_power_threshold);
106 ReadParam(subsection, "prefer_first_two_channels",
107 &param->prefer_first_two_channels);
108 }
109}
110
Gustaf Ullbergf534a642019-11-25 16:13:58 +0100111void ReadParam(
112 const Json::Value& root,
113 std::string param_name,
114 EchoCanceller3Config::Suppressor::SubbandNearendDetection::SubbandRegion*
115 param) {
116 RTC_DCHECK(param);
117 Json::Value json_array;
118 if (rtc::GetValueFromJsonObject(root, param_name, &json_array)) {
119 std::vector<int> v;
120 rtc::JsonArrayToIntVector(json_array, &v);
121 if (v.size() != 2) {
122 RTC_LOG(LS_ERROR) << "Incorrect array size for " << param_name;
123 return;
124 }
125 param->low = static_cast<size_t>(v[0]);
126 param->high = static_cast<size_t>(v[1]);
127 }
128}
129
Sam Zackrissona4c85142018-10-10 10:44:43 +0200130void ReadParam(const Json::Value& root,
131 std::string param_name,
132 EchoCanceller3Config::Suppressor::MaskingThresholds* param) {
Sam Zackrisson703259c2018-10-10 17:17:43 +0200133 RTC_DCHECK(param);
Sam Zackrissona4c85142018-10-10 10:44:43 +0200134 Json::Value json_array;
135 if (rtc::GetValueFromJsonObject(root, param_name, &json_array)) {
136 std::vector<double> v;
137 rtc::JsonArrayToDoubleVector(json_array, &v);
138 if (v.size() != 3) {
139 RTC_LOG(LS_ERROR) << "Incorrect array size for " << param_name;
Sam Zackrisson703259c2018-10-10 17:17:43 +0200140 return;
Sam Zackrissona4c85142018-10-10 10:44:43 +0200141 }
142 param->enr_transparent = static_cast<float>(v[0]);
143 param->enr_suppress = static_cast<float>(v[1]);
144 param->emr_transparent = static_cast<float>(v[2]);
145 }
146}
147} // namespace
148
Per Åhgren370bae42018-10-25 11:32:39 +0200149void Aec3ConfigFromJsonString(absl::string_view json_string,
150 EchoCanceller3Config* config,
151 bool* parsing_successful) {
152 RTC_DCHECK(config);
153 RTC_DCHECK(parsing_successful);
154 EchoCanceller3Config& cfg = *config;
155 cfg = EchoCanceller3Config();
156 *parsing_successful = true;
Sam Zackrissona4c85142018-10-10 10:44:43 +0200157
158 Json::Value root;
159 bool success = Json::Reader().parse(std::string(json_string), root);
160 if (!success) {
161 RTC_LOG(LS_ERROR) << "Incorrect JSON format: " << json_string;
Per Åhgren370bae42018-10-25 11:32:39 +0200162 *parsing_successful = false;
163 return;
Sam Zackrissona4c85142018-10-10 10:44:43 +0200164 }
165
166 Json::Value aec3_root;
167 success = rtc::GetValueFromJsonObject(root, "aec3", &aec3_root);
168 if (!success) {
169 RTC_LOG(LS_ERROR) << "Missing AEC3 config field: " << json_string;
Per Åhgren370bae42018-10-25 11:32:39 +0200170 *parsing_successful = false;
171 return;
Sam Zackrissona4c85142018-10-10 10:44:43 +0200172 }
173
174 Json::Value section;
Per Åhgrenc1d20922019-04-22 23:36:58 +0200175 if (rtc::GetValueFromJsonObject(aec3_root, "buffering", &section)) {
Gustaf Ullberg11539f02018-10-15 13:40:29 +0200176 ReadParam(section, "excess_render_detection_interval_blocks",
177 &cfg.buffering.excess_render_detection_interval_blocks);
178 ReadParam(section, "max_allowed_excess_render_blocks",
179 &cfg.buffering.max_allowed_excess_render_blocks);
180 }
181
Sam Zackrissona4c85142018-10-10 10:44:43 +0200182 if (rtc::GetValueFromJsonObject(aec3_root, "delay", &section)) {
183 ReadParam(section, "default_delay", &cfg.delay.default_delay);
184 ReadParam(section, "down_sampling_factor", &cfg.delay.down_sampling_factor);
185 ReadParam(section, "num_filters", &cfg.delay.num_filters);
Gustaf Ullberg9249fbf2019-03-14 11:24:54 +0100186 ReadParam(section, "delay_headroom_samples",
187 &cfg.delay.delay_headroom_samples);
188 ReadParam(section, "hysteresis_limit_blocks",
189 &cfg.delay.hysteresis_limit_blocks);
Sam Zackrissona4c85142018-10-10 10:44:43 +0200190 ReadParam(section, "fixed_capture_delay_samples",
191 &cfg.delay.fixed_capture_delay_samples);
192 ReadParam(section, "delay_estimate_smoothing",
193 &cfg.delay.delay_estimate_smoothing);
194 ReadParam(section, "delay_candidate_detection_threshold",
195 &cfg.delay.delay_candidate_detection_threshold);
196
197 Json::Value subsection;
198 if (rtc::GetValueFromJsonObject(section, "delay_selection_thresholds",
199 &subsection)) {
200 ReadParam(subsection, "initial",
201 &cfg.delay.delay_selection_thresholds.initial);
202 ReadParam(subsection, "converged",
203 &cfg.delay.delay_selection_thresholds.converged);
204 }
Gustaf Ullberg52caa0e2019-04-11 14:43:17 +0200205
206 ReadParam(section, "use_external_delay_estimator",
207 &cfg.delay.use_external_delay_estimator);
Sam Zackrissonffc84522019-10-15 13:43:02 +0200208 ReadParam(section, "log_warning_on_delay_changes",
209 &cfg.delay.log_warning_on_delay_changes);
Per Åhgren6a05bb12019-12-03 11:24:59 +0100210
211 ReadParam(section, "render_alignment_mixing",
212 &cfg.delay.render_alignment_mixing);
213 ReadParam(section, "capture_alignment_mixing",
214 &cfg.delay.capture_alignment_mixing);
Sam Zackrissona4c85142018-10-10 10:44:43 +0200215 }
216
217 if (rtc::GetValueFromJsonObject(aec3_root, "filter", &section)) {
Per Åhgrenff045112020-03-20 11:20:39 +0100218 ReadParam(section, "refined", &cfg.filter.refined);
Per Åhgren9d661982020-03-20 11:26:48 +0100219 ReadParam(section, "coarse", &cfg.filter.coarse);
Per Åhgrenff045112020-03-20 11:20:39 +0100220 ReadParam(section, "refined_initial", &cfg.filter.refined_initial);
Per Åhgren9d661982020-03-20 11:26:48 +0100221 ReadParam(section, "coarse_initial", &cfg.filter.coarse_initial);
Sam Zackrissona4c85142018-10-10 10:44:43 +0200222 ReadParam(section, "config_change_duration_blocks",
223 &cfg.filter.config_change_duration_blocks);
224 ReadParam(section, "initial_state_seconds",
225 &cfg.filter.initial_state_seconds);
Gustaf Ullberg992a96f2020-12-08 13:03:55 +0100226 ReadParam(section, "coarse_reset_hangover_blocks",
227 &cfg.filter.coarse_reset_hangover_blocks);
Sam Zackrissona4c85142018-10-10 10:44:43 +0200228 ReadParam(section, "conservative_initial_phase",
229 &cfg.filter.conservative_initial_phase);
Per Åhgren9d661982020-03-20 11:26:48 +0100230 ReadParam(section, "enable_coarse_filter_output_usage",
231 &cfg.filter.enable_coarse_filter_output_usage);
Gustaf Ullberg52caa0e2019-04-11 14:43:17 +0200232 ReadParam(section, "use_linear_filter", &cfg.filter.use_linear_filter);
Per Åhgrenc20a19c2019-11-13 11:12:29 +0100233 ReadParam(section, "export_linear_aec_output",
234 &cfg.filter.export_linear_aec_output);
Sam Zackrissona4c85142018-10-10 10:44:43 +0200235 }
236
237 if (rtc::GetValueFromJsonObject(aec3_root, "erle", &section)) {
238 ReadParam(section, "min", &cfg.erle.min);
239 ReadParam(section, "max_l", &cfg.erle.max_l);
240 ReadParam(section, "max_h", &cfg.erle.max_h);
241 ReadParam(section, "onset_detection", &cfg.erle.onset_detection);
Jesús de Vicente Peña44974e12018-11-20 12:54:23 +0100242 ReadParam(section, "num_sections", &cfg.erle.num_sections);
Per Åhgren8be669f2019-10-11 23:02:26 +0200243 ReadParam(section, "clamp_quality_estimate_to_zero",
244 &cfg.erle.clamp_quality_estimate_to_zero);
245 ReadParam(section, "clamp_quality_estimate_to_one",
246 &cfg.erle.clamp_quality_estimate_to_one);
Sam Zackrissona4c85142018-10-10 10:44:43 +0200247 }
248
249 if (rtc::GetValueFromJsonObject(aec3_root, "ep_strength", &section)) {
Per Åhgrene8efbbd2019-03-14 11:29:39 +0100250 ReadParam(section, "default_gain", &cfg.ep_strength.default_gain);
Sam Zackrissona4c85142018-10-10 10:44:43 +0200251 ReadParam(section, "default_len", &cfg.ep_strength.default_len);
Sam Zackrissona4c85142018-10-10 10:44:43 +0200252 ReadParam(section, "echo_can_saturate", &cfg.ep_strength.echo_can_saturate);
253 ReadParam(section, "bounded_erl", &cfg.ep_strength.bounded_erl);
254 }
255
Sam Zackrissona4c85142018-10-10 10:44:43 +0200256 if (rtc::GetValueFromJsonObject(aec3_root, "echo_audibility", &section)) {
257 ReadParam(section, "low_render_limit",
258 &cfg.echo_audibility.low_render_limit);
259 ReadParam(section, "normal_render_limit",
260 &cfg.echo_audibility.normal_render_limit);
261
262 ReadParam(section, "floor_power", &cfg.echo_audibility.floor_power);
263 ReadParam(section, "audibility_threshold_lf",
264 &cfg.echo_audibility.audibility_threshold_lf);
265 ReadParam(section, "audibility_threshold_mf",
266 &cfg.echo_audibility.audibility_threshold_mf);
267 ReadParam(section, "audibility_threshold_hf",
268 &cfg.echo_audibility.audibility_threshold_hf);
Jesús de Vicente Peña70a59632019-04-16 12:32:15 +0200269 ReadParam(section, "use_stationarity_properties",
270 &cfg.echo_audibility.use_stationarity_properties);
Sam Zackrisson877dc892018-10-23 14:17:38 +0200271 ReadParam(section, "use_stationarity_properties_at_init",
Sam Zackrissona4c85142018-10-10 10:44:43 +0200272 &cfg.echo_audibility.use_stationarity_properties_at_init);
273 }
274
Per Åhgren01cf44d2018-10-20 00:17:13 +0200275 if (rtc::GetValueFromJsonObject(aec3_root, "render_levels", &section)) {
276 ReadParam(section, "active_render_limit",
277 &cfg.render_levels.active_render_limit);
278 ReadParam(section, "poor_excitation_render_limit",
279 &cfg.render_levels.poor_excitation_render_limit);
280 ReadParam(section, "poor_excitation_render_limit_ds8",
281 &cfg.render_levels.poor_excitation_render_limit_ds8);
Per Åhgrenae40e192019-10-29 22:54:05 +0100282 ReadParam(section, "render_power_gain_db",
283 &cfg.render_levels.render_power_gain_db);
Per Åhgren01cf44d2018-10-20 00:17:13 +0200284 }
285
Sam Zackrissona4c85142018-10-10 10:44:43 +0200286 if (rtc::GetValueFromJsonObject(aec3_root, "echo_removal_control",
287 &section)) {
Sam Zackrissona4c85142018-10-10 10:44:43 +0200288 ReadParam(section, "has_clock_drift",
289 &cfg.echo_removal_control.has_clock_drift);
290 ReadParam(section, "linear_and_stable_echo_path",
291 &cfg.echo_removal_control.linear_and_stable_echo_path);
292 }
293
294 if (rtc::GetValueFromJsonObject(aec3_root, "echo_model", &section)) {
295 Json::Value subsection;
296 ReadParam(section, "noise_floor_hold", &cfg.echo_model.noise_floor_hold);
297 ReadParam(section, "min_noise_floor_power",
298 &cfg.echo_model.min_noise_floor_power);
299 ReadParam(section, "stationary_gate_slope",
300 &cfg.echo_model.stationary_gate_slope);
301 ReadParam(section, "noise_gate_power", &cfg.echo_model.noise_gate_power);
302 ReadParam(section, "noise_gate_slope", &cfg.echo_model.noise_gate_slope);
303 ReadParam(section, "render_pre_window_size",
304 &cfg.echo_model.render_pre_window_size);
305 ReadParam(section, "render_post_window_size",
306 &cfg.echo_model.render_post_window_size);
Sam Zackrisson389bf0f2020-10-02 21:13:13 +0200307 ReadParam(section, "model_reverb_in_nonlinear_mode",
308 &cfg.echo_model.model_reverb_in_nonlinear_mode);
Sam Zackrissona4c85142018-10-10 10:44:43 +0200309 }
310
Per Åhgrena388b752020-03-25 07:31:47 +0100311 if (rtc::GetValueFromJsonObject(aec3_root, "comfort_noise", &section)) {
312 ReadParam(section, "noise_floor_dbfs", &cfg.comfort_noise.noise_floor_dbfs);
313 }
314
Sam Zackrissona4c85142018-10-10 10:44:43 +0200315 Json::Value subsection;
316 if (rtc::GetValueFromJsonObject(aec3_root, "suppressor", &section)) {
317 ReadParam(section, "nearend_average_blocks",
318 &cfg.suppressor.nearend_average_blocks);
319
320 if (rtc::GetValueFromJsonObject(section, "normal_tuning", &subsection)) {
321 ReadParam(subsection, "mask_lf", &cfg.suppressor.normal_tuning.mask_lf);
322 ReadParam(subsection, "mask_hf", &cfg.suppressor.normal_tuning.mask_hf);
323 ReadParam(subsection, "max_inc_factor",
324 &cfg.suppressor.normal_tuning.max_inc_factor);
325 ReadParam(subsection, "max_dec_factor_lf",
326 &cfg.suppressor.normal_tuning.max_dec_factor_lf);
327 }
328
329 if (rtc::GetValueFromJsonObject(section, "nearend_tuning", &subsection)) {
330 ReadParam(subsection, "mask_lf", &cfg.suppressor.nearend_tuning.mask_lf);
331 ReadParam(subsection, "mask_hf", &cfg.suppressor.nearend_tuning.mask_hf);
332 ReadParam(subsection, "max_inc_factor",
333 &cfg.suppressor.nearend_tuning.max_inc_factor);
334 ReadParam(subsection, "max_dec_factor_lf",
335 &cfg.suppressor.nearend_tuning.max_dec_factor_lf);
336 }
337
338 if (rtc::GetValueFromJsonObject(section, "dominant_nearend_detection",
339 &subsection)) {
340 ReadParam(subsection, "enr_threshold",
341 &cfg.suppressor.dominant_nearend_detection.enr_threshold);
Gustaf Ullbergc9f9b872018-10-22 15:15:36 +0200342 ReadParam(subsection, "enr_exit_threshold",
343 &cfg.suppressor.dominant_nearend_detection.enr_exit_threshold);
Sam Zackrissona4c85142018-10-10 10:44:43 +0200344 ReadParam(subsection, "snr_threshold",
345 &cfg.suppressor.dominant_nearend_detection.snr_threshold);
346 ReadParam(subsection, "hold_duration",
347 &cfg.suppressor.dominant_nearend_detection.hold_duration);
348 ReadParam(subsection, "trigger_threshold",
349 &cfg.suppressor.dominant_nearend_detection.trigger_threshold);
Per Åhgrenfb5c1ec2018-10-24 13:02:11 +0200350 ReadParam(
351 subsection, "use_during_initial_phase",
352 &cfg.suppressor.dominant_nearend_detection.use_during_initial_phase);
Sam Zackrissona4c85142018-10-10 10:44:43 +0200353 }
354
Gustaf Ullbergf534a642019-11-25 16:13:58 +0100355 if (rtc::GetValueFromJsonObject(section, "subband_nearend_detection",
356 &subsection)) {
357 ReadParam(
358 subsection, "nearend_average_blocks",
359 &cfg.suppressor.subband_nearend_detection.nearend_average_blocks);
360 ReadParam(subsection, "subband1",
361 &cfg.suppressor.subband_nearend_detection.subband1);
362 ReadParam(subsection, "subband2",
363 &cfg.suppressor.subband_nearend_detection.subband2);
364 ReadParam(subsection, "nearend_threshold",
365 &cfg.suppressor.subband_nearend_detection.nearend_threshold);
366 ReadParam(subsection, "snr_threshold",
367 &cfg.suppressor.subband_nearend_detection.snr_threshold);
368 }
369
370 ReadParam(section, "use_subband_nearend_detection",
371 &cfg.suppressor.use_subband_nearend_detection);
372
Sam Zackrissona4c85142018-10-10 10:44:43 +0200373 if (rtc::GetValueFromJsonObject(section, "high_bands_suppression",
374 &subsection)) {
375 ReadParam(subsection, "enr_threshold",
376 &cfg.suppressor.high_bands_suppression.enr_threshold);
377 ReadParam(subsection, "max_gain_during_echo",
378 &cfg.suppressor.high_bands_suppression.max_gain_during_echo);
Per Åhgren17e4c582019-11-27 08:13:24 +0100379 ReadParam(subsection, "anti_howling_activation_threshold",
380 &cfg.suppressor.high_bands_suppression
381 .anti_howling_activation_threshold);
382 ReadParam(subsection, "anti_howling_gain",
383 &cfg.suppressor.high_bands_suppression.anti_howling_gain);
Sam Zackrissona4c85142018-10-10 10:44:43 +0200384 }
385
386 ReadParam(section, "floor_first_increase",
387 &cfg.suppressor.floor_first_increase);
Gustaf Ullberg7e4ad822020-10-22 14:36:37 +0200388 ReadParam(section, "conservative_hf_suppression",
389 &cfg.suppressor.conservative_hf_suppression);
Sam Zackrissona4c85142018-10-10 10:44:43 +0200390 }
Per Åhgren370bae42018-10-25 11:32:39 +0200391}
392
393EchoCanceller3Config Aec3ConfigFromJsonString(absl::string_view json_string) {
394 EchoCanceller3Config cfg;
395 bool not_used;
396 Aec3ConfigFromJsonString(json_string, &cfg, &not_used);
Sam Zackrissona4c85142018-10-10 10:44:43 +0200397 return cfg;
398}
399
400std::string Aec3ConfigToJsonString(const EchoCanceller3Config& config) {
401 rtc::StringBuilder ost;
402 ost << "{";
403 ost << "\"aec3\": {";
Per Åhgrenc1d20922019-04-22 23:36:58 +0200404 ost << "\"buffering\": {";
405 ost << "\"excess_render_detection_interval_blocks\": "
406 << config.buffering.excess_render_detection_interval_blocks << ",";
407 ost << "\"max_allowed_excess_render_blocks\": "
408 << config.buffering.max_allowed_excess_render_blocks;
409 ost << "},";
410
Sam Zackrissona4c85142018-10-10 10:44:43 +0200411 ost << "\"delay\": {";
412 ost << "\"default_delay\": " << config.delay.default_delay << ",";
413 ost << "\"down_sampling_factor\": " << config.delay.down_sampling_factor
414 << ",";
415 ost << "\"num_filters\": " << config.delay.num_filters << ",";
Gustaf Ullberg9249fbf2019-03-14 11:24:54 +0100416 ost << "\"delay_headroom_samples\": " << config.delay.delay_headroom_samples
Sam Zackrissona4c85142018-10-10 10:44:43 +0200417 << ",";
Gustaf Ullberg9249fbf2019-03-14 11:24:54 +0100418 ost << "\"hysteresis_limit_blocks\": " << config.delay.hysteresis_limit_blocks
419 << ",";
Sam Zackrissona4c85142018-10-10 10:44:43 +0200420 ost << "\"fixed_capture_delay_samples\": "
421 << config.delay.fixed_capture_delay_samples << ",";
422 ost << "\"delay_estimate_smoothing\": "
423 << config.delay.delay_estimate_smoothing << ",";
424 ost << "\"delay_candidate_detection_threshold\": "
425 << config.delay.delay_candidate_detection_threshold << ",";
426
427 ost << "\"delay_selection_thresholds\": {";
428 ost << "\"initial\": " << config.delay.delay_selection_thresholds.initial
429 << ",";
430 ost << "\"converged\": " << config.delay.delay_selection_thresholds.converged;
Gustaf Ullbergee84d392019-09-10 09:36:43 +0200431 ost << "},";
Sam Zackrissona4c85142018-10-10 10:44:43 +0200432
Gustaf Ullbergee84d392019-09-10 09:36:43 +0200433 ost << "\"use_external_delay_estimator\": "
434 << (config.delay.use_external_delay_estimator ? "true" : "false") << ",";
Sam Zackrissonffc84522019-10-15 13:43:02 +0200435 ost << "\"log_warning_on_delay_changes\": "
Per Åhgren6a05bb12019-12-03 11:24:59 +0100436 << (config.delay.log_warning_on_delay_changes ? "true" : "false") << ",";
437
438 ost << "\"render_alignment_mixing\": {";
439 ost << "\"downmix\": "
440 << (config.delay.render_alignment_mixing.downmix ? "true" : "false")
441 << ",";
442 ost << "\"adaptive_selection\": "
443 << (config.delay.render_alignment_mixing.adaptive_selection ? "true"
444 : "false")
445 << ",";
446 ost << "\"activity_power_threshold\": "
447 << config.delay.render_alignment_mixing.activity_power_threshold << ",";
448 ost << "\"prefer_first_two_channels\": "
449 << (config.delay.render_alignment_mixing.prefer_first_two_channels
450 ? "true"
451 : "false");
452 ost << "},";
453
454 ost << "\"capture_alignment_mixing\": {";
455 ost << "\"downmix\": "
456 << (config.delay.capture_alignment_mixing.downmix ? "true" : "false")
457 << ",";
458 ost << "\"adaptive_selection\": "
459 << (config.delay.capture_alignment_mixing.adaptive_selection ? "true"
460 : "false")
461 << ",";
462 ost << "\"activity_power_threshold\": "
463 << config.delay.capture_alignment_mixing.activity_power_threshold << ",";
464 ost << "\"prefer_first_two_channels\": "
465 << (config.delay.capture_alignment_mixing.prefer_first_two_channels
466 ? "true"
467 : "false");
468 ost << "}";
Sam Zackrissona4c85142018-10-10 10:44:43 +0200469 ost << "},";
470
471 ost << "\"filter\": {";
Sam Zackrissona4c85142018-10-10 10:44:43 +0200472
Per Åhgrenff045112020-03-20 11:20:39 +0100473 ost << "\"refined\": [";
474 ost << config.filter.refined.length_blocks << ",";
475 ost << config.filter.refined.leakage_converged << ",";
476 ost << config.filter.refined.leakage_diverged << ",";
477 ost << config.filter.refined.error_floor << ",";
478 ost << config.filter.refined.error_ceil << ",";
479 ost << config.filter.refined.noise_gate;
480 ost << "],";
481
Per Åhgren9d661982020-03-20 11:26:48 +0100482 ost << "\"coarse\": [";
483 ost << config.filter.coarse.length_blocks << ",";
484 ost << config.filter.coarse.rate << ",";
485 ost << config.filter.coarse.noise_gate;
486 ost << "],";
487
Per Åhgrenff045112020-03-20 11:20:39 +0100488 ost << "\"refined_initial\": [";
489 ost << config.filter.refined_initial.length_blocks << ",";
490 ost << config.filter.refined_initial.leakage_converged << ",";
491 ost << config.filter.refined_initial.leakage_diverged << ",";
492 ost << config.filter.refined_initial.error_floor << ",";
493 ost << config.filter.refined_initial.error_ceil << ",";
494 ost << config.filter.refined_initial.noise_gate;
495 ost << "],";
496
Per Åhgren9d661982020-03-20 11:26:48 +0100497 ost << "\"coarse_initial\": [";
498 ost << config.filter.coarse_initial.length_blocks << ",";
499 ost << config.filter.coarse_initial.rate << ",";
500 ost << config.filter.coarse_initial.noise_gate;
501 ost << "],";
502
Sam Zackrissona4c85142018-10-10 10:44:43 +0200503 ost << "\"config_change_duration_blocks\": "
504 << config.filter.config_change_duration_blocks << ",";
505 ost << "\"initial_state_seconds\": " << config.filter.initial_state_seconds
506 << ",";
Gustaf Ullberg992a96f2020-12-08 13:03:55 +0100507 ost << "\"coarse_reset_hangover_blocks\": "
508 << config.filter.coarse_reset_hangover_blocks << ",";
Sam Zackrissona4c85142018-10-10 10:44:43 +0200509 ost << "\"conservative_initial_phase\": "
510 << (config.filter.conservative_initial_phase ? "true" : "false") << ",";
Per Åhgren9d661982020-03-20 11:26:48 +0100511 ost << "\"enable_coarse_filter_output_usage\": "
512 << (config.filter.enable_coarse_filter_output_usage ? "true" : "false")
513 << ",";
Per Åhgrenc20a19c2019-11-13 11:12:29 +0100514 ost << "\"use_linear_filter\": "
515 << (config.filter.use_linear_filter ? "true" : "false") << ",";
516 ost << "\"export_linear_aec_output\": "
Per Åhgrene1562872020-04-09 13:12:08 +0200517 << (config.filter.export_linear_aec_output ? "true" : "false");
Sam Zackrissona4c85142018-10-10 10:44:43 +0200518
519 ost << "},";
520
521 ost << "\"erle\": {";
522 ost << "\"min\": " << config.erle.min << ",";
523 ost << "\"max_l\": " << config.erle.max_l << ",";
524 ost << "\"max_h\": " << config.erle.max_h << ",";
525 ost << "\"onset_detection\": "
Jesús de Vicente Peña44974e12018-11-20 12:54:23 +0100526 << (config.erle.onset_detection ? "true" : "false") << ",";
Per Åhgren8be669f2019-10-11 23:02:26 +0200527 ost << "\"num_sections\": " << config.erle.num_sections << ",";
528 ost << "\"clamp_quality_estimate_to_zero\": "
529 << (config.erle.clamp_quality_estimate_to_zero ? "true" : "false") << ",";
530 ost << "\"clamp_quality_estimate_to_one\": "
531 << (config.erle.clamp_quality_estimate_to_one ? "true" : "false");
Sam Zackrissona4c85142018-10-10 10:44:43 +0200532 ost << "},";
533
534 ost << "\"ep_strength\": {";
Per Åhgrene8efbbd2019-03-14 11:29:39 +0100535 ost << "\"default_gain\": " << config.ep_strength.default_gain << ",";
Sam Zackrissona4c85142018-10-10 10:44:43 +0200536 ost << "\"default_len\": " << config.ep_strength.default_len << ",";
Sam Zackrissona4c85142018-10-10 10:44:43 +0200537 ost << "\"echo_can_saturate\": "
538 << (config.ep_strength.echo_can_saturate ? "true" : "false") << ",";
539 ost << "\"bounded_erl\": "
540 << (config.ep_strength.bounded_erl ? "true" : "false");
541
542 ost << "},";
543
Sam Zackrissona4c85142018-10-10 10:44:43 +0200544 ost << "\"echo_audibility\": {";
545 ost << "\"low_render_limit\": " << config.echo_audibility.low_render_limit
546 << ",";
547 ost << "\"normal_render_limit\": "
548 << config.echo_audibility.normal_render_limit << ",";
549 ost << "\"floor_power\": " << config.echo_audibility.floor_power << ",";
550 ost << "\"audibility_threshold_lf\": "
551 << config.echo_audibility.audibility_threshold_lf << ",";
552 ost << "\"audibility_threshold_mf\": "
553 << config.echo_audibility.audibility_threshold_mf << ",";
554 ost << "\"audibility_threshold_hf\": "
555 << config.echo_audibility.audibility_threshold_hf << ",";
Jesús de Vicente Peña70a59632019-04-16 12:32:15 +0200556 ost << "\"use_stationarity_properties\": "
557 << (config.echo_audibility.use_stationarity_properties ? "true" : "false")
Sam Zackrissona4c85142018-10-10 10:44:43 +0200558 << ",";
559 ost << "\"use_stationarity_properties_at_init\": "
560 << (config.echo_audibility.use_stationarity_properties_at_init ? "true"
561 : "false");
562 ost << "},";
563
564 ost << "\"render_levels\": {";
565 ost << "\"active_render_limit\": " << config.render_levels.active_render_limit
566 << ",";
567 ost << "\"poor_excitation_render_limit\": "
568 << config.render_levels.poor_excitation_render_limit << ",";
569 ost << "\"poor_excitation_render_limit_ds8\": "
Per Åhgrenae40e192019-10-29 22:54:05 +0100570 << config.render_levels.poor_excitation_render_limit_ds8 << ",";
571 ost << "\"render_power_gain_db\": "
572 << config.render_levels.render_power_gain_db;
Sam Zackrissona4c85142018-10-10 10:44:43 +0200573 ost << "},";
574
575 ost << "\"echo_removal_control\": {";
Sam Zackrissona4c85142018-10-10 10:44:43 +0200576 ost << "\"has_clock_drift\": "
577 << (config.echo_removal_control.has_clock_drift ? "true" : "false")
578 << ",";
579 ost << "\"linear_and_stable_echo_path\": "
580 << (config.echo_removal_control.linear_and_stable_echo_path ? "true"
581 : "false");
582
583 ost << "},";
584
585 ost << "\"echo_model\": {";
586 ost << "\"noise_floor_hold\": " << config.echo_model.noise_floor_hold << ",";
587 ost << "\"min_noise_floor_power\": "
588 << config.echo_model.min_noise_floor_power << ",";
589 ost << "\"stationary_gate_slope\": "
590 << config.echo_model.stationary_gate_slope << ",";
591 ost << "\"noise_gate_power\": " << config.echo_model.noise_gate_power << ",";
592 ost << "\"noise_gate_slope\": " << config.echo_model.noise_gate_slope << ",";
593 ost << "\"render_pre_window_size\": "
594 << config.echo_model.render_pre_window_size << ",";
595 ost << "\"render_post_window_size\": "
Sam Zackrisson389bf0f2020-10-02 21:13:13 +0200596 << config.echo_model.render_post_window_size << ",";
597 ost << "\"model_reverb_in_nonlinear_mode\": "
598 << (config.echo_model.model_reverb_in_nonlinear_mode ? "true" : "false");
Sam Zackrissona4c85142018-10-10 10:44:43 +0200599 ost << "},";
600
Per Åhgrena388b752020-03-25 07:31:47 +0100601 ost << "\"comfort_noise\": {";
602 ost << "\"noise_floor_dbfs\": " << config.comfort_noise.noise_floor_dbfs;
603 ost << "},";
604
Sam Zackrissona4c85142018-10-10 10:44:43 +0200605 ost << "\"suppressor\": {";
606 ost << "\"nearend_average_blocks\": "
607 << config.suppressor.nearend_average_blocks << ",";
608 ost << "\"normal_tuning\": {";
609 ost << "\"mask_lf\": [";
610 ost << config.suppressor.normal_tuning.mask_lf.enr_transparent << ",";
611 ost << config.suppressor.normal_tuning.mask_lf.enr_suppress << ",";
612 ost << config.suppressor.normal_tuning.mask_lf.emr_transparent;
613 ost << "],";
614 ost << "\"mask_hf\": [";
615 ost << config.suppressor.normal_tuning.mask_hf.enr_transparent << ",";
616 ost << config.suppressor.normal_tuning.mask_hf.enr_suppress << ",";
617 ost << config.suppressor.normal_tuning.mask_hf.emr_transparent;
618 ost << "],";
619 ost << "\"max_inc_factor\": "
620 << config.suppressor.normal_tuning.max_inc_factor << ",";
621 ost << "\"max_dec_factor_lf\": "
622 << config.suppressor.normal_tuning.max_dec_factor_lf;
623 ost << "},";
624 ost << "\"nearend_tuning\": {";
625 ost << "\"mask_lf\": [";
626 ost << config.suppressor.nearend_tuning.mask_lf.enr_transparent << ",";
627 ost << config.suppressor.nearend_tuning.mask_lf.enr_suppress << ",";
628 ost << config.suppressor.nearend_tuning.mask_lf.emr_transparent;
629 ost << "],";
630 ost << "\"mask_hf\": [";
631 ost << config.suppressor.nearend_tuning.mask_hf.enr_transparent << ",";
632 ost << config.suppressor.nearend_tuning.mask_hf.enr_suppress << ",";
633 ost << config.suppressor.nearend_tuning.mask_hf.emr_transparent;
634 ost << "],";
635 ost << "\"max_inc_factor\": "
636 << config.suppressor.nearend_tuning.max_inc_factor << ",";
637 ost << "\"max_dec_factor_lf\": "
638 << config.suppressor.nearend_tuning.max_dec_factor_lf;
639 ost << "},";
640 ost << "\"dominant_nearend_detection\": {";
641 ost << "\"enr_threshold\": "
642 << config.suppressor.dominant_nearend_detection.enr_threshold << ",";
Gustaf Ullbergc9f9b872018-10-22 15:15:36 +0200643 ost << "\"enr_exit_threshold\": "
644 << config.suppressor.dominant_nearend_detection.enr_exit_threshold << ",";
Sam Zackrissona4c85142018-10-10 10:44:43 +0200645 ost << "\"snr_threshold\": "
646 << config.suppressor.dominant_nearend_detection.snr_threshold << ",";
647 ost << "\"hold_duration\": "
648 << config.suppressor.dominant_nearend_detection.hold_duration << ",";
649 ost << "\"trigger_threshold\": "
Per Åhgrenfb5c1ec2018-10-24 13:02:11 +0200650 << config.suppressor.dominant_nearend_detection.trigger_threshold << ",";
651 ost << "\"use_during_initial_phase\": "
652 << config.suppressor.dominant_nearend_detection.use_during_initial_phase;
Sam Zackrissona4c85142018-10-10 10:44:43 +0200653 ost << "},";
Gustaf Ullbergf534a642019-11-25 16:13:58 +0100654 ost << "\"subband_nearend_detection\": {";
655 ost << "\"nearend_average_blocks\": "
656 << config.suppressor.subband_nearend_detection.nearend_average_blocks
657 << ",";
658 ost << "\"subband1\": [";
659 ost << config.suppressor.subband_nearend_detection.subband1.low << ",";
660 ost << config.suppressor.subband_nearend_detection.subband1.high;
661 ost << "],";
662 ost << "\"subband2\": [";
663 ost << config.suppressor.subband_nearend_detection.subband2.low << ",";
664 ost << config.suppressor.subband_nearend_detection.subband2.high;
665 ost << "],";
666 ost << "\"nearend_threshold\": "
667 << config.suppressor.subband_nearend_detection.nearend_threshold << ",";
668 ost << "\"snr_threshold\": "
669 << config.suppressor.subband_nearend_detection.snr_threshold;
670 ost << "},";
671 ost << "\"use_subband_nearend_detection\": "
672 << config.suppressor.use_subband_nearend_detection << ",";
Sam Zackrissona4c85142018-10-10 10:44:43 +0200673 ost << "\"high_bands_suppression\": {";
674 ost << "\"enr_threshold\": "
675 << config.suppressor.high_bands_suppression.enr_threshold << ",";
676 ost << "\"max_gain_during_echo\": "
Per Åhgren17e4c582019-11-27 08:13:24 +0100677 << config.suppressor.high_bands_suppression.max_gain_during_echo << ",";
678 ost << "\"anti_howling_activation_threshold\": "
679 << config.suppressor.high_bands_suppression
680 .anti_howling_activation_threshold
681 << ",";
682 ost << "\"anti_howling_gain\": "
683 << config.suppressor.high_bands_suppression.anti_howling_gain;
Sam Zackrissona4c85142018-10-10 10:44:43 +0200684 ost << "},";
Gustaf Ullberg7e4ad822020-10-22 14:36:37 +0200685 ost << "\"floor_first_increase\": " << config.suppressor.floor_first_increase
686 << ",";
687 ost << "\"conservative_hf_suppression\": "
688 << config.suppressor.conservative_hf_suppression;
Sam Zackrissona4c85142018-10-10 10:44:43 +0200689 ost << "}";
690 ost << "}";
691 ost << "}";
692
693 return ost.Release();
694}
695} // namespace webrtc