2019-03-04 21:54:50 -05:00
|
|
|
//
|
|
|
|
// DisplayMetrics.cpp
|
|
|
|
// Clock Signal
|
|
|
|
//
|
|
|
|
// Created by Thomas Harte on 04/03/2019.
|
|
|
|
// Copyright © 2019 Thomas Harte. All rights reserved.
|
|
|
|
//
|
|
|
|
|
|
|
|
#include "DisplayMetrics.hpp"
|
|
|
|
|
2019-03-05 22:01:58 -05:00
|
|
|
#include <numeric>
|
2019-03-05 21:41:20 -05:00
|
|
|
|
2019-03-04 21:54:50 -05:00
|
|
|
using namespace Outputs::Display;
|
|
|
|
|
2019-03-05 21:41:20 -05:00
|
|
|
// MARK: Frame size estimation.
|
|
|
|
|
2019-03-04 21:54:50 -05:00
|
|
|
void Metrics::announce_event(ScanTarget::Event event) {
|
2019-03-05 21:41:20 -05:00
|
|
|
switch(event) {
|
|
|
|
case ScanTarget::Event::EndHorizontalRetrace:
|
|
|
|
++lines_this_frame_;
|
|
|
|
break;
|
2019-03-05 22:01:58 -05:00
|
|
|
case ScanTarget::Event::BeginVerticalRetrace:
|
2019-03-05 21:41:20 -05:00
|
|
|
add_line_total(lines_this_frame_);
|
2019-03-05 22:01:58 -05:00
|
|
|
break;
|
|
|
|
case ScanTarget::Event::EndVerticalRetrace:
|
2019-03-05 21:41:20 -05:00
|
|
|
lines_this_frame_ = 0;
|
|
|
|
break;
|
|
|
|
default: break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void Metrics::add_line_total(int total) {
|
2019-03-05 22:01:58 -05:00
|
|
|
line_total_history_[line_total_history_pointer_] = total;
|
|
|
|
line_total_history_pointer_ = (line_total_history_pointer_ + 1) % line_total_history_.size();
|
|
|
|
}
|
|
|
|
|
2020-05-20 23:34:26 -04:00
|
|
|
float Metrics::visible_lines_per_frame_estimate() const {
|
2019-03-05 22:01:58 -05:00
|
|
|
// Just average the number of records contained in line_total_history_ to provide this estimate;
|
|
|
|
// that array should be an even number, to allow for potential interlaced sources.
|
|
|
|
return float(std::accumulate(line_total_history_.begin(), line_total_history_.end(), 0)) / float(line_total_history_.size());
|
2019-03-05 21:41:20 -05:00
|
|
|
}
|
|
|
|
|
2020-05-20 23:34:26 -04:00
|
|
|
int Metrics::current_line() const {
|
2019-03-05 22:01:58 -05:00
|
|
|
return lines_this_frame_;
|
2019-03-04 21:54:50 -05:00
|
|
|
}
|
|
|
|
|
2019-03-05 21:41:20 -05:00
|
|
|
// MARK: GPU processing speed decisions.
|
|
|
|
|
2019-03-04 21:54:50 -05:00
|
|
|
void Metrics::announce_did_resize() {
|
2019-03-05 21:41:20 -05:00
|
|
|
frames_missed_ = frames_hit_ = 0;
|
2019-03-04 21:54:50 -05:00
|
|
|
}
|
|
|
|
|
2020-09-13 21:07:59 -04:00
|
|
|
void Metrics::announce_draw_status(bool complete) {
|
2019-03-05 21:41:20 -05:00
|
|
|
if(!complete) {
|
|
|
|
++frames_missed_;
|
|
|
|
} else {
|
|
|
|
++frames_hit_;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Don't allow the record of history to extend too far into the past.
|
|
|
|
if(frames_hit_ + frames_missed_ > 200) {
|
|
|
|
// Subtract from whichever wasn't just incremented, to ensure the
|
|
|
|
// most recent information is more important than the historic stuff.
|
|
|
|
if(!complete) {
|
|
|
|
--frames_hit_;
|
|
|
|
} else {
|
|
|
|
--frames_missed_;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Rebalance if either thing has gone negative.
|
|
|
|
if(frames_hit_ < 0) {
|
|
|
|
frames_missed_ += frames_hit_;
|
|
|
|
frames_hit_ = 0;
|
|
|
|
}
|
|
|
|
if(frames_missed_ < 0) {
|
|
|
|
frames_hit_ += frames_missed_;
|
|
|
|
frames_missed_ = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-09-13 21:07:59 -04:00
|
|
|
void Metrics::announce_draw_status(size_t, std::chrono::high_resolution_clock::duration, bool complete) {
|
|
|
|
announce_draw_status(complete);
|
|
|
|
}
|
|
|
|
|
2020-05-20 23:34:26 -04:00
|
|
|
bool Metrics::should_lower_resolution() const {
|
2019-03-05 21:41:20 -05:00
|
|
|
// If less than 100 frames are on record, return no opinion; otherwise
|
|
|
|
// suggest a lower resolution if more than 10 frames in the last 100-200
|
|
|
|
// took too long to produce.
|
|
|
|
if(frames_hit_ + frames_missed_ < 100) return false;
|
|
|
|
return frames_missed_ > 10;
|
2019-03-04 21:54:50 -05:00
|
|
|
}
|