|  | /* | 
|  | *  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 WEBRTC_MODULES_PACING_ALR_DETECTOR_H_ | 
|  | #define WEBRTC_MODULES_PACING_ALR_DETECTOR_H_ | 
|  |  | 
|  | #include "webrtc/api/optional.h" | 
|  | #include "webrtc/common_types.h" | 
|  | #include "webrtc/modules/pacing/interval_budget.h" | 
|  | #include "webrtc/modules/pacing/paced_sender.h" | 
|  | #include "webrtc/rtc_base/rate_statistics.h" | 
|  | #include "webrtc/typedefs.h" | 
|  |  | 
|  | namespace webrtc { | 
|  |  | 
|  | // 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(); | 
|  | ~AlrDetector(); | 
|  |  | 
|  | void OnBytesSent(size_t bytes_sent, int64_t delta_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. | 
|  | rtc::Optional<int64_t> GetApplicationLimitedRegionStartTime() const; | 
|  |  | 
|  | struct AlrExperimentSettings { | 
|  | float pacing_factor = PacedSender::kDefaultPaceMultiplier; | 
|  | int64_t max_paced_queue_time = PacedSender::kMaxQueueLengthMs; | 
|  | int alr_bandwidth_usage_percent = kDefaultAlrBandwidthUsagePercent; | 
|  | int alr_start_budget_level_percent = kDefaultAlrStartBudgetLevelPercent; | 
|  | int alr_stop_budget_level_percent = kDefaultAlrStopBudgetLevelPercent; | 
|  | // Will be sent to the receive side for stats slicing. | 
|  | // Can be 0..6, because it's sent as a 3 bits value and there's also | 
|  | // reserved value to indicate absence of experiment. | 
|  | int group_id = 0; | 
|  | }; | 
|  | static rtc::Optional<AlrExperimentSettings> ParseAlrSettingsFromFieldTrial( | 
|  | const char* experiment_name); | 
|  |  | 
|  | // Sent traffic percentage as a function of network capacity used to determine | 
|  | // application-limited region. ALR region start when bandwidth usage drops | 
|  | // below kAlrStartUsagePercent and ends when it raises above | 
|  | // kAlrEndUsagePercent. NOTE: This is intentionally conservative at the moment | 
|  | // until BW adjustments of application limited region is fine tuned. | 
|  | static constexpr int kDefaultAlrBandwidthUsagePercent = 65; | 
|  | static constexpr int kDefaultAlrStartBudgetLevelPercent = 80; | 
|  | static constexpr int kDefaultAlrStopBudgetLevelPercent = 50; | 
|  | static const char kScreenshareProbingBweExperimentName[]; | 
|  | static const char kStrictPacingAndProbingExperimentName[]; | 
|  |  | 
|  | void UpdateBudgetWithElapsedTime(int64_t delta_time_ms); | 
|  | void UpdateBudgetWithBytesSent(size_t bytes_sent); | 
|  |  | 
|  | private: | 
|  | int bandwidth_usage_percent_; | 
|  | int alr_start_budget_level_percent_; | 
|  | int alr_stop_budget_level_percent_; | 
|  |  | 
|  | IntervalBudget alr_budget_; | 
|  | rtc::Optional<int64_t> alr_started_time_ms_; | 
|  | }; | 
|  |  | 
|  | }  // namespace webrtc | 
|  |  | 
|  | #endif  // WEBRTC_MODULES_PACING_ALR_DETECTOR_H_ |