Chromium Code Reviews| Index: webrtc/modules/pacing/interval_budget.cc |
| diff --git a/webrtc/modules/pacing/interval_budget.cc b/webrtc/modules/pacing/interval_budget.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..0cd6cf5bbe9a0e95279e444b90f3947c7c900adb |
| --- /dev/null |
| +++ b/webrtc/modules/pacing/interval_budget.cc |
| @@ -0,0 +1,64 @@ |
| +/* |
| + * 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. |
| + */ |
| + |
| +#include "webrtc/modules/pacing/interval_budget.h" |
| + |
| +#include <algorithm> |
| + |
| +namespace webrtc { |
| +namespace { |
| +constexpr int kWindowMs = 500; |
| +} |
| + |
| +IntervalBudget::IntervalBudget(int initial_target_rate_kbps) |
| + : IntervalBudget(initial_target_rate_kbps, false) {} |
| + |
| +IntervalBudget::IntervalBudget(int initial_target_rate_kbps, |
| + bool can_build_up_underuse) |
| + : bytes_remaining_(0), can_build_up_underuse_(can_build_up_underuse) { |
| + set_target_rate_kbps(initial_target_rate_kbps); |
| +} |
| + |
| +void IntervalBudget::set_target_rate_kbps(int target_rate_kbps) { |
| + target_rate_kbps_ = target_rate_kbps; |
| + max_bytes_in_budget_ = (kWindowMs * target_rate_kbps_) / 8; |
| + bytes_remaining_ = std::min(std::max(-max_bytes_in_budget_, bytes_remaining_), |
| + max_bytes_in_budget_); |
| +} |
| + |
| +void IntervalBudget::IncreaseBudget(int64_t delta_time_ms) { |
|
philipel
2017/07/10 11:41:05
I think it might be good to merge IncreaseBudget a
tschumi
2017/07/11 09:33:31
Would be a bit of a refactoring in the pacer => ma
philipel
2017/07/11 12:29:05
Yeah, a separate CL sounds good. Please add a TODO
tschumi
2017/07/11 12:43:35
Done.
|
| + int bytes = target_rate_kbps_ * delta_time_ms / 8; |
| + if (bytes_remaining_ < 0 || can_build_up_underuse_) { |
| + // We overused last interval, compensate this interval. |
| + bytes_remaining_ = std::min(bytes_remaining_ + bytes, max_bytes_in_budget_); |
| + } else { |
| + // If we underused last interval we can't use it this interval. |
| + bytes_remaining_ = std::min(bytes, max_bytes_in_budget_); |
|
philipel
2017/07/10 11:41:05
It looks like |bytes_remaining_| can be positive e
tschumi
2017/07/11 09:33:31
delta_time_ms is clamped by the pacer to 5ms so by
philipel
2017/07/11 12:29:05
Sound like we rely on external behavior, don't thi
tschumi
2017/07/11 12:43:35
Done.
tschumi
2017/07/11 12:43:35
Done.
|
| + } |
| +} |
| + |
| +void IntervalBudget::UseBudget(size_t bytes) { |
| + bytes_remaining_ = std::max(bytes_remaining_ - static_cast<int>(bytes), |
| + -max_bytes_in_budget_); |
| +} |
| + |
| +size_t IntervalBudget::bytes_remaining() const { |
| + return static_cast<size_t>(std::max(0, bytes_remaining_)); |
| +} |
| + |
| +int IntervalBudget::budget_level_percent() const { |
| + return bytes_remaining_ * 100 / max_bytes_in_budget_; |
| +} |
| + |
| +int IntervalBudget::target_rate_kbps() const { |
| + return target_rate_kbps_; |
| +} |
| + |
| +} // namespace webrtc |