Account for server-side lag with burst packets.

Only count as burst, if there was enough lag. Might need adaption to
count lag again for judging the EPM, due to differing window resolution.
This commit is contained in:
asofold 2014-07-26 20:25:54 +02:00
parent b4ec7caa85
commit 901b2a45a2

View File

@ -90,10 +90,14 @@ public class NetStatic {
double violation = (double) fullCount - (double) (maxPackets * winNum * winDur / 1000f); double violation = (double) fullCount - (double) (maxPackets * winNum * winDur / 1000f);
final float burst = packetFreq.bucketScore(0); final float burst = packetFreq.bucketScore(0);
if (burst > burstPackets) { if (burst > burstPackets) {
// TODO: Account for "just now lag", i.e. time until first occupied one > 0. // Account for server-side lag "minimally".
if (burst > burstPackets * TickTask.getLag(winDur, true)) {
// TODO: Does lag adaption suffice this way ?
burstFreq.add(time, 1f); // TODO: Remove float packets or do this properly. burstFreq.add(time, 1f); // TODO: Remove float packets or do this properly.
violation = Math.max(violation, burst - burstDirect); violation = Math.max(violation, burst - burstDirect);
violation = Math.max(violation, burstEPM * (double) (burstFreq.bucketDuration() * burstFreq.numberOfBuckets()) / 60000.0 - (double) burstFreq.score(0f)); violation = Math.max(violation, burstEPM * (double) (burstFreq.bucketDuration() * burstFreq.numberOfBuckets()) / 60000.0 - (double) burstFreq.score(0f));
}
} }
return Math.max(0.0, violation); return Math.max(0.0, violation);
} }