blob: 119a4011e1fe854124d92edf9b7f204f655482b0 [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>
Jonas Olssona4d87372019-07-05 19:08:33 +020015
Sebastian Janssoncabe3832018-01-12 10:54:18 +010016#include <string>
17
Per Kjellander5b698732019-04-15 12:36:33 +020018#include "api/transport/field_trial_based_config.h"
Sebastian Janssoncabe3832018-01-12 10:54:18 +010019#include "rtc_base/logging.h"
Sebastian Janssoncabe3832018-01-12 10:54:18 +010020
21namespace webrtc {
22
23const char AlrExperimentSettings::kScreenshareProbingBweExperimentName[] =
24 "WebRTC-ProbingScreenshareBwe";
25const char AlrExperimentSettings::kStrictPacingAndProbingExperimentName[] =
26 "WebRTC-StrictPacingAndProbing";
27const char kDefaultProbingScreenshareBweSettings[] = "1.0,2875,80,40,-60,3";
28
29bool AlrExperimentSettings::MaxOneFieldTrialEnabled() {
Per Kjellander5b698732019-04-15 12:36:33 +020030 return AlrExperimentSettings::MaxOneFieldTrialEnabled(
31 FieldTrialBasedConfig());
32}
33
34bool AlrExperimentSettings::MaxOneFieldTrialEnabled(
35 const WebRtcKeyValueConfig& key_value_config) {
36 return key_value_config.Lookup(kStrictPacingAndProbingExperimentName)
Sebastian Janssoncabe3832018-01-12 10:54:18 +010037 .empty() ||
Per Kjellander5b698732019-04-15 12:36:33 +020038 key_value_config.Lookup(kScreenshareProbingBweExperimentName).empty();
Sebastian Janssoncabe3832018-01-12 10:54:18 +010039}
40
Danil Chapovalov0a1d1892018-06-21 11:48:25 +020041absl::optional<AlrExperimentSettings>
Sebastian Janssoncabe3832018-01-12 10:54:18 +010042AlrExperimentSettings::CreateFromFieldTrial(const char* experiment_name) {
Per Kjellander5b698732019-04-15 12:36:33 +020043 return AlrExperimentSettings::CreateFromFieldTrial(FieldTrialBasedConfig(),
44 experiment_name);
45}
46
47absl::optional<AlrExperimentSettings>
48AlrExperimentSettings::CreateFromFieldTrial(
49 const WebRtcKeyValueConfig& key_value_config,
50 const char* experiment_name) {
Danil Chapovalov0a1d1892018-06-21 11:48:25 +020051 absl::optional<AlrExperimentSettings> ret;
Per Kjellander5b698732019-04-15 12:36:33 +020052 std::string group_name = key_value_config.Lookup(experiment_name);
Sebastian Janssoncabe3832018-01-12 10:54:18 +010053
54 const std::string kIgnoredSuffix = "_Dogfood";
55 std::string::size_type suffix_pos = group_name.rfind(kIgnoredSuffix);
56 if (suffix_pos != std::string::npos &&
57 suffix_pos == group_name.length() - kIgnoredSuffix.length()) {
58 group_name.resize(group_name.length() - kIgnoredSuffix.length());
59 }
60
Erik Språng1c1b1ea2019-04-03 20:20:42 +020061 if (group_name.empty()) {
62 if (experiment_name == kScreenshareProbingBweExperimentName) {
63 // This experiment is now default-on with fixed settings.
64 // TODO(sprang): Remove this kill-switch and clean up experiment code.
Sebastian Janssoncabe3832018-01-12 10:54:18 +010065 group_name = kDefaultProbingScreenshareBweSettings;
Erik Språng1c1b1ea2019-04-03 20:20:42 +020066 } else {
67 return ret;
Sebastian Janssoncabe3832018-01-12 10:54:18 +010068 }
69 }
70
Sebastian Janssoncabe3832018-01-12 10:54:18 +010071 AlrExperimentSettings settings;
72 if (sscanf(group_name.c_str(), "%f,%" PRId64 ",%d,%d,%d,%d",
73 &settings.pacing_factor, &settings.max_paced_queue_time,
74 &settings.alr_bandwidth_usage_percent,
75 &settings.alr_start_budget_level_percent,
76 &settings.alr_stop_budget_level_percent,
77 &settings.group_id) == 6) {
78 ret.emplace(settings);
79 RTC_LOG(LS_INFO) << "Using ALR experiment settings: "
80 "pacing factor: "
81 << settings.pacing_factor << ", max pacer queue length: "
82 << settings.max_paced_queue_time
Bjorn Terelius787f4b22019-05-28 13:00:26 +020083 << ", ALR bandwidth usage percent: "
Sebastian Janssoncabe3832018-01-12 10:54:18 +010084 << settings.alr_bandwidth_usage_percent
Bjorn Terelius787f4b22019-05-28 13:00:26 +020085 << ", ALR start budget level percent: "
Sebastian Janssoncabe3832018-01-12 10:54:18 +010086 << settings.alr_start_budget_level_percent
87 << ", ALR end budget level percent: "
88 << settings.alr_stop_budget_level_percent
89 << ", ALR experiment group ID: " << settings.group_id;
90 } else {
91 RTC_LOG(LS_INFO) << "Failed to parse ALR experiment: " << experiment_name;
92 }
93
94 return ret;
95}
96
97} // namespace webrtc