Merge "Add MaxLumaSampleRate grace percent to stats."
This commit is contained in:
commit
21015480f6
@ -132,8 +132,11 @@ Vp9Level Vp9LevelStats::GetLevel() const {
|
|||||||
|
|
||||||
int level_index = 0;
|
int level_index = 0;
|
||||||
Vp9Level max_level = LEVEL_UNKNOWN;
|
Vp9Level max_level = LEVEL_UNKNOWN;
|
||||||
|
const double grace_multiplier =
|
||||||
|
max_luma_sample_rate_grace_percent_ / 100.0 + 1.0;
|
||||||
for (int i = 0; i < kNumVp9Levels; ++i) {
|
for (int i = 0; i < kNumVp9Levels; ++i) {
|
||||||
if (max_luma_sample_rate <= Vp9LevelTable[i].max_luma_sample_rate) {
|
if (max_luma_sample_rate <=
|
||||||
|
Vp9LevelTable[i].max_luma_sample_rate * grace_multiplier) {
|
||||||
if (max_level < Vp9LevelTable[i].level) {
|
if (max_level < Vp9LevelTable[i].level) {
|
||||||
max_level = Vp9LevelTable[i].level;
|
max_level = Vp9LevelTable[i].level;
|
||||||
level_index = i;
|
level_index = i;
|
||||||
|
@ -73,6 +73,7 @@ class Vp9LevelStats {
|
|||||||
current_luma_size_(0),
|
current_luma_size_(0),
|
||||||
max_luma_size_(0),
|
max_luma_size_(0),
|
||||||
max_luma_end_ns_(0),
|
max_luma_end_ns_(0),
|
||||||
|
max_luma_sample_rate_grace_percent_(1.5),
|
||||||
first_altref(true),
|
first_altref(true),
|
||||||
frames_since_last_altref(0),
|
frames_since_last_altref(0),
|
||||||
minimum_altref_distance(std::numeric_limits<int>::max()),
|
minimum_altref_distance(std::numeric_limits<int>::max()),
|
||||||
@ -135,7 +136,12 @@ class Vp9LevelStats {
|
|||||||
// not explictly set by this function then this class will use end - start
|
// not explictly set by this function then this class will use end - start
|
||||||
// as the duration.
|
// as the duration.
|
||||||
void set_duration(int64_t time_ns) { duration_ns_ = time_ns; }
|
void set_duration(int64_t time_ns) { duration_ns_ = time_ns; }
|
||||||
|
double max_luma_sample_rate_grace_percent() const {
|
||||||
|
return max_luma_sample_rate_grace_percent_;
|
||||||
|
}
|
||||||
|
void set_max_luma_sample_rate_grace_percent(double percent) {
|
||||||
|
max_luma_sample_rate_grace_percent_ = percent;
|
||||||
|
}
|
||||||
bool estimate_last_frame_duration() const {
|
bool estimate_last_frame_duration() const {
|
||||||
return estimate_last_frame_duration_;
|
return estimate_last_frame_duration_;
|
||||||
}
|
}
|
||||||
@ -164,6 +170,14 @@ class Vp9LevelStats {
|
|||||||
int64_t max_luma_size_;
|
int64_t max_luma_size_;
|
||||||
int64_t max_luma_end_ns_;
|
int64_t max_luma_end_ns_;
|
||||||
|
|
||||||
|
// MaxLumaSampleRate = (ExampleFrameRate + ExampleFrameRate /
|
||||||
|
// MinimumAltrefDistance) * MaxLumaPictureSize. For levels 1-4
|
||||||
|
// ExampleFrameRate / MinimumAltrefDistance is non-integer, so using a sliding
|
||||||
|
// window of one frame to calculate MaxLumaSampleRate may have frames >
|
||||||
|
// (ExampleFrameRate + ExampleFrameRate / MinimumAltrefDistance) in the
|
||||||
|
// window. In order to address this issue, a grace percent of 1.5 was added.
|
||||||
|
double max_luma_sample_rate_grace_percent_;
|
||||||
|
|
||||||
bool first_altref;
|
bool first_altref;
|
||||||
int frames_since_last_altref;
|
int frames_since_last_altref;
|
||||||
int minimum_altref_distance;
|
int minimum_altref_distance;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user