blob: 2ac7aeebca01217bd0642fdf1f413fb5ccc9f8ee [file] [log] [blame] [edit]
/*
* Copyright (c) 2019 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 "common_video/frame_rate_estimator.h"
#include "rtc_base/time_utils.h"
namespace webrtc {
FrameRateEstimator::FrameRateEstimator(TimeDelta averaging_window)
: averaging_window_(averaging_window) {}
void FrameRateEstimator::OnFrame(Timestamp time) {
CullOld(time);
frame_times_.push_back(time);
}
std::optional<double> FrameRateEstimator::GetAverageFps() const {
if (frame_times_.size() < 2) {
return std::nullopt;
}
TimeDelta time_span = frame_times_.back() - frame_times_.front();
if (time_span < TimeDelta::Micros(1)) {
return std::nullopt;
}
TimeDelta avg_frame_interval = time_span / (frame_times_.size() - 1);
return static_cast<double>(rtc::kNumMicrosecsPerSec) /
avg_frame_interval.us();
}
std::optional<double> FrameRateEstimator::GetAverageFps(Timestamp now) {
CullOld(now);
return GetAverageFps();
}
void FrameRateEstimator::Reset() {
frame_times_.clear();
}
void FrameRateEstimator::CullOld(Timestamp now) {
while (!frame_times_.empty() &&
frame_times_.front() + averaging_window_ < now) {
frame_times_.pop_front();
}
}
} // namespace webrtc