Move simulcast hysteresis factor parsing to RateControlSettings
Bug: webrtc:10223 Change-Id: I962ca959afbcd8c27a0f79533c6e3c97369c697e Reviewed-on: https://webrtc-review.googlesource.com/c/119262 Commit-Queue: Erik Språng <sprang@webrtc.org> Reviewed-by: Ilya Nikolaevskiy <ilnik@webrtc.org> Cr-Commit-Position: refs/heads/master@{#26374}
This commit is contained in:
@ -292,6 +292,7 @@ rtc_source_set("video_coding_utility") {
|
|||||||
"../../rtc_base:rtc_task_queue",
|
"../../rtc_base:rtc_task_queue",
|
||||||
"../../rtc_base:sequenced_task_checker",
|
"../../rtc_base:sequenced_task_checker",
|
||||||
"../../rtc_base/experiments:quality_scaling_experiment",
|
"../../rtc_base/experiments:quality_scaling_experiment",
|
||||||
|
"../../rtc_base/experiments:rate_control_settings",
|
||||||
"../../rtc_base/system:arch",
|
"../../rtc_base/system:arch",
|
||||||
"../../rtc_base/task_utils:repeating_task",
|
"../../rtc_base/task_utils:repeating_task",
|
||||||
"../../system_wrappers",
|
"../../system_wrappers",
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
|
|
||||||
#include "common_types.h" // NOLINT(build/include)
|
#include "common_types.h" // NOLINT(build/include)
|
||||||
#include "rtc_base/checks.h"
|
#include "rtc_base/checks.h"
|
||||||
|
#include "rtc_base/experiments/rate_control_settings.h"
|
||||||
#include "system_wrappers/include/field_trial.h"
|
#include "system_wrappers/include/field_trial.h"
|
||||||
|
|
||||||
namespace webrtc {
|
namespace webrtc {
|
||||||
@ -40,33 +41,6 @@ static const float kBaseHeavy3TlRateAllocation[kMaxTemporalStreams] = {
|
|||||||
|
|
||||||
const uint32_t kLegacyScreenshareTl0BitrateKbps = 200;
|
const uint32_t kLegacyScreenshareTl0BitrateKbps = 200;
|
||||||
const uint32_t kLegacyScreenshareTl1BitrateKbps = 1000;
|
const uint32_t kLegacyScreenshareTl1BitrateKbps = 1000;
|
||||||
|
|
||||||
double GetHysteresisFactor(const VideoCodec& codec) {
|
|
||||||
double factor = 1.0;
|
|
||||||
|
|
||||||
std::string field_trial_name;
|
|
||||||
switch (codec.mode) {
|
|
||||||
case VideoCodecMode::kRealtimeVideo:
|
|
||||||
field_trial_name = "WebRTC-SimulcastUpswitchHysteresisPercent";
|
|
||||||
// Default to no hysteresis for simulcast video.
|
|
||||||
factor = 1.0;
|
|
||||||
break;
|
|
||||||
case VideoCodecMode::kScreensharing:
|
|
||||||
field_trial_name = "WebRTC-SimulcastScreenshareUpswitchHysteresisPercent";
|
|
||||||
// Default to 35% hysteresis for simulcast screenshare.
|
|
||||||
factor = 1.35;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string group_name = webrtc::field_trial::FindFullName(field_trial_name);
|
|
||||||
int percent = 0;
|
|
||||||
if (!group_name.empty() && sscanf(group_name.c_str(), "%d", &percent) == 1 &&
|
|
||||||
percent >= 0) {
|
|
||||||
factor = 1.0 + (percent / 100.0);
|
|
||||||
}
|
|
||||||
|
|
||||||
return factor;
|
|
||||||
}
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
float SimulcastRateAllocator::GetTemporalRateAllocation(int num_layers,
|
float SimulcastRateAllocator::GetTemporalRateAllocation(int num_layers,
|
||||||
@ -83,7 +57,12 @@ float SimulcastRateAllocator::GetTemporalRateAllocation(int num_layers,
|
|||||||
}
|
}
|
||||||
|
|
||||||
SimulcastRateAllocator::SimulcastRateAllocator(const VideoCodec& codec)
|
SimulcastRateAllocator::SimulcastRateAllocator(const VideoCodec& codec)
|
||||||
: codec_(codec), hysteresis_factor_(GetHysteresisFactor(codec)) {}
|
: codec_(codec),
|
||||||
|
hysteresis_factor_(codec.mode == VideoCodecMode::kScreensharing
|
||||||
|
? RateControlSettings::ParseFromFieldTrials()
|
||||||
|
.GetSimulcastScreenshareHysteresisFactor()
|
||||||
|
: RateControlSettings::ParseFromFieldTrials()
|
||||||
|
.GetSimulcastVideoHysteresisFactor()) {}
|
||||||
|
|
||||||
SimulcastRateAllocator::~SimulcastRateAllocator() = default;
|
SimulcastRateAllocator::~SimulcastRateAllocator() = default;
|
||||||
|
|
||||||
|
@ -35,6 +35,14 @@ const char kVp8TrustedRateControllerFieldTrialName[] =
|
|||||||
const char kVp9TrustedRateControllerFieldTrialName[] =
|
const char kVp9TrustedRateControllerFieldTrialName[] =
|
||||||
"WebRTC-LibvpxVp9TrustedRateController";
|
"WebRTC-LibvpxVp9TrustedRateController";
|
||||||
|
|
||||||
|
const char* kVideoHysteresisFieldTrialname =
|
||||||
|
"WebRTC-SimulcastUpswitchHysteresisPercent";
|
||||||
|
const double kDefaultVideoHysteresisFactor = 1.0;
|
||||||
|
const char* kScreenshareHysteresisFieldTrialname =
|
||||||
|
"WebRTC-SimulcastScreenshareUpswitchHysteresisPercent";
|
||||||
|
// Default to 35% hysteresis for simulcast screenshare.
|
||||||
|
const double kDefaultScreenshareHysteresisFactor = 1.35;
|
||||||
|
|
||||||
absl::optional<int> MaybeReadCwndExperimentParameter(
|
absl::optional<int> MaybeReadCwndExperimentParameter(
|
||||||
const WebRtcKeyValueConfig* const key_value_config) {
|
const WebRtcKeyValueConfig* const key_value_config) {
|
||||||
int64_t accepted_queue_ms;
|
int64_t accepted_queue_ms;
|
||||||
@ -74,6 +82,18 @@ bool IsEnabled(const WebRtcKeyValueConfig* const key_value_config,
|
|||||||
return key_value_config->Lookup(key).find("Enabled") == 0;
|
return key_value_config->Lookup(key).find("Enabled") == 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
double ParseHysteresisFactor(const WebRtcKeyValueConfig* const key_value_config,
|
||||||
|
absl::string_view key,
|
||||||
|
double default_value) {
|
||||||
|
std::string group_name = key_value_config->Lookup(key);
|
||||||
|
int percent = 0;
|
||||||
|
if (!group_name.empty() && sscanf(group_name.c_str(), "%d", &percent) == 1 &&
|
||||||
|
percent >= 0) {
|
||||||
|
return 1.0 + (percent / 100.0);
|
||||||
|
}
|
||||||
|
return default_value;
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
RateControlSettings::RateControlSettings(
|
RateControlSettings::RateControlSettings(
|
||||||
@ -89,11 +109,21 @@ RateControlSettings::RateControlSettings(
|
|||||||
trust_vp8_(
|
trust_vp8_(
|
||||||
"trust_vp8",
|
"trust_vp8",
|
||||||
IsEnabled(key_value_config, kVp8TrustedRateControllerFieldTrialName)),
|
IsEnabled(key_value_config, kVp8TrustedRateControllerFieldTrialName)),
|
||||||
trust_vp9_("trust_vp9",
|
trust_vp9_(
|
||||||
IsEnabled(key_value_config,
|
"trust_vp9",
|
||||||
kVp9TrustedRateControllerFieldTrialName)) {
|
IsEnabled(key_value_config, kVp9TrustedRateControllerFieldTrialName)),
|
||||||
|
video_hysteresis_("video_hysteresis",
|
||||||
|
ParseHysteresisFactor(key_value_config,
|
||||||
|
kVideoHysteresisFieldTrialname,
|
||||||
|
kDefaultVideoHysteresisFactor)),
|
||||||
|
screenshare_hysteresis_(
|
||||||
|
"screenshare_hysteresis",
|
||||||
|
ParseHysteresisFactor(key_value_config,
|
||||||
|
kScreenshareHysteresisFieldTrialname,
|
||||||
|
kDefaultScreenshareHysteresisFactor)) {
|
||||||
ParseFieldTrial({&congestion_window_, &congestion_window_pushback_,
|
ParseFieldTrial({&congestion_window_, &congestion_window_pushback_,
|
||||||
&pacing_factor_, &alr_probing_, &trust_vp8_, &trust_vp9_},
|
&pacing_factor_, &alr_probing_, &trust_vp8_, &trust_vp9_,
|
||||||
|
&video_hysteresis_, &screenshare_hysteresis_},
|
||||||
key_value_config->Lookup("WebRTC-VideoRateControl"));
|
key_value_config->Lookup("WebRTC-VideoRateControl"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -146,4 +176,12 @@ bool RateControlSettings::LibvpxVp9TrustedRateController() const {
|
|||||||
return trust_vp9_.Get();
|
return trust_vp9_.Get();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
double RateControlSettings::GetSimulcastVideoHysteresisFactor() const {
|
||||||
|
return video_hysteresis_.Get();
|
||||||
|
}
|
||||||
|
|
||||||
|
double RateControlSettings::GetSimulcastScreenshareHysteresisFactor() const {
|
||||||
|
return screenshare_hysteresis_.Get();
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace webrtc
|
} // namespace webrtc
|
||||||
|
@ -41,6 +41,9 @@ class RateControlSettings final {
|
|||||||
bool LibvpxVp8TrustedRateController() const;
|
bool LibvpxVp8TrustedRateController() const;
|
||||||
bool LibvpxVp9TrustedRateController() const;
|
bool LibvpxVp9TrustedRateController() const;
|
||||||
|
|
||||||
|
double GetSimulcastVideoHysteresisFactor() const;
|
||||||
|
double GetSimulcastScreenshareHysteresisFactor() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
explicit RateControlSettings(
|
explicit RateControlSettings(
|
||||||
const WebRtcKeyValueConfig* const key_value_config);
|
const WebRtcKeyValueConfig* const key_value_config);
|
||||||
@ -51,6 +54,8 @@ class RateControlSettings final {
|
|||||||
FieldTrialParameter<bool> alr_probing_;
|
FieldTrialParameter<bool> alr_probing_;
|
||||||
FieldTrialParameter<bool> trust_vp8_;
|
FieldTrialParameter<bool> trust_vp8_;
|
||||||
FieldTrialParameter<bool> trust_vp9_;
|
FieldTrialParameter<bool> trust_vp9_;
|
||||||
|
FieldTrialParameter<double> video_hysteresis_;
|
||||||
|
FieldTrialParameter<double> screenshare_hysteresis_;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace webrtc
|
} // namespace webrtc
|
||||||
|
Reference in New Issue
Block a user