blob: 5066e6ff798b7166860ed1e54e1a1ba01228b353 [file] [log] [blame]
isheriff31687812016-10-04 08:43:09 -07001/*
2 * Copyright (c) 2016 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 "webrtc/modules/pacing/alr_detector.h"
12
sprang89c4a7e2017-06-30 13:27:40 -070013#include <string>
14
Henrik Kjellanderdca1e092017-07-01 16:42:22 +020015#include "webrtc/base/checks.h"
16#include "webrtc/base/format_macros.h"
17#include "webrtc/base/logging.h"
sprang89c4a7e2017-06-30 13:27:40 -070018#include "webrtc/system_wrappers/include/field_trial.h"
isheriff31687812016-10-04 08:43:09 -070019
20namespace {
Sergey Ulanov0182f852016-11-16 15:42:11 -080021// Time period over which outgoing traffic is measured.
22constexpr int kMeasurementPeriodMs = 500;
isheriff31687812016-10-04 08:43:09 -070023
isheriff31687812016-10-04 08:43:09 -070024} // namespace
25
26namespace webrtc {
27
sprang89c4a7e2017-06-30 13:27:40 -070028const char* AlrDetector::kScreenshareProbingBweExperimentName =
29 "WebRTC-ProbingScreenshareBwe";
30
isheriff31687812016-10-04 08:43:09 -070031AlrDetector::AlrDetector()
sprang89c4a7e2017-06-30 13:27:40 -070032 : alr_start_usage_percent_(kDefaultAlrStartUsagePercent),
33 alr_end_usage_percent_(kDefaultAlrEndUsagePercent),
34 rate_(kMeasurementPeriodMs, RateStatistics::kBpsScale),
35 estimated_bitrate_bps_(0) {
36 rtc::Optional<AlrExperimentSettings> experiment_settings =
37 ParseAlrSettingsFromFieldTrial();
38 if (experiment_settings) {
39 alr_start_usage_percent_ = experiment_settings->alr_start_usage_percent;
40 alr_end_usage_percent_ = experiment_settings->alr_end_usage_percent;
41 }
42}
isheriff31687812016-10-04 08:43:09 -070043
44AlrDetector::~AlrDetector() {}
45
Sergey Ulanov0182f852016-11-16 15:42:11 -080046void AlrDetector::OnBytesSent(size_t bytes_sent, int64_t now_ms) {
47 RTC_DCHECK(estimated_bitrate_bps_);
48
49 rate_.Update(bytes_sent, now_ms);
50 rtc::Optional<uint32_t> rate = rate_.Rate(now_ms);
51 if (!rate)
52 return;
53
54 int percentage = static_cast<int>(*rate) * 100 / estimated_bitrate_bps_;
sprang89c4a7e2017-06-30 13:27:40 -070055 if (percentage < alr_start_usage_percent_ && !alr_started_time_ms_) {
sergeyu80ed35e2016-11-28 13:11:13 -080056 alr_started_time_ms_ = rtc::Optional<int64_t>(now_ms);
sprang89c4a7e2017-06-30 13:27:40 -070057 } else if (percentage > alr_end_usage_percent_ && alr_started_time_ms_) {
sergeyu80ed35e2016-11-28 13:11:13 -080058 alr_started_time_ms_ = rtc::Optional<int64_t>();
isheriff31687812016-10-04 08:43:09 -070059 }
60}
61
62void AlrDetector::SetEstimatedBitrate(int bitrate_bps) {
63 RTC_DCHECK(bitrate_bps);
64 estimated_bitrate_bps_ = bitrate_bps;
65}
66
sergeyu80ed35e2016-11-28 13:11:13 -080067rtc::Optional<int64_t> AlrDetector::GetApplicationLimitedRegionStartTime()
68 const {
69 return alr_started_time_ms_;
isheriff31687812016-10-04 08:43:09 -070070}
71
sprang89c4a7e2017-06-30 13:27:40 -070072rtc::Optional<AlrDetector::AlrExperimentSettings>
73AlrDetector::ParseAlrSettingsFromFieldTrial() {
74 rtc::Optional<AlrExperimentSettings> ret;
75 std::string group_name =
76 field_trial::FindFullName(kScreenshareProbingBweExperimentName);
77
78 const std::string kIgnoredSuffix = "_Dogfood";
79 if (group_name.rfind(kIgnoredSuffix) ==
80 group_name.length() - kIgnoredSuffix.length()) {
81 group_name.resize(group_name.length() - kIgnoredSuffix.length());
82 }
83
84 if (group_name.empty())
85 return ret;
86
87 AlrExperimentSettings settings;
88 if (sscanf(group_name.c_str(), "%f-%" PRId64 "-%d-%d",
89 &settings.pacing_factor, &settings.max_paced_queue_time,
90 &settings.alr_start_usage_percent,
91 &settings.alr_end_usage_percent) == 4) {
92 ret.emplace(settings);
93 LOG(LS_INFO) << "Using screenshare ALR experiment settings: "
94 "pacing factor: "
95 << settings.pacing_factor << ", max pacer queue length: "
96 << settings.max_paced_queue_time
97 << ", ALR start usage percent: "
98 << settings.alr_start_usage_percent
99 << ", ALR end usage percent: "
100 << settings.alr_end_usage_percent;
101 }
102
103 return ret;
104}
105
isheriff31687812016-10-04 08:43:09 -0700106} // namespace webrtc