blob: d71c045d2bed7fe30668a4cbd2deb6c2eed36c7e [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 Chapovalov098da172021-01-14 16:15:31 +010019#include "absl/base/attributes.h"
Danil Chapovalov0040b662018-06-18 10:48:16 +020020#include "absl/types/optional.h"
Jonas Orelande62c2f22022-03-29 11:04:48 +020021#include "api/field_trials_view.h"
Danil Chapovalov83bbe912019-08-07 12:24:53 +020022#include "api/rtc_event_log/rtc_event_log.h"
Sebastian Janssonc6c44262018-05-09 10:33:39 +020023#include "api/transport/network_control.h"
Christoffer Rodbro377f5a22020-02-12 10:11:13 +010024#include "api/units/data_rate.h"
Jonas Olssone0960042019-03-12 13:49:26 +010025#include "rtc_base/experiments/field_trial_parser.h"
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +010026
27namespace webrtc {
28
Jonas Olssone0960042019-03-12 13:49:26 +010029struct ProbeControllerConfig {
Jonas Orelande62c2f22022-03-29 11:04:48 +020030 explicit ProbeControllerConfig(const FieldTrialsView* key_value_config);
Jonas Olssone0960042019-03-12 13:49:26 +010031 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;
Christoffer Rodbro377f5a22020-02-12 10:11:13 +010053 FieldTrialParameter<DataRate> allocation_probe_max;
Per Kjellander88af2032022-05-16 19:58:40 +020054
55 // The minimum number probing packets used.
56 FieldTrialParameter<int> min_probe_packets_sent;
57 // The minimum probing duration.
58 FieldTrialParameter<TimeDelta> min_probe_duration;
Jonas Olssone0960042019-03-12 13:49:26 +010059};
60
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +010061// This class controls initiation of probing to estimate initial channel
62// capacity. There is also support for probing during a session when max
63// bitrate is adjusted by an application.
64class ProbeController {
65 public:
Jonas Orelande62c2f22022-03-29 11:04:48 +020066 explicit ProbeController(const FieldTrialsView* key_value_config,
Piotr (Peter) Slatalac39f4622019-02-15 07:38:04 -080067 RtcEventLog* event_log);
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +010068 ~ProbeController();
69
Byoungchan Lee604fd2f2022-01-21 09:49:39 +090070 ProbeController(const ProbeController&) = delete;
71 ProbeController& operator=(const ProbeController&) = delete;
72
Danil Chapovalov098da172021-01-14 16:15:31 +010073 ABSL_MUST_USE_RESULT std::vector<ProbeClusterConfig> SetBitrates(
Sebastian Janssonda2ec402018-08-02 16:27:28 +020074 int64_t min_bitrate_bps,
75 int64_t start_bitrate_bps,
76 int64_t max_bitrate_bps,
77 int64_t at_time_ms);
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +010078
philipeldb4fa4b2018-03-06 18:29:22 +010079 // The total bitrate, as opposed to the max bitrate, is the sum of the
80 // configured bitrates for all active streams.
Danil Chapovalov098da172021-01-14 16:15:31 +010081 ABSL_MUST_USE_RESULT std::vector<ProbeClusterConfig>
Sebastian Janssonda2ec402018-08-02 16:27:28 +020082 OnMaxTotalAllocatedBitrate(int64_t max_total_allocated_bitrate,
83 int64_t at_time_ms);
philipeldb4fa4b2018-03-06 18:29:22 +010084
Danil Chapovalov098da172021-01-14 16:15:31 +010085 ABSL_MUST_USE_RESULT std::vector<ProbeClusterConfig> OnNetworkAvailability(
Sebastian Janssonda2ec402018-08-02 16:27:28 +020086 NetworkAvailability msg);
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +010087
Danil Chapovalov098da172021-01-14 16:15:31 +010088 ABSL_MUST_USE_RESULT std::vector<ProbeClusterConfig> SetEstimatedBitrate(
Sebastian Janssonda2ec402018-08-02 16:27:28 +020089 int64_t bitrate_bps,
90 int64_t at_time_ms);
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +010091
92 void EnablePeriodicAlrProbing(bool enable);
93
Danil Chapovalov0040b662018-06-18 10:48:16 +020094 void SetAlrStartTimeMs(absl::optional<int64_t> alr_start_time);
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +010095 void SetAlrEndedTimeMs(int64_t alr_end_time);
96
Danil Chapovalov098da172021-01-14 16:15:31 +010097 ABSL_MUST_USE_RESULT std::vector<ProbeClusterConfig> RequestProbe(
Sebastian Janssonda2ec402018-08-02 16:27:28 +020098 int64_t at_time_ms);
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +010099
Erik Språng791d43c2019-01-08 15:46:06 +0100100 // Sets a new maximum probing bitrate, without generating a new probe cluster.
101 void SetMaxBitrate(int64_t max_bitrate_bps);
102
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +0100103 // Resets the ProbeController to a state equivalent to as if it was just
Artem Titov6f4b4fa2021-07-28 20:26:13 +0200104 // created EXCEPT for `enable_periodic_alr_probing_`.
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +0100105 void Reset(int64_t at_time_ms);
106
Danil Chapovalov098da172021-01-14 16:15:31 +0100107 ABSL_MUST_USE_RESULT std::vector<ProbeClusterConfig> Process(
Sebastian Janssonda2ec402018-08-02 16:27:28 +0200108 int64_t at_time_ms);
Sebastian Janssonf2e3e7a2018-04-06 17:16:06 +0200109
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +0100110 private:
111 enum class State {
112 // Initial state where no probing has been triggered yet.
113 kInit,
114 // Waiting for probing results to continue further probing.
115 kWaitingForProbingResult,
116 // Probing is complete.
117 kProbingComplete,
118 };
119
Danil Chapovalov098da172021-01-14 16:15:31 +0100120 ABSL_MUST_USE_RESULT std::vector<ProbeClusterConfig>
Sebastian Janssonda2ec402018-08-02 16:27:28 +0200121 InitiateExponentialProbing(int64_t at_time_ms);
Danil Chapovalov098da172021-01-14 16:15:31 +0100122 ABSL_MUST_USE_RESULT std::vector<ProbeClusterConfig> InitiateProbing(
Sebastian Janssonda2ec402018-08-02 16:27:28 +0200123 int64_t now_ms,
Jonas Olssone0960042019-03-12 13:49:26 +0100124 std::vector<int64_t> bitrates_to_probe,
Sebastian Janssonda2ec402018-08-02 16:27:28 +0200125 bool probe_further);
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +0100126
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +0100127 bool network_available_;
128 State state_;
129 int64_t min_bitrate_to_probe_further_bps_;
130 int64_t time_last_probing_initiated_ms_;
131 int64_t estimated_bitrate_bps_;
132 int64_t start_bitrate_bps_;
133 int64_t max_bitrate_bps_;
134 int64_t last_bwe_drop_probing_time_ms_;
Danil Chapovalov0040b662018-06-18 10:48:16 +0200135 absl::optional<int64_t> alr_start_time_ms_;
136 absl::optional<int64_t> alr_end_time_ms_;
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +0100137 bool enable_periodic_alr_probing_;
138 int64_t time_of_last_large_drop_ms_;
139 int64_t bitrate_before_last_large_drop_bps_;
philipel0676f222018-04-17 16:12:21 +0200140 int64_t max_total_allocated_bitrate_;
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +0100141
Erik Språngcfe36ca2018-11-29 17:32:48 +0100142 const bool in_rapid_recovery_experiment_;
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +0100143 // For WebRTC.BWE.MidCallProbing.* metric.
144 bool mid_call_probing_waiting_for_result_;
145 int64_t mid_call_probing_bitrate_bps_;
146 int64_t mid_call_probing_succcess_threshold_;
Piotr (Peter) Slatalac39f4622019-02-15 07:38:04 -0800147 RtcEventLog* event_log_;
148
149 int32_t next_probe_cluster_id_ = 1;
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +0100150
Jonas Olssone0960042019-03-12 13:49:26 +0100151 ProbeControllerConfig config_;
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +0100152};
153
Sebastian Jansson6bcd7f62018-02-27 17:07:02 +0100154} // namespace webrtc
155
Sebastian Janssonfc7ec8e2018-02-28 16:48:00 +0100156#endif // MODULES_CONGESTION_CONTROLLER_GOOG_CC_PROBE_CONTROLLER_H_