mirror of
https://github.com/overte-org/overte.git
synced 2025-08-09 13:09:52 +02:00
CR comments and fixing the average calculation
This commit is contained in:
parent
0c88972f09
commit
59027959b8
4 changed files with 44 additions and 7 deletions
|
@ -91,6 +91,7 @@
|
||||||
#include <SceneScriptingInterface.h>
|
#include <SceneScriptingInterface.h>
|
||||||
#include <ScriptCache.h>
|
#include <ScriptCache.h>
|
||||||
#include <SettingHandle.h>
|
#include <SettingHandle.h>
|
||||||
|
#include <SimpleAverage.h>
|
||||||
#include <SoundCache.h>
|
#include <SoundCache.h>
|
||||||
#include <TextRenderer.h>
|
#include <TextRenderer.h>
|
||||||
#include <Tooltip.h>
|
#include <Tooltip.h>
|
||||||
|
@ -178,6 +179,7 @@ using namespace std;
|
||||||
// Starfield information
|
// Starfield information
|
||||||
static unsigned STARFIELD_NUM_STARS = 50000;
|
static unsigned STARFIELD_NUM_STARS = 50000;
|
||||||
static unsigned STARFIELD_SEED = 1;
|
static unsigned STARFIELD_SEED = 1;
|
||||||
|
static uint8_t THROTTLED_IDLE_TIMER_DELAY = 2;
|
||||||
|
|
||||||
const qint64 MAXIMUM_CACHE_SIZE = 10 * BYTES_PER_GIGABYTES; // 10GB
|
const qint64 MAXIMUM_CACHE_SIZE = 10 * BYTES_PER_GIGABYTES; // 10GB
|
||||||
|
|
||||||
|
@ -1784,17 +1786,17 @@ void Application::checkFPS() {
|
||||||
DependencyManager::get<NodeList>()->sendDomainServerCheckIn();
|
DependencyManager::get<NodeList>()->sendDomainServerCheckIn();
|
||||||
}
|
}
|
||||||
|
|
||||||
static SimpleMovingAverage interIdleDurations;
|
|
||||||
static uint64_t lastIdleEnd{ 0 };
|
|
||||||
|
|
||||||
void Application::idle() {
|
void Application::idle() {
|
||||||
|
static SimpleAverage<float> interIdleDurations;
|
||||||
|
static uint64_t lastIdleEnd{ 0 };
|
||||||
|
|
||||||
if (lastIdleEnd != 0) {
|
if (lastIdleEnd != 0) {
|
||||||
uint64_t now = usecTimestampNow();
|
uint64_t now = usecTimestampNow();
|
||||||
interIdleDurations.updateAverage(now - lastIdleEnd);
|
interIdleDurations.update(now - lastIdleEnd);
|
||||||
static uint64_t lastReportTime = now;
|
static uint64_t lastReportTime = now;
|
||||||
if ((now - lastReportTime) >= (1000 * 1000)) {
|
if ((now - lastReportTime) >= (USECS_PER_SECOND)) {
|
||||||
int avgIdleDuration = (int)interIdleDurations.getAverage();
|
int avgIdleDuration = (int)interIdleDurations.getAverage();
|
||||||
qDebug() << "Average inter-idle time: " << avgIdleDuration << "s for " << interIdleDurations.getSampleCount() << " samples";
|
qCDebug(interfaceapp_timing) << "Average inter-idle time: " << avgIdleDuration << "s for " << interIdleDurations.getCount() << " samples";
|
||||||
interIdleDurations.reset();
|
interIdleDurations.reset();
|
||||||
lastReportTime = now;
|
lastReportTime = now;
|
||||||
}
|
}
|
||||||
|
@ -1845,7 +1847,7 @@ void Application::idle() {
|
||||||
|
|
||||||
// After finishing all of the above work, restart the idle timer, allowing 2ms to process events.
|
// After finishing all of the above work, restart the idle timer, allowing 2ms to process events.
|
||||||
}
|
}
|
||||||
idleTimer->start(_glWidget->isThrottleRendering() ? 10 : 0);
|
idleTimer->start(_glWidget->isThrottleRendering() ? THROTTLED_IDLE_TIMER_DELAY : 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
// check for any requested background downloads.
|
// check for any requested background downloads.
|
||||||
|
|
|
@ -12,3 +12,4 @@
|
||||||
#include "InterfaceLogging.h"
|
#include "InterfaceLogging.h"
|
||||||
|
|
||||||
Q_LOGGING_CATEGORY(interfaceapp, "hifi.interface")
|
Q_LOGGING_CATEGORY(interfaceapp, "hifi.interface")
|
||||||
|
Q_LOGGING_CATEGORY(interfaceapp_timing, "hifi.interface.timing")
|
||||||
|
|
|
@ -15,5 +15,6 @@
|
||||||
#include <QLoggingCategory>
|
#include <QLoggingCategory>
|
||||||
|
|
||||||
Q_DECLARE_LOGGING_CATEGORY(interfaceapp)
|
Q_DECLARE_LOGGING_CATEGORY(interfaceapp)
|
||||||
|
Q_DECLARE_LOGGING_CATEGORY(interfaceapp_timing)
|
||||||
|
|
||||||
#endif // hifi_InterfaceLogging_h
|
#endif // hifi_InterfaceLogging_h
|
||||||
|
|
33
libraries/shared/src/SimpleAverage.h
Normal file
33
libraries/shared/src/SimpleAverage.h
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
//
|
||||||
|
// Created by Bradley Austin Davis on 2015/07/01.
|
||||||
|
// Copyright 2013 High Fidelity, Inc.
|
||||||
|
//
|
||||||
|
// Distributed under the Apache License, Version 2.0.
|
||||||
|
// See the accompanying file LICENSE or http://www.apache.org/licenses/LICENSE-2.0.html
|
||||||
|
//
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
#ifndef hifi_SimpleAverage_h
|
||||||
|
#define hifi_SimpleAverage_h
|
||||||
|
|
||||||
|
template<typename T>
|
||||||
|
class SimpleAverage {
|
||||||
|
public:
|
||||||
|
void update(T sample) {
|
||||||
|
_sum += sample;
|
||||||
|
++_count;
|
||||||
|
}
|
||||||
|
void reset() {
|
||||||
|
_sum = 0;
|
||||||
|
_count = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int getCount() const { return _count; };
|
||||||
|
T getAverage() const { return _sum / (T)_count; };
|
||||||
|
|
||||||
|
private:
|
||||||
|
int _count;
|
||||||
|
T _sum;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
Loading…
Reference in a new issue