/* * Copyright (c) 2017 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 "modules/congestion_controller/acknowledged_bitrate_estimator.h" #include #include "modules/rtp_rtcp/include/rtp_rtcp_defines.h" #include "rtc_base/ptr_util.h" namespace webrtc { namespace { bool IsInSendTimeHistory(const PacketFeedback& packet) { return packet.send_time_ms >= 0; } } // namespace AcknowledgedBitrateEstimator::AcknowledgedBitrateEstimator() : AcknowledgedBitrateEstimator(rtc::MakeUnique()) {} AcknowledgedBitrateEstimator::AcknowledgedBitrateEstimator( std::unique_ptr bitrate_estimator) : bitrate_estimator_(std::move(bitrate_estimator)) {} void AcknowledgedBitrateEstimator::IncomingPacketFeedbackVector( const std::vector& packet_feedback_vector) { RTC_DCHECK(std::is_sorted(packet_feedback_vector.begin(), packet_feedback_vector.end(), PacketFeedbackComparator())); for (const auto& packet : packet_feedback_vector) { if (IsInSendTimeHistory(packet)) { MaybeExpectFastRateChange(packet.send_time_ms); bitrate_estimator_->Update(packet.arrival_time_ms, packet.payload_size); } } } rtc::Optional AcknowledgedBitrateEstimator::bitrate_bps() const { return bitrate_estimator_->bitrate_bps(); } void AcknowledgedBitrateEstimator::SetAlrEndedTimeMs( int64_t alr_ended_time_ms) { alr_ended_time_ms_.emplace(alr_ended_time_ms); } void AcknowledgedBitrateEstimator::MaybeExpectFastRateChange( int64_t packet_send_time_ms) { if (alr_ended_time_ms_ && packet_send_time_ms > *alr_ended_time_ms_) { bitrate_estimator_->ExpectFastRateChange(); alr_ended_time_ms_.reset(); } } } // namespace webrtc