NOTRY=true BUG=webrtc:6156 Review-Url: https://codereview.webrtc.org/2206583002 Cr-Commit-Position: refs/heads/master@{#13619}
148 lines
4.8 KiB
C++
148 lines
4.8 KiB
C++
/*
|
|
* 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.
|
|
*/
|
|
|
|
#ifndef WEBRTC_MODULES_CONGESTION_CONTROLLER_DELAY_BASED_BWE_H_
|
|
#define WEBRTC_MODULES_CONGESTION_CONTROLLER_DELAY_BASED_BWE_H_
|
|
|
|
#include <list>
|
|
#include <map>
|
|
#include <memory>
|
|
#include <vector>
|
|
|
|
#include "webrtc/base/checks.h"
|
|
#include "webrtc/base/constructormagic.h"
|
|
#include "webrtc/base/criticalsection.h"
|
|
#include "webrtc/base/rate_statistics.h"
|
|
#include "webrtc/base/thread_checker.h"
|
|
#include "webrtc/modules/remote_bitrate_estimator/aimd_rate_control.h"
|
|
#include "webrtc/modules/remote_bitrate_estimator/include/remote_bitrate_estimator.h"
|
|
#include "webrtc/modules/remote_bitrate_estimator/inter_arrival.h"
|
|
#include "webrtc/modules/remote_bitrate_estimator/overuse_detector.h"
|
|
#include "webrtc/modules/remote_bitrate_estimator/overuse_estimator.h"
|
|
#include "webrtc/system_wrappers/include/critical_section_wrapper.h"
|
|
|
|
namespace webrtc {
|
|
|
|
class DelayBasedBwe : public RemoteBitrateEstimator {
|
|
public:
|
|
DelayBasedBwe(RemoteBitrateObserver* observer, Clock* clock);
|
|
virtual ~DelayBasedBwe() {}
|
|
|
|
void IncomingPacketFeedbackVector(
|
|
const std::vector<PacketInfo>& packet_feedback_vector) override;
|
|
|
|
void IncomingPacket(int64_t arrival_time_ms,
|
|
size_t payload_size,
|
|
const RTPHeader& header) override {
|
|
RTC_NOTREACHED();
|
|
}
|
|
|
|
// This class relies on Process() being called periodically (at least once
|
|
// every other second) for streams to be timed out properly. Therefore it
|
|
// shouldn't be detached from the ProcessThread except if it's about to be
|
|
// deleted.
|
|
void Process() override;
|
|
int64_t TimeUntilNextProcess() override;
|
|
void OnRttUpdate(int64_t avg_rtt_ms, int64_t max_rtt_ms) override;
|
|
void RemoveStream(uint32_t ssrc) override;
|
|
bool LatestEstimate(std::vector<uint32_t>* ssrcs,
|
|
uint32_t* bitrate_bps) const override;
|
|
void SetMinBitrate(int min_bitrate_bps) override;
|
|
|
|
private:
|
|
struct Probe {
|
|
Probe(int64_t send_time_ms,
|
|
int64_t recv_time_ms,
|
|
size_t payload_size,
|
|
int cluster_id)
|
|
: send_time_ms(send_time_ms),
|
|
recv_time_ms(recv_time_ms),
|
|
payload_size(payload_size),
|
|
cluster_id(cluster_id) {}
|
|
int64_t send_time_ms;
|
|
int64_t recv_time_ms;
|
|
size_t payload_size;
|
|
int cluster_id;
|
|
};
|
|
|
|
struct Cluster {
|
|
Cluster()
|
|
: send_mean_ms(0.0f),
|
|
recv_mean_ms(0.0f),
|
|
mean_size(0),
|
|
count(0),
|
|
num_above_min_delta(0) {}
|
|
|
|
int GetSendBitrateBps() const {
|
|
RTC_CHECK_GT(send_mean_ms, 0.0f);
|
|
return mean_size * 8 * 1000 / send_mean_ms;
|
|
}
|
|
|
|
int GetRecvBitrateBps() const {
|
|
RTC_CHECK_GT(recv_mean_ms, 0.0f);
|
|
return mean_size * 8 * 1000 / recv_mean_ms;
|
|
}
|
|
|
|
float send_mean_ms;
|
|
float recv_mean_ms;
|
|
// TODO(holmer): Add some variance metric as well?
|
|
size_t mean_size;
|
|
int count;
|
|
int num_above_min_delta;
|
|
};
|
|
|
|
typedef std::map<uint32_t, int64_t> Ssrcs;
|
|
enum class ProbeResult { kBitrateUpdated, kNoUpdate };
|
|
|
|
static void AddCluster(std::list<Cluster>* clusters, Cluster* cluster);
|
|
|
|
void IncomingPacketInfo(int64_t arrival_time_ms,
|
|
uint32_t send_time_24bits,
|
|
size_t payload_size,
|
|
uint32_t ssrc,
|
|
int probe_cluster_id);
|
|
|
|
void ComputeClusters(std::list<Cluster>* clusters) const;
|
|
|
|
std::list<Cluster>::const_iterator FindBestProbe(
|
|
const std::list<Cluster>& clusters) const;
|
|
|
|
// Returns true if a probe which changed the estimate was detected.
|
|
ProbeResult ProcessClusters(int64_t now_ms) EXCLUSIVE_LOCKS_REQUIRED(&crit_);
|
|
|
|
bool IsBitrateImproving(int probe_bitrate_bps) const
|
|
EXCLUSIVE_LOCKS_REQUIRED(&crit_);
|
|
|
|
void TimeoutStreams(int64_t now_ms) EXCLUSIVE_LOCKS_REQUIRED(&crit_);
|
|
|
|
rtc::ThreadChecker network_thread_;
|
|
Clock* const clock_;
|
|
RemoteBitrateObserver* const observer_;
|
|
std::unique_ptr<InterArrival> inter_arrival_;
|
|
std::unique_ptr<OveruseEstimator> estimator_;
|
|
OveruseDetector detector_;
|
|
RateStatistics incoming_bitrate_;
|
|
std::list<Probe> probes_;
|
|
size_t total_probes_received_;
|
|
int64_t first_packet_time_ms_;
|
|
int64_t last_update_ms_;
|
|
bool uma_recorded_;
|
|
|
|
rtc::CriticalSection crit_;
|
|
Ssrcs ssrcs_ GUARDED_BY(&crit_);
|
|
AimdRateControl remote_rate_ GUARDED_BY(&crit_);
|
|
|
|
RTC_DISALLOW_IMPLICIT_CONSTRUCTORS(DelayBasedBwe);
|
|
};
|
|
|
|
} // namespace webrtc
|
|
|
|
#endif // WEBRTC_MODULES_CONGESTION_CONTROLLER_DELAY_BASED_BWE_H_
|