| /* |
| * 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_PROBE_CONTROLLER_H_ |
| #define MODULES_CONGESTION_CONTROLLER_GOOG_CC_PROBE_CONTROLLER_H_ |
| |
| #include <stdint.h> |
| |
| #include <initializer_list> |
| #include <vector> |
| |
| #include "absl/types/optional.h" |
| #include "api/transport/network_control.h" |
| #include "api/transport/webrtc_key_value_config.h" |
| #include "logging/rtc_event_log/rtc_event_log.h" |
| #include "rtc_base/constructor_magic.h" |
| #include "rtc_base/experiments/field_trial_parser.h" |
| #include "rtc_base/system/unused.h" |
| |
| namespace webrtc { |
| |
| class Clock; |
| |
| struct ProbeControllerConfig { |
| explicit ProbeControllerConfig(const WebRtcKeyValueConfig* key_value_config); |
| ProbeControllerConfig(const ProbeControllerConfig&); |
| ProbeControllerConfig& operator=(const ProbeControllerConfig&) = default; |
| ~ProbeControllerConfig(); |
| |
| // These parameters configure the initial probes. First we send one or two |
| // probes of sizes p1 * start_bitrate_bps_ and p2 * start_bitrate_bps_. |
| // Then whenever we get a bitrate estimate of at least further_probe_threshold |
| // times the size of the last sent probe we'll send another one of size |
| // step_size times the new estimate. |
| FieldTrialParameter<double> first_exponential_probe_scale_; |
| FieldTrialOptional<double> second_exponential_probe_scale_; |
| FieldTrialParameter<double> further_exponential_probe_scale_; |
| FieldTrialParameter<double> further_probe_threshold; |
| |
| // Configures how often we send ALR probes and how big they are. |
| FieldTrialParameter<TimeDelta> alr_probing_interval_; |
| FieldTrialParameter<double> alr_probe_scale_; |
| }; |
| |
| // This class controls initiation of probing to estimate initial channel |
| // capacity. There is also support for probing during a session when max |
| // bitrate is adjusted by an application. |
| class ProbeController { |
| public: |
| explicit ProbeController(const WebRtcKeyValueConfig* key_value_config, |
| RtcEventLog* event_log); |
| ~ProbeController(); |
| |
| RTC_WARN_UNUSED_RESULT std::vector<ProbeClusterConfig> SetBitrates( |
| int64_t min_bitrate_bps, |
| int64_t start_bitrate_bps, |
| int64_t max_bitrate_bps, |
| int64_t at_time_ms); |
| |
| // The total bitrate, as opposed to the max bitrate, is the sum of the |
| // configured bitrates for all active streams. |
| RTC_WARN_UNUSED_RESULT std::vector<ProbeClusterConfig> |
| OnMaxTotalAllocatedBitrate(int64_t max_total_allocated_bitrate, |
| int64_t at_time_ms); |
| |
| RTC_WARN_UNUSED_RESULT std::vector<ProbeClusterConfig> OnNetworkAvailability( |
| NetworkAvailability msg); |
| |
| RTC_WARN_UNUSED_RESULT std::vector<ProbeClusterConfig> SetEstimatedBitrate( |
| int64_t bitrate_bps, |
| int64_t at_time_ms); |
| |
| void EnablePeriodicAlrProbing(bool enable); |
| |
| void SetAlrStartTimeMs(absl::optional<int64_t> alr_start_time); |
| void SetAlrEndedTimeMs(int64_t alr_end_time); |
| |
| RTC_WARN_UNUSED_RESULT std::vector<ProbeClusterConfig> RequestProbe( |
| int64_t at_time_ms); |
| |
| // Sets a new maximum probing bitrate, without generating a new probe cluster. |
| void SetMaxBitrate(int64_t max_bitrate_bps); |
| |
| // Resets the ProbeController to a state equivalent to as if it was just |
| // created EXCEPT for |enable_periodic_alr_probing_|. |
| void Reset(int64_t at_time_ms); |
| |
| RTC_WARN_UNUSED_RESULT std::vector<ProbeClusterConfig> Process( |
| int64_t at_time_ms); |
| |
| private: |
| enum class State { |
| // Initial state where no probing has been triggered yet. |
| kInit, |
| // Waiting for probing results to continue further probing. |
| kWaitingForProbingResult, |
| // Probing is complete. |
| kProbingComplete, |
| }; |
| |
| RTC_WARN_UNUSED_RESULT std::vector<ProbeClusterConfig> |
| InitiateExponentialProbing(int64_t at_time_ms); |
| RTC_WARN_UNUSED_RESULT std::vector<ProbeClusterConfig> InitiateProbing( |
| int64_t now_ms, |
| std::vector<int64_t> bitrates_to_probe, |
| bool probe_further); |
| |
| bool network_available_; |
| State state_; |
| int64_t min_bitrate_to_probe_further_bps_; |
| int64_t time_last_probing_initiated_ms_; |
| int64_t estimated_bitrate_bps_; |
| int64_t start_bitrate_bps_; |
| int64_t max_bitrate_bps_; |
| int64_t last_bwe_drop_probing_time_ms_; |
| absl::optional<int64_t> alr_start_time_ms_; |
| absl::optional<int64_t> alr_end_time_ms_; |
| bool enable_periodic_alr_probing_; |
| int64_t time_of_last_large_drop_ms_; |
| int64_t bitrate_before_last_large_drop_bps_; |
| int64_t max_total_allocated_bitrate_; |
| |
| const bool in_rapid_recovery_experiment_; |
| const bool limit_probes_with_allocateable_rate_; |
| // For WebRTC.BWE.MidCallProbing.* metric. |
| bool mid_call_probing_waiting_for_result_; |
| int64_t mid_call_probing_bitrate_bps_; |
| int64_t mid_call_probing_succcess_threshold_; |
| RtcEventLog* event_log_; |
| |
| int32_t next_probe_cluster_id_ = 1; |
| |
| ProbeControllerConfig config_; |
| |
| RTC_DISALLOW_COPY_AND_ASSIGN(ProbeController); |
| }; |
| |
| } // namespace webrtc |
| |
| #endif // MODULES_CONGESTION_CONTROLLER_GOOG_CC_PROBE_CONTROLLER_H_ |