/* * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. * * Use of this source code is governed by a BSD-style license * that can be found in the LICENSE file in the root of the source * tree. An additional intellectual property rights grant can be found * in the file PATENTS. All contributing project authors may * be found in the AUTHORS file in the root of the source tree. */ #ifndef MODULES_CONGESTION_CONTROLLER_GOOG_CC_ALR_DETECTOR_H_ #define MODULES_CONGESTION_CONTROLLER_GOOG_CC_ALR_DETECTOR_H_ #include #include #include #include "absl/types/optional.h" #include "api/field_trials_view.h" #include "modules/pacing/interval_budget.h" #include "rtc_base/experiments/alr_experiment.h" #include "rtc_base/experiments/struct_parameters_parser.h" namespace webrtc { class RtcEventLog; struct AlrDetectorConfig { // Sent traffic ratio as a function of network capacity used to determine // application-limited region. ALR region start when bandwidth usage drops // below kAlrStartUsageRatio and ends when it raises above // kAlrEndUsageRatio. NOTE: This is intentionally conservative at the moment // until BW adjustments of application limited region is fine tuned. double bandwidth_usage_ratio = 0.65; double start_budget_level_ratio = 0.80; double stop_budget_level_ratio = 0.50; std::unique_ptr Parser(); }; // Application limited region detector is a class that utilizes signals of // elapsed time and bytes sent to estimate whether network traffic is // currently limited by the application's ability to generate traffic. // // AlrDetector provides a signal that can be utilized to adjust // estimate bandwidth. // Note: This class is not thread-safe. class AlrDetector { public: AlrDetector(AlrDetectorConfig config, RtcEventLog* event_log); explicit AlrDetector(const FieldTrialsView* key_value_config); AlrDetector(const FieldTrialsView* key_value_config, RtcEventLog* event_log); ~AlrDetector(); void OnBytesSent(size_t bytes_sent, int64_t send_time_ms); // Set current estimated bandwidth. void SetEstimatedBitrate(int bitrate_bps); // Returns time in milliseconds when the current application-limited region // started or empty result if the sender is currently not application-limited. absl::optional GetApplicationLimitedRegionStartTime() const; private: friend class GoogCcStatePrinter; const AlrDetectorConfig conf_; absl::optional last_send_time_ms_; IntervalBudget alr_budget_; absl::optional alr_started_time_ms_; RtcEventLog* event_log_; }; } // namespace webrtc #endif // MODULES_CONGESTION_CONTROLLER_GOOG_CC_ALR_DETECTOR_H_