blob: d805cb3998c5b318808171f5b68266ceac0d8a7e [file] [log] [blame]
Sebastian Janssoncabe3832018-01-12 10:54:18 +01001/*
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#include "rtc_base/experiments/alr_experiment.h"
12
Yves Gerey988cc082018-10-23 12:03:01 +020013#include <inttypes.h>
14#include <stdio.h>
Sebastian Janssoncabe3832018-01-12 10:54:18 +010015#include <string>
16
Per Kjellander5b698732019-04-15 12:36:33 +020017#include "api/transport/field_trial_based_config.h"
Sebastian Janssoncabe3832018-01-12 10:54:18 +010018#include "rtc_base/logging.h"
Sebastian Janssoncabe3832018-01-12 10:54:18 +010019
20namespace webrtc {
21
22const char AlrExperimentSettings::kScreenshareProbingBweExperimentName[] =
23 "WebRTC-ProbingScreenshareBwe";
24const char AlrExperimentSettings::kStrictPacingAndProbingExperimentName[] =
25 "WebRTC-StrictPacingAndProbing";
26const char kDefaultProbingScreenshareBweSettings[] = "1.0,2875,80,40,-60,3";
27
28bool AlrExperimentSettings::MaxOneFieldTrialEnabled() {
Per Kjellander5b698732019-04-15 12:36:33 +020029 return AlrExperimentSettings::MaxOneFieldTrialEnabled(
30 FieldTrialBasedConfig());
31}
32
33bool AlrExperimentSettings::MaxOneFieldTrialEnabled(
34 const WebRtcKeyValueConfig& key_value_config) {
35 return key_value_config.Lookup(kStrictPacingAndProbingExperimentName)
Sebastian Janssoncabe3832018-01-12 10:54:18 +010036 .empty() ||
Per Kjellander5b698732019-04-15 12:36:33 +020037 key_value_config.Lookup(kScreenshareProbingBweExperimentName).empty();
Sebastian Janssoncabe3832018-01-12 10:54:18 +010038}
39
Danil Chapovalov0a1d1892018-06-21 11:48:25 +020040absl::optional<AlrExperimentSettings>
Sebastian Janssoncabe3832018-01-12 10:54:18 +010041AlrExperimentSettings::CreateFromFieldTrial(const char* experiment_name) {
Per Kjellander5b698732019-04-15 12:36:33 +020042 return AlrExperimentSettings::CreateFromFieldTrial(FieldTrialBasedConfig(),
43 experiment_name);
44}
45
46absl::optional<AlrExperimentSettings>
47AlrExperimentSettings::CreateFromFieldTrial(
48 const WebRtcKeyValueConfig& key_value_config,
49 const char* experiment_name) {
Danil Chapovalov0a1d1892018-06-21 11:48:25 +020050 absl::optional<AlrExperimentSettings> ret;
Per Kjellander5b698732019-04-15 12:36:33 +020051 std::string group_name = key_value_config.Lookup(experiment_name);
Sebastian Janssoncabe3832018-01-12 10:54:18 +010052
53 const std::string kIgnoredSuffix = "_Dogfood";
54 std::string::size_type suffix_pos = group_name.rfind(kIgnoredSuffix);
55 if (suffix_pos != std::string::npos &&
56 suffix_pos == group_name.length() - kIgnoredSuffix.length()) {
57 group_name.resize(group_name.length() - kIgnoredSuffix.length());
58 }
59
Erik Språng1c1b1ea2019-04-03 20:20:42 +020060 if (group_name.empty()) {
61 if (experiment_name == kScreenshareProbingBweExperimentName) {
62 // This experiment is now default-on with fixed settings.
63 // TODO(sprang): Remove this kill-switch and clean up experiment code.
Sebastian Janssoncabe3832018-01-12 10:54:18 +010064 group_name = kDefaultProbingScreenshareBweSettings;
Erik Språng1c1b1ea2019-04-03 20:20:42 +020065 } else {
66 return ret;
Sebastian Janssoncabe3832018-01-12 10:54:18 +010067 }
68 }
69
Sebastian Janssoncabe3832018-01-12 10:54:18 +010070 AlrExperimentSettings settings;
71 if (sscanf(group_name.c_str(), "%f,%" PRId64 ",%d,%d,%d,%d",
72 &settings.pacing_factor, &settings.max_paced_queue_time,
73 &settings.alr_bandwidth_usage_percent,
74 &settings.alr_start_budget_level_percent,
75 &settings.alr_stop_budget_level_percent,
76 &settings.group_id) == 6) {
77 ret.emplace(settings);
78 RTC_LOG(LS_INFO) << "Using ALR experiment settings: "
79 "pacing factor: "
80 << settings.pacing_factor << ", max pacer queue length: "
81 << settings.max_paced_queue_time
Bjorn Terelius787f4b22019-05-28 13:00:26 +020082 << ", ALR bandwidth usage percent: "
Sebastian Janssoncabe3832018-01-12 10:54:18 +010083 << settings.alr_bandwidth_usage_percent
Bjorn Terelius787f4b22019-05-28 13:00:26 +020084 << ", ALR start budget level percent: "
Sebastian Janssoncabe3832018-01-12 10:54:18 +010085 << settings.alr_start_budget_level_percent
86 << ", ALR end budget level percent: "
87 << settings.alr_stop_budget_level_percent
88 << ", ALR experiment group ID: " << settings.group_id;
89 } else {
90 RTC_LOG(LS_INFO) << "Failed to parse ALR experiment: " << experiment_name;
91 }
92
93 return ret;
94}
95
96} // namespace webrtc