| /* |
| * Copyright 2018 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. |
| */ |
| #ifndef API_CALL_BITRATE_ALLOCATION_H_ |
| #define API_CALL_BITRATE_ALLOCATION_H_ |
| |
| #include "api/units/data_rate.h" |
| #include "api/units/time_delta.h" |
| |
| namespace webrtc { |
| |
| // BitrateAllocationUpdate provides information to allocated streams about their |
| // bitrate allocation. It originates from the BitrateAllocater class and is |
| // propagated from there. |
| struct BitrateAllocationUpdate { |
| // The allocated target bitrate. Media streams should produce this amount of |
| // data. (Note that this may include packet overhead depending on |
| // configuration.) |
| DataRate target_bitrate = DataRate::Zero(); |
| // The allocated part of the estimated link capacity. This is more stable than |
| // the target as it is based on the underlying link capacity estimate. This |
| // should be used to change encoder configuration when the cost of change is |
| // high. |
| DataRate stable_target_bitrate = DataRate::Zero(); |
| // Predicted packet loss ratio. |
| double packet_loss_ratio = 0; |
| // Predicted round trip time. |
| TimeDelta round_trip_time = TimeDelta::PlusInfinity(); |
| // `bwe_period` is deprecated, use `stable_target_bitrate` allocation instead. |
| TimeDelta bwe_period = TimeDelta::PlusInfinity(); |
| // Congestion window pushback bitrate reduction fraction. Used in |
| // VideoStreamEncoder to reduce the bitrate by the given fraction |
| // by dropping frames. |
| double cwnd_reduce_ratio = 0; |
| }; |
| |
| } // namespace webrtc |
| |
| #endif // API_CALL_BITRATE_ALLOCATION_H_ |