Sebastian Jansson | 6bcd7f6 | 2018-02-27 17:07:02 +0100 | [diff] [blame] | 1 | /* |
| 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 | |
Sebastian Jansson | fc7ec8e | 2018-02-28 16:48:00 +0100 | [diff] [blame] | 11 | #ifndef MODULES_CONGESTION_CONTROLLER_GOOG_CC_PROBE_CONTROLLER_H_ |
| 12 | #define MODULES_CONGESTION_CONTROLLER_GOOG_CC_PROBE_CONTROLLER_H_ |
Sebastian Jansson | 6bcd7f6 | 2018-02-27 17:07:02 +0100 | [diff] [blame] | 13 | |
| 14 | #include <stdint.h> |
| 15 | |
| 16 | #include <initializer_list> |
Sebastian Jansson | f2e3e7a | 2018-04-06 17:16:06 +0200 | [diff] [blame] | 17 | #include <vector> |
Sebastian Jansson | 6bcd7f6 | 2018-02-27 17:07:02 +0100 | [diff] [blame] | 18 | |
Danil Chapovalov | 0040b66 | 2018-06-18 10:48:16 +0200 | [diff] [blame] | 19 | #include "absl/types/optional.h" |
Sebastian Jansson | c6c4426 | 2018-05-09 10:33:39 +0200 | [diff] [blame] | 20 | #include "api/transport/network_control.h" |
Sebastian Jansson | 95edb03 | 2019-01-17 16:24:12 +0100 | [diff] [blame] | 21 | #include "api/transport/webrtc_key_value_config.h" |
Piotr (Peter) Slatala | c39f462 | 2019-02-15 07:38:04 -0800 | [diff] [blame] | 22 | #include "logging/rtc_event_log/rtc_event_log.h" |
Steve Anton | 10542f2 | 2019-01-11 09:11:00 -0800 | [diff] [blame] | 23 | #include "rtc_base/constructor_magic.h" |
Jonas Olsson | e096004 | 2019-03-12 13:49:26 +0100 | [diff] [blame] | 24 | #include "rtc_base/experiments/field_trial_parser.h" |
Sebastian Jansson | da2ec40 | 2018-08-02 16:27:28 +0200 | [diff] [blame] | 25 | #include "rtc_base/system/unused.h" |
Sebastian Jansson | 6bcd7f6 | 2018-02-27 17:07:02 +0100 | [diff] [blame] | 26 | |
| 27 | namespace webrtc { |
| 28 | |
| 29 | class Clock; |
| 30 | |
Jonas Olsson | e096004 | 2019-03-12 13:49:26 +0100 | [diff] [blame] | 31 | struct ProbeControllerConfig { |
| 32 | explicit ProbeControllerConfig(const WebRtcKeyValueConfig* key_value_config); |
| 33 | ProbeControllerConfig(const ProbeControllerConfig&); |
| 34 | ProbeControllerConfig& operator=(const ProbeControllerConfig&) = default; |
| 35 | ~ProbeControllerConfig(); |
| 36 | |
| 37 | // These parameters configure the initial probes. First we send one or two |
| 38 | // probes of sizes p1 * start_bitrate_bps_ and p2 * start_bitrate_bps_. |
| 39 | // Then whenever we get a bitrate estimate of at least further_probe_threshold |
| 40 | // times the size of the last sent probe we'll send another one of size |
| 41 | // step_size times the new estimate. |
Jonas Olsson | 01d3618 | 2019-03-27 15:57:02 +0100 | [diff] [blame^] | 42 | FieldTrialParameter<double> first_exponential_probe_scale; |
| 43 | FieldTrialOptional<double> second_exponential_probe_scale; |
| 44 | FieldTrialParameter<double> further_exponential_probe_scale; |
Jonas Olsson | e096004 | 2019-03-12 13:49:26 +0100 | [diff] [blame] | 45 | FieldTrialParameter<double> further_probe_threshold; |
| 46 | |
| 47 | // Configures how often we send ALR probes and how big they are. |
Jonas Olsson | 01d3618 | 2019-03-27 15:57:02 +0100 | [diff] [blame^] | 48 | FieldTrialParameter<TimeDelta> alr_probing_interval; |
| 49 | FieldTrialParameter<double> alr_probe_scale; |
| 50 | |
| 51 | // Configures the probes emitted by changed to the allocated bitrate. |
| 52 | FieldTrialOptional<double> first_allocation_probe_scale; |
| 53 | FieldTrialOptional<double> second_allocation_probe_scale; |
| 54 | FieldTrialFlag allocation_allow_further_probing; |
Jonas Olsson | e096004 | 2019-03-12 13:49:26 +0100 | [diff] [blame] | 55 | }; |
| 56 | |
Sebastian Jansson | 6bcd7f6 | 2018-02-27 17:07:02 +0100 | [diff] [blame] | 57 | // This class controls initiation of probing to estimate initial channel |
| 58 | // capacity. There is also support for probing during a session when max |
| 59 | // bitrate is adjusted by an application. |
| 60 | class ProbeController { |
| 61 | public: |
Piotr (Peter) Slatala | c39f462 | 2019-02-15 07:38:04 -0800 | [diff] [blame] | 62 | explicit ProbeController(const WebRtcKeyValueConfig* key_value_config, |
| 63 | RtcEventLog* event_log); |
Sebastian Jansson | 6bcd7f6 | 2018-02-27 17:07:02 +0100 | [diff] [blame] | 64 | ~ProbeController(); |
| 65 | |
Sebastian Jansson | da2ec40 | 2018-08-02 16:27:28 +0200 | [diff] [blame] | 66 | RTC_WARN_UNUSED_RESULT std::vector<ProbeClusterConfig> SetBitrates( |
| 67 | int64_t min_bitrate_bps, |
| 68 | int64_t start_bitrate_bps, |
| 69 | int64_t max_bitrate_bps, |
| 70 | int64_t at_time_ms); |
Sebastian Jansson | 6bcd7f6 | 2018-02-27 17:07:02 +0100 | [diff] [blame] | 71 | |
philipel | db4fa4b | 2018-03-06 18:29:22 +0100 | [diff] [blame] | 72 | // The total bitrate, as opposed to the max bitrate, is the sum of the |
| 73 | // configured bitrates for all active streams. |
Sebastian Jansson | da2ec40 | 2018-08-02 16:27:28 +0200 | [diff] [blame] | 74 | RTC_WARN_UNUSED_RESULT std::vector<ProbeClusterConfig> |
| 75 | OnMaxTotalAllocatedBitrate(int64_t max_total_allocated_bitrate, |
| 76 | int64_t at_time_ms); |
philipel | db4fa4b | 2018-03-06 18:29:22 +0100 | [diff] [blame] | 77 | |
Sebastian Jansson | da2ec40 | 2018-08-02 16:27:28 +0200 | [diff] [blame] | 78 | RTC_WARN_UNUSED_RESULT std::vector<ProbeClusterConfig> OnNetworkAvailability( |
| 79 | NetworkAvailability msg); |
Sebastian Jansson | 6bcd7f6 | 2018-02-27 17:07:02 +0100 | [diff] [blame] | 80 | |
Sebastian Jansson | da2ec40 | 2018-08-02 16:27:28 +0200 | [diff] [blame] | 81 | RTC_WARN_UNUSED_RESULT std::vector<ProbeClusterConfig> SetEstimatedBitrate( |
| 82 | int64_t bitrate_bps, |
| 83 | int64_t at_time_ms); |
Sebastian Jansson | 6bcd7f6 | 2018-02-27 17:07:02 +0100 | [diff] [blame] | 84 | |
| 85 | void EnablePeriodicAlrProbing(bool enable); |
| 86 | |
Danil Chapovalov | 0040b66 | 2018-06-18 10:48:16 +0200 | [diff] [blame] | 87 | void SetAlrStartTimeMs(absl::optional<int64_t> alr_start_time); |
Sebastian Jansson | 6bcd7f6 | 2018-02-27 17:07:02 +0100 | [diff] [blame] | 88 | void SetAlrEndedTimeMs(int64_t alr_end_time); |
| 89 | |
Sebastian Jansson | da2ec40 | 2018-08-02 16:27:28 +0200 | [diff] [blame] | 90 | RTC_WARN_UNUSED_RESULT std::vector<ProbeClusterConfig> RequestProbe( |
| 91 | int64_t at_time_ms); |
Sebastian Jansson | 6bcd7f6 | 2018-02-27 17:07:02 +0100 | [diff] [blame] | 92 | |
Erik Språng | 791d43c | 2019-01-08 15:46:06 +0100 | [diff] [blame] | 93 | // Sets a new maximum probing bitrate, without generating a new probe cluster. |
| 94 | void SetMaxBitrate(int64_t max_bitrate_bps); |
| 95 | |
Sebastian Jansson | 6bcd7f6 | 2018-02-27 17:07:02 +0100 | [diff] [blame] | 96 | // Resets the ProbeController to a state equivalent to as if it was just |
| 97 | // created EXCEPT for |enable_periodic_alr_probing_|. |
| 98 | void Reset(int64_t at_time_ms); |
| 99 | |
Sebastian Jansson | da2ec40 | 2018-08-02 16:27:28 +0200 | [diff] [blame] | 100 | RTC_WARN_UNUSED_RESULT std::vector<ProbeClusterConfig> Process( |
| 101 | int64_t at_time_ms); |
Sebastian Jansson | f2e3e7a | 2018-04-06 17:16:06 +0200 | [diff] [blame] | 102 | |
Sebastian Jansson | 6bcd7f6 | 2018-02-27 17:07:02 +0100 | [diff] [blame] | 103 | private: |
| 104 | enum class State { |
| 105 | // Initial state where no probing has been triggered yet. |
| 106 | kInit, |
| 107 | // Waiting for probing results to continue further probing. |
| 108 | kWaitingForProbingResult, |
| 109 | // Probing is complete. |
| 110 | kProbingComplete, |
| 111 | }; |
| 112 | |
Sebastian Jansson | da2ec40 | 2018-08-02 16:27:28 +0200 | [diff] [blame] | 113 | RTC_WARN_UNUSED_RESULT std::vector<ProbeClusterConfig> |
| 114 | InitiateExponentialProbing(int64_t at_time_ms); |
| 115 | RTC_WARN_UNUSED_RESULT std::vector<ProbeClusterConfig> InitiateProbing( |
| 116 | int64_t now_ms, |
Jonas Olsson | e096004 | 2019-03-12 13:49:26 +0100 | [diff] [blame] | 117 | std::vector<int64_t> bitrates_to_probe, |
Sebastian Jansson | da2ec40 | 2018-08-02 16:27:28 +0200 | [diff] [blame] | 118 | bool probe_further); |
Sebastian Jansson | 6bcd7f6 | 2018-02-27 17:07:02 +0100 | [diff] [blame] | 119 | |
Sebastian Jansson | 6bcd7f6 | 2018-02-27 17:07:02 +0100 | [diff] [blame] | 120 | bool network_available_; |
| 121 | State state_; |
| 122 | int64_t min_bitrate_to_probe_further_bps_; |
| 123 | int64_t time_last_probing_initiated_ms_; |
| 124 | int64_t estimated_bitrate_bps_; |
| 125 | int64_t start_bitrate_bps_; |
| 126 | int64_t max_bitrate_bps_; |
| 127 | int64_t last_bwe_drop_probing_time_ms_; |
Danil Chapovalov | 0040b66 | 2018-06-18 10:48:16 +0200 | [diff] [blame] | 128 | absl::optional<int64_t> alr_start_time_ms_; |
| 129 | absl::optional<int64_t> alr_end_time_ms_; |
Sebastian Jansson | 6bcd7f6 | 2018-02-27 17:07:02 +0100 | [diff] [blame] | 130 | bool enable_periodic_alr_probing_; |
| 131 | int64_t time_of_last_large_drop_ms_; |
| 132 | int64_t bitrate_before_last_large_drop_bps_; |
philipel | 0676f22 | 2018-04-17 16:12:21 +0200 | [diff] [blame] | 133 | int64_t max_total_allocated_bitrate_; |
Sebastian Jansson | 6bcd7f6 | 2018-02-27 17:07:02 +0100 | [diff] [blame] | 134 | |
Erik Språng | cfe36ca | 2018-11-29 17:32:48 +0100 | [diff] [blame] | 135 | const bool in_rapid_recovery_experiment_; |
| 136 | const bool limit_probes_with_allocateable_rate_; |
Sebastian Jansson | 6bcd7f6 | 2018-02-27 17:07:02 +0100 | [diff] [blame] | 137 | // For WebRTC.BWE.MidCallProbing.* metric. |
| 138 | bool mid_call_probing_waiting_for_result_; |
| 139 | int64_t mid_call_probing_bitrate_bps_; |
| 140 | int64_t mid_call_probing_succcess_threshold_; |
Piotr (Peter) Slatala | c39f462 | 2019-02-15 07:38:04 -0800 | [diff] [blame] | 141 | RtcEventLog* event_log_; |
| 142 | |
| 143 | int32_t next_probe_cluster_id_ = 1; |
Sebastian Jansson | 6bcd7f6 | 2018-02-27 17:07:02 +0100 | [diff] [blame] | 144 | |
Jonas Olsson | e096004 | 2019-03-12 13:49:26 +0100 | [diff] [blame] | 145 | ProbeControllerConfig config_; |
| 146 | |
Sebastian Jansson | f2e3e7a | 2018-04-06 17:16:06 +0200 | [diff] [blame] | 147 | RTC_DISALLOW_COPY_AND_ASSIGN(ProbeController); |
Sebastian Jansson | 6bcd7f6 | 2018-02-27 17:07:02 +0100 | [diff] [blame] | 148 | }; |
| 149 | |
Sebastian Jansson | 6bcd7f6 | 2018-02-27 17:07:02 +0100 | [diff] [blame] | 150 | } // namespace webrtc |
| 151 | |
Sebastian Jansson | fc7ec8e | 2018-02-28 16:48:00 +0100 | [diff] [blame] | 152 | #endif // MODULES_CONGESTION_CONTROLLER_GOOG_CC_PROBE_CONTROLLER_H_ |