blob: f22acff25f574077f0fb2342332d29493fa819a4 [file] [log] [blame]
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +01001/*
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 Janssonfc7ec8e2018-02-28 16:48:00 +010011#ifndef MODULES_CONGESTION_CONTROLLER_GOOG_CC_PROBE_CONTROLLER_H_
12#define MODULES_CONGESTION_CONTROLLER_GOOG_CC_PROBE_CONTROLLER_H_
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +010013
14#include <stdint.h>
15
16#include <initializer_list>
Sebastian Janssonf2e3e7a2018-04-06 17:16:06 +020017#include <vector>
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +010018
Danil Chapovalov0040b662018-06-18 10:48:16 +020019#include "absl/types/optional.h"
Danil Chapovalov83bbe912019-08-07 12:24:53 +020020#include "api/rtc_event_log/rtc_event_log.h"
Sebastian Janssonc6c44262018-05-09 10:33:39 +020021#include "api/transport/network_control.h"
Sebastian Jansson95edb032019-01-17 16:24:12 +010022#include "api/transport/webrtc_key_value_config.h"
Steve Anton10542f22019-01-11 09:11:00 -080023#include "rtc_base/constructor_magic.h"
Jonas Olssone0960042019-03-12 13:49:26 +010024#include "rtc_base/experiments/field_trial_parser.h"
Sebastian Janssonda2ec402018-08-02 16:27:28 +020025#include "rtc_base/system/unused.h"
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +010026
27namespace webrtc {
28
Jonas Olssone0960042019-03-12 13:49:26 +010029struct ProbeControllerConfig {
30 explicit ProbeControllerConfig(const WebRtcKeyValueConfig* key_value_config);
31 ProbeControllerConfig(const ProbeControllerConfig&);
32 ProbeControllerConfig& operator=(const ProbeControllerConfig&) = default;
33 ~ProbeControllerConfig();
34
35 // These parameters configure the initial probes. First we send one or two
36 // probes of sizes p1 * start_bitrate_bps_ and p2 * start_bitrate_bps_.
37 // Then whenever we get a bitrate estimate of at least further_probe_threshold
38 // times the size of the last sent probe we'll send another one of size
39 // step_size times the new estimate.
Jonas Olsson01d36182019-03-27 15:57:02 +010040 FieldTrialParameter<double> first_exponential_probe_scale;
41 FieldTrialOptional<double> second_exponential_probe_scale;
42 FieldTrialParameter<double> further_exponential_probe_scale;
Jonas Olssone0960042019-03-12 13:49:26 +010043 FieldTrialParameter<double> further_probe_threshold;
44
45 // Configures how often we send ALR probes and how big they are.
Jonas Olsson01d36182019-03-27 15:57:02 +010046 FieldTrialParameter<TimeDelta> alr_probing_interval;
47 FieldTrialParameter<double> alr_probe_scale;
48
49 // Configures the probes emitted by changed to the allocated bitrate.
50 FieldTrialOptional<double> first_allocation_probe_scale;
51 FieldTrialOptional<double> second_allocation_probe_scale;
52 FieldTrialFlag allocation_allow_further_probing;
Jonas Olssone0960042019-03-12 13:49:26 +010053};
54
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +010055// This class controls initiation of probing to estimate initial channel
56// capacity. There is also support for probing during a session when max
57// bitrate is adjusted by an application.
58class ProbeController {
59 public:
Piotr (Peter) Slatalac39f4622019-02-15 07:38:04 -080060 explicit ProbeController(const WebRtcKeyValueConfig* key_value_config,
61 RtcEventLog* event_log);
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +010062 ~ProbeController();
63
Sebastian Janssonda2ec402018-08-02 16:27:28 +020064 RTC_WARN_UNUSED_RESULT std::vector<ProbeClusterConfig> SetBitrates(
65 int64_t min_bitrate_bps,
66 int64_t start_bitrate_bps,
67 int64_t max_bitrate_bps,
68 int64_t at_time_ms);
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +010069
philipeldb4fa4b2018-03-06 18:29:22 +010070 // The total bitrate, as opposed to the max bitrate, is the sum of the
71 // configured bitrates for all active streams.
Sebastian Janssonda2ec402018-08-02 16:27:28 +020072 RTC_WARN_UNUSED_RESULT std::vector<ProbeClusterConfig>
73 OnMaxTotalAllocatedBitrate(int64_t max_total_allocated_bitrate,
74 int64_t at_time_ms);
philipeldb4fa4b2018-03-06 18:29:22 +010075
Sebastian Janssonda2ec402018-08-02 16:27:28 +020076 RTC_WARN_UNUSED_RESULT std::vector<ProbeClusterConfig> OnNetworkAvailability(
77 NetworkAvailability msg);
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +010078
Sebastian Janssonda2ec402018-08-02 16:27:28 +020079 RTC_WARN_UNUSED_RESULT std::vector<ProbeClusterConfig> SetEstimatedBitrate(
80 int64_t bitrate_bps,
81 int64_t at_time_ms);
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +010082
83 void EnablePeriodicAlrProbing(bool enable);
84
Danil Chapovalov0040b662018-06-18 10:48:16 +020085 void SetAlrStartTimeMs(absl::optional<int64_t> alr_start_time);
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +010086 void SetAlrEndedTimeMs(int64_t alr_end_time);
87
Sebastian Janssonda2ec402018-08-02 16:27:28 +020088 RTC_WARN_UNUSED_RESULT std::vector<ProbeClusterConfig> RequestProbe(
89 int64_t at_time_ms);
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +010090
Erik Språng791d43c2019-01-08 15:46:06 +010091 // Sets a new maximum probing bitrate, without generating a new probe cluster.
92 void SetMaxBitrate(int64_t max_bitrate_bps);
93
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +010094 // Resets the ProbeController to a state equivalent to as if it was just
95 // created EXCEPT for |enable_periodic_alr_probing_|.
96 void Reset(int64_t at_time_ms);
97
Sebastian Janssonda2ec402018-08-02 16:27:28 +020098 RTC_WARN_UNUSED_RESULT std::vector<ProbeClusterConfig> Process(
99 int64_t at_time_ms);
Sebastian Janssonf2e3e7a2018-04-06 17:16:06 +0200100
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +0100101 private:
102 enum class State {
103 // Initial state where no probing has been triggered yet.
104 kInit,
105 // Waiting for probing results to continue further probing.
106 kWaitingForProbingResult,
107 // Probing is complete.
108 kProbingComplete,
109 };
110
Sebastian Janssonda2ec402018-08-02 16:27:28 +0200111 RTC_WARN_UNUSED_RESULT std::vector<ProbeClusterConfig>
112 InitiateExponentialProbing(int64_t at_time_ms);
113 RTC_WARN_UNUSED_RESULT std::vector<ProbeClusterConfig> InitiateProbing(
114 int64_t now_ms,
Jonas Olssone0960042019-03-12 13:49:26 +0100115 std::vector<int64_t> bitrates_to_probe,
Sebastian Janssonda2ec402018-08-02 16:27:28 +0200116 bool probe_further);
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +0100117
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +0100118 bool network_available_;
119 State state_;
120 int64_t min_bitrate_to_probe_further_bps_;
121 int64_t time_last_probing_initiated_ms_;
122 int64_t estimated_bitrate_bps_;
123 int64_t start_bitrate_bps_;
124 int64_t max_bitrate_bps_;
125 int64_t last_bwe_drop_probing_time_ms_;
Danil Chapovalov0040b662018-06-18 10:48:16 +0200126 absl::optional<int64_t> alr_start_time_ms_;
127 absl::optional<int64_t> alr_end_time_ms_;
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +0100128 bool enable_periodic_alr_probing_;
129 int64_t time_of_last_large_drop_ms_;
130 int64_t bitrate_before_last_large_drop_bps_;
philipel0676f222018-04-17 16:12:21 +0200131 int64_t max_total_allocated_bitrate_;
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +0100132
Erik Språngcfe36ca2018-11-29 17:32:48 +0100133 const bool in_rapid_recovery_experiment_;
134 const bool limit_probes_with_allocateable_rate_;
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +0100135 // For WebRTC.BWE.MidCallProbing.* metric.
136 bool mid_call_probing_waiting_for_result_;
137 int64_t mid_call_probing_bitrate_bps_;
138 int64_t mid_call_probing_succcess_threshold_;
Piotr (Peter) Slatalac39f4622019-02-15 07:38:04 -0800139 RtcEventLog* event_log_;
140
141 int32_t next_probe_cluster_id_ = 1;
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +0100142
Jonas Olssone0960042019-03-12 13:49:26 +0100143 ProbeControllerConfig config_;
144
Sebastian Janssonf2e3e7a2018-04-06 17:16:06 +0200145 RTC_DISALLOW_COPY_AND_ASSIGN(ProbeController);
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +0100146};
147
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +0100148} // namespace webrtc
149
Sebastian Janssonfc7ec8e2018-02-28 16:48:00 +0100150#endif // MODULES_CONGESTION_CONTROLLER_GOOG_CC_PROBE_CONTROLLER_H_