1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39
|
#include "stdafx.h"
#include "FramerateTimer.h"
namespace util {
FramerateTimer::Time::Time(FramerateTimer &t) : owner(t) {}
FramerateTimer::Time::~Time() {
owner.onInterval(Timestamp() - startTime);
}
FramerateTimer::FramerateTimer(const wchar_t *name) : name(name), currentSample(0) {}
void FramerateTimer::onInterval(Timespan time) {
samples[currentSample++] = time;
if (currentSample == numSamples) {
outputStats();
currentSample = 0;
}
}
void FramerateTimer::outputStats() {
Timespan minTime = samples[0];
Timespan maxTime = samples[0];
Timespan sumTime = samples[0];
for (nat i = 1; i < numSamples; i++) {
sumTime += samples[i];
limitMax(minTime, samples[i]);
limitMin(maxTime, samples[i]);
}
sumTime = sumTime / numSamples;
debugStream() << name << ": Min: " << minTime << ", max: " << maxTime << ", avg: " << sumTime << std::endl;
}
}
|