Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1087)

Side by Side Diff: webrtc/modules/remote_bitrate_estimator/aimd_rate_control.h

Issue 1368943002: Fix suspend below min bitrate in new API by making it possible to set min bitrate at the receive-si… (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Merge. Created 5 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « webrtc/call/call.cc ('k') | webrtc/modules/remote_bitrate_estimator/aimd_rate_control.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2014 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2014 The WebRTC project authors. All Rights Reserved.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license 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 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 6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may 7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree. 8 * be found in the AUTHORS file in the root of the source tree.
9 */ 9 */
10 10
11 #ifndef WEBRTC_MODULES_REMOTE_BITRATE_ESTIMATOR_AIMD_RATE_CONTROL_H_ 11 #ifndef WEBRTC_MODULES_REMOTE_BITRATE_ESTIMATOR_AIMD_RATE_CONTROL_H_
12 #define WEBRTC_MODULES_REMOTE_BITRATE_ESTIMATOR_AIMD_RATE_CONTROL_H_ 12 #define WEBRTC_MODULES_REMOTE_BITRATE_ESTIMATOR_AIMD_RATE_CONTROL_H_
13 13
14 #include "webrtc/base/constructormagic.h" 14 #include "webrtc/base/constructormagic.h"
15 #include "webrtc/modules/remote_bitrate_estimator/include/bwe_defines.h" 15 #include "webrtc/modules/remote_bitrate_estimator/include/bwe_defines.h"
16 16
17 namespace webrtc { 17 namespace webrtc {
18 18
19 // A rate control implementation based on additive increases of 19 // A rate control implementation based on additive increases of
20 // bitrate when no over-use is detected and multiplicative decreases when 20 // bitrate when no over-use is detected and multiplicative decreases when
21 // over-uses are detected. When we think the available bandwidth has changes or 21 // over-uses are detected. When we think the available bandwidth has changes or
22 // is unknown, we will switch to a "slow-start mode" where we increase 22 // is unknown, we will switch to a "slow-start mode" where we increase
23 // multiplicatively. 23 // multiplicatively.
24 class AimdRateControl { 24 class AimdRateControl {
25 public: 25 public:
26 explicit AimdRateControl(uint32_t min_bitrate_bps); 26 AimdRateControl();
27 virtual ~AimdRateControl() {} 27 virtual ~AimdRateControl() {}
28 28
29 // Returns true if there is a valid estimate of the incoming bitrate, false 29 // Returns true if there is a valid estimate of the incoming bitrate, false
30 // otherwise. 30 // otherwise.
31 bool ValidEstimate() const; 31 bool ValidEstimate() const;
32 uint32_t GetMinBitrate() const; 32 void SetMinBitrate(int min_bitrate_bps);
33 int64_t GetFeedbackInterval() const; 33 int64_t GetFeedbackInterval() const;
34 // Returns true if the bitrate estimate hasn't been changed for more than 34 // Returns true if the bitrate estimate hasn't been changed for more than
35 // an RTT, or if the incoming_bitrate is more than 5% above the current 35 // an RTT, or if the incoming_bitrate is more than 5% above the current
36 // estimate. Should be used to decide if we should reduce the rate further 36 // estimate. Should be used to decide if we should reduce the rate further
37 // when over-using. 37 // when over-using.
38 bool TimeToReduceFurther(int64_t time_now, 38 bool TimeToReduceFurther(int64_t time_now,
39 uint32_t incoming_bitrate_bps) const; 39 uint32_t incoming_bitrate_bps) const;
40 uint32_t LatestEstimate() const; 40 uint32_t LatestEstimate() const;
41 uint32_t UpdateBandwidthEstimate(int64_t now_ms); 41 uint32_t UpdateBandwidthEstimate(int64_t now_ms);
42 void SetRtt(int64_t rtt); 42 void SetRtt(int64_t rtt);
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after
74 RateControlRegion rate_control_region_; 74 RateControlRegion rate_control_region_;
75 int64_t time_last_bitrate_change_; 75 int64_t time_last_bitrate_change_;
76 RateControlInput current_input_; 76 RateControlInput current_input_;
77 bool updated_; 77 bool updated_;
78 int64_t time_first_incoming_estimate_; 78 int64_t time_first_incoming_estimate_;
79 bool bitrate_is_initialized_; 79 bool bitrate_is_initialized_;
80 float beta_; 80 float beta_;
81 int64_t rtt_; 81 int64_t rtt_;
82 int64_t time_of_last_log_; 82 int64_t time_of_last_log_;
83 bool in_experiment_; 83 bool in_experiment_;
84
85 RTC_DISALLOW_IMPLICIT_CONSTRUCTORS(AimdRateControl);
86 }; 84 };
87 } // namespace webrtc 85 } // namespace webrtc
88 86
89 #endif // WEBRTC_MODULES_REMOTE_BITRATE_ESTIMATOR_AIMD_RATE_CONTROL_H_ 87 #endif // WEBRTC_MODULES_REMOTE_BITRATE_ESTIMATOR_AIMD_RATE_CONTROL_H_
OLDNEW
« no previous file with comments | « webrtc/call/call.cc ('k') | webrtc/modules/remote_bitrate_estimator/aimd_rate_control.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698