Control rtt_mult addition cap via experiment.
Bug: webrtc:10717 Change-Id: I68f7d8216e1a1611e692dd82ba96890cad98c7de Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/140284 Commit-Queue: Michael Horowitz <mhoro@webrtc.org> Reviewed-by: Stefan Holmer <stefan@webrtc.org> Reviewed-by: Åsa Persson <asapersson@webrtc.org> Cr-Commit-Position: refs/heads/master@{#28191}
This commit is contained in:
@ -62,7 +62,8 @@ FrameBuffer::FrameBuffer(Clock* clock,
|
|||||||
stats_callback_(stats_callback),
|
stats_callback_(stats_callback),
|
||||||
last_log_non_decoded_ms_(-kLogNonDecodedIntervalMs),
|
last_log_non_decoded_ms_(-kLogNonDecodedIntervalMs),
|
||||||
add_rtt_to_playout_delay_(
|
add_rtt_to_playout_delay_(
|
||||||
webrtc::field_trial::IsEnabled("WebRTC-AddRttToPlayoutDelay")) {}
|
webrtc::field_trial::IsEnabled("WebRTC-AddRttToPlayoutDelay")),
|
||||||
|
rtt_mult_settings_(RttMultExperiment::GetRttMultValue()) {}
|
||||||
|
|
||||||
FrameBuffer::~FrameBuffer() {}
|
FrameBuffer::~FrameBuffer() {}
|
||||||
|
|
||||||
@ -299,11 +300,10 @@ EncodedFrame* FrameBuffer::GetNextFrame() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
float rtt_mult = protection_mode_ == kProtectionNackFEC ? 0.0 : 1.0;
|
float rtt_mult = protection_mode_ == kProtectionNackFEC ? 0.0 : 1.0;
|
||||||
absl::optional<double> rtt_mult_add_cap_ms = absl::nullopt;
|
absl::optional<float> rtt_mult_add_cap_ms = absl::nullopt;
|
||||||
if (RttMultExperiment::RttMultEnabled()) {
|
if (rtt_mult_settings_.has_value()) {
|
||||||
rtt_mult = RttMultExperiment::GetRttMultValue();
|
rtt_mult = rtt_mult_settings_->rtt_mult_setting;
|
||||||
// TODO(mhoro): add RttMultExperiment::GetJitterEstCapValue();
|
rtt_mult_add_cap_ms = rtt_mult_settings_->rtt_mult_add_cap_ms;
|
||||||
rtt_mult_add_cap_ms = 200.0;
|
|
||||||
}
|
}
|
||||||
timing_->SetJitterDelay(
|
timing_->SetJitterDelay(
|
||||||
jitter_estimator_.GetJitterEstimate(rtt_mult, rtt_mult_add_cap_ms));
|
jitter_estimator_.GetJitterEstimate(rtt_mult, rtt_mult_add_cap_ms));
|
||||||
|
@ -195,6 +195,9 @@ class FrameBuffer {
|
|||||||
|
|
||||||
const bool add_rtt_to_playout_delay_;
|
const bool add_rtt_to_playout_delay_;
|
||||||
|
|
||||||
|
// rtt_mult experiment settings.
|
||||||
|
const absl::optional<RttMultExperiment::Settings> rtt_mult_settings_;
|
||||||
|
|
||||||
RTC_DISALLOW_IMPLICIT_CONSTRUCTORS(FrameBuffer);
|
RTC_DISALLOW_IMPLICIT_CONSTRUCTORS(FrameBuffer);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -131,6 +131,7 @@ rtc_static_library("rtt_mult_experiment") {
|
|||||||
deps = [
|
deps = [
|
||||||
"../:rtc_base_approved",
|
"../:rtc_base_approved",
|
||||||
"../../system_wrappers:field_trial",
|
"../../system_wrappers:field_trial",
|
||||||
|
"//third_party/abseil-cpp/absl/types:optional",
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -22,29 +22,43 @@ namespace {
|
|||||||
const char kRttMultExperiment[] = "WebRTC-RttMult";
|
const char kRttMultExperiment[] = "WebRTC-RttMult";
|
||||||
const float max_rtt_mult_setting = 1.0;
|
const float max_rtt_mult_setting = 1.0;
|
||||||
const float min_rtt_mult_setting = 0.0;
|
const float min_rtt_mult_setting = 0.0;
|
||||||
|
const float max_rtt_mult_add_cap_ms = 2000.0;
|
||||||
|
const float min_rtt_mult_add_cap_ms = 0.0;
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
bool RttMultExperiment::RttMultEnabled() {
|
bool RttMultExperiment::RttMultEnabled() {
|
||||||
return field_trial::IsEnabled(kRttMultExperiment);
|
return field_trial::IsEnabled(kRttMultExperiment);
|
||||||
}
|
}
|
||||||
|
|
||||||
float RttMultExperiment::GetRttMultValue() {
|
absl::optional<RttMultExperiment::Settings>
|
||||||
|
RttMultExperiment::GetRttMultValue() {
|
||||||
|
if (!RttMultExperiment::RttMultEnabled())
|
||||||
|
return absl::nullopt;
|
||||||
const std::string group =
|
const std::string group =
|
||||||
webrtc::field_trial::FindFullName(kRttMultExperiment);
|
webrtc::field_trial::FindFullName(kRttMultExperiment);
|
||||||
if (group.empty()) {
|
if (group.empty()) {
|
||||||
RTC_LOG(LS_WARNING) << "Could not find rtt_mult_experiment.";
|
RTC_LOG(LS_WARNING) << "Could not find rtt_mult_experiment.";
|
||||||
return 0.0;
|
return absl::nullopt;
|
||||||
}
|
}
|
||||||
|
|
||||||
float rtt_mult_setting;
|
Settings s;
|
||||||
if (sscanf(group.c_str(), "Enabled-%f", &rtt_mult_setting) != 1) {
|
if (sscanf(group.c_str(), "Enabled-%f,%f", &s.rtt_mult_setting,
|
||||||
|
&s.rtt_mult_add_cap_ms) != 2) {
|
||||||
RTC_LOG(LS_WARNING) << "Invalid number of parameters provided.";
|
RTC_LOG(LS_WARNING) << "Invalid number of parameters provided.";
|
||||||
return 0.0;
|
return absl::nullopt;
|
||||||
}
|
}
|
||||||
// Bounds check rtt_mult_setting value.
|
// Bounds check rtt_mult_setting and rtt_mult_add_cap_ms values.
|
||||||
rtt_mult_setting = std::min(rtt_mult_setting, max_rtt_mult_setting);
|
s.rtt_mult_setting = std::min(s.rtt_mult_setting, max_rtt_mult_setting);
|
||||||
rtt_mult_setting = std::max(rtt_mult_setting, min_rtt_mult_setting);
|
s.rtt_mult_setting = std::max(s.rtt_mult_setting, min_rtt_mult_setting);
|
||||||
return rtt_mult_setting;
|
s.rtt_mult_add_cap_ms =
|
||||||
|
std::min(s.rtt_mult_add_cap_ms, max_rtt_mult_add_cap_ms);
|
||||||
|
s.rtt_mult_add_cap_ms =
|
||||||
|
std::max(s.rtt_mult_add_cap_ms, min_rtt_mult_add_cap_ms);
|
||||||
|
RTC_LOG(LS_INFO) << "rtt_mult experiment: rtt_mult value = "
|
||||||
|
<< s.rtt_mult_setting
|
||||||
|
<< " rtt_mult addition cap = " << s.rtt_mult_add_cap_ms
|
||||||
|
<< " ms.";
|
||||||
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace webrtc
|
} // namespace webrtc
|
||||||
|
@ -10,15 +10,24 @@
|
|||||||
#ifndef RTC_BASE_EXPERIMENTS_RTT_MULT_EXPERIMENT_H_
|
#ifndef RTC_BASE_EXPERIMENTS_RTT_MULT_EXPERIMENT_H_
|
||||||
#define RTC_BASE_EXPERIMENTS_RTT_MULT_EXPERIMENT_H_
|
#define RTC_BASE_EXPERIMENTS_RTT_MULT_EXPERIMENT_H_
|
||||||
|
|
||||||
|
#include "absl/types/optional.h"
|
||||||
|
|
||||||
namespace webrtc {
|
namespace webrtc {
|
||||||
|
|
||||||
class RttMultExperiment {
|
class RttMultExperiment {
|
||||||
public:
|
public:
|
||||||
|
struct Settings {
|
||||||
|
float rtt_mult_setting; // Jitter buffer size is increased by this factor
|
||||||
|
// times the estimated RTT.
|
||||||
|
float rtt_mult_add_cap_ms; // Jitter buffer size increase is capped by this
|
||||||
|
// value.
|
||||||
|
};
|
||||||
|
|
||||||
// Returns true if the experiment is enabled.
|
// Returns true if the experiment is enabled.
|
||||||
static bool RttMultEnabled();
|
static bool RttMultEnabled();
|
||||||
|
|
||||||
// Returns rtt_mult value from field trial.
|
// Returns rtt_mult value and rtt_mult addition cap value from field trial.
|
||||||
static float GetRttMultValue();
|
static absl::optional<RttMultExperiment::Settings> GetRttMultValue();
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace webrtc
|
} // namespace webrtc
|
||||||
|
@ -20,33 +20,43 @@ TEST(RttMultExperimentTest, RttMultDisabledByDefault) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
TEST(RttMultExperimentTest, RttMultEnabledByFieldTrial) {
|
TEST(RttMultExperimentTest, RttMultEnabledByFieldTrial) {
|
||||||
webrtc::test::ScopedFieldTrials field_trials("WebRTC-RttMult/Enabled-0.25/");
|
webrtc::test::ScopedFieldTrials field_trials(
|
||||||
|
"WebRTC-RttMult/Enabled-0.60,100.0/");
|
||||||
EXPECT_TRUE(RttMultExperiment::RttMultEnabled());
|
EXPECT_TRUE(RttMultExperiment::RttMultEnabled());
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(RttMultExperimentTest, RttMultTestValue) {
|
TEST(RttMultExperimentTest, RttMultTestValue) {
|
||||||
webrtc::test::ScopedFieldTrials field_trials("WebRTC-RttMult/Enabled-0.25/");
|
webrtc::test::ScopedFieldTrials field_trials(
|
||||||
EXPECT_EQ(0.25, RttMultExperiment::GetRttMultValue());
|
"WebRTC-RttMult/Enabled-0.60,100.0/");
|
||||||
|
EXPECT_EQ(0.6f, RttMultExperiment::GetRttMultValue()->rtt_mult_setting);
|
||||||
|
EXPECT_EQ(100.0f, RttMultExperiment::GetRttMultValue()->rtt_mult_add_cap_ms);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(RttMultExperimentTest, RttMultTestMalformedEnabled) {
|
TEST(RttMultExperimentTest, RttMultTestMalformedEnabled) {
|
||||||
webrtc::test::ScopedFieldTrials field_trials("WebRTC-RttMult/Enable-0.25/");
|
webrtc::test::ScopedFieldTrials field_trials(
|
||||||
|
"WebRTC-RttMult/Enable-0.60,100.0/");
|
||||||
EXPECT_FALSE(RttMultExperiment::RttMultEnabled());
|
EXPECT_FALSE(RttMultExperiment::RttMultEnabled());
|
||||||
|
EXPECT_FALSE(RttMultExperiment::GetRttMultValue());
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(RttMultExperimentTest, RttMultTestValueOutOfBoundsPositive) {
|
TEST(RttMultExperimentTest, RttMultTestValueOutOfBoundsPositive) {
|
||||||
webrtc::test::ScopedFieldTrials field_trials("WebRTC-RttMult/Enabled-1.5/");
|
webrtc::test::ScopedFieldTrials field_trials(
|
||||||
EXPECT_EQ(1.0, RttMultExperiment::GetRttMultValue());
|
"WebRTC-RttMult/Enabled-1.5,2100.0/");
|
||||||
|
EXPECT_EQ(1.0f, RttMultExperiment::GetRttMultValue()->rtt_mult_setting);
|
||||||
|
EXPECT_EQ(2000.0f, RttMultExperiment::GetRttMultValue()->rtt_mult_add_cap_ms);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(RttMultExperimentTest, RttMultTestValueOutOfBoundsNegative) {
|
TEST(RttMultExperimentTest, RttMultTestValueOutOfBoundsNegative) {
|
||||||
webrtc::test::ScopedFieldTrials field_trials("WebRTC-RttMult/Enabled--0.5/");
|
webrtc::test::ScopedFieldTrials field_trials(
|
||||||
EXPECT_EQ(0.0, RttMultExperiment::GetRttMultValue());
|
"WebRTC-RttMult/Enabled--0.5,-100.0/");
|
||||||
|
EXPECT_EQ(0.0f, RttMultExperiment::GetRttMultValue()->rtt_mult_setting);
|
||||||
|
EXPECT_EQ(0.0f, RttMultExperiment::GetRttMultValue()->rtt_mult_add_cap_ms);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(RttMultExperimentTest, RttMultTestMalformedValue) {
|
TEST(RttMultExperimentTest, RttMultTestMalformedValue) {
|
||||||
webrtc::test::ScopedFieldTrials field_trials("WebRTC-RttMult/Enabled-0.2a5/");
|
webrtc::test::ScopedFieldTrials field_trials(
|
||||||
EXPECT_NE(0.25, RttMultExperiment::GetRttMultValue());
|
"WebRTC-RttMult/Enabled-0.25,10a0.0/");
|
||||||
|
EXPECT_NE(100.0f, RttMultExperiment::GetRttMultValue()->rtt_mult_add_cap_ms);
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace webrtc
|
} // namespace webrtc
|
||||||
|
Reference in New Issue
Block a user