[BLEEDING] Attempt to make moving.morepackets less strict.

This commit is contained in:
asofold 2014-07-18 01:45:58 +02:00
parent 85a104ed75
commit e3cdd761ec

View File

@ -65,29 +65,36 @@ public class MorePackets extends Check {
// Add packet to frequency count. // Add packet to frequency count.
data.morePacketsFreq.add(time, 1f); data.morePacketsFreq.add(time, 1f);
// Fill up all "used" time windows (minimum we can do without other events. // Fill up all "used" time windows (minimum we can do without other events).
boolean used = false;
final float burnScore = (float) idealPackets * (float) data.morePacketsFreq.bucketDuration() / 1000f; final float burnScore = (float) idealPackets * (float) data.morePacketsFreq.bucketDuration() / 1000f;
for (int i = 1; i < data.morePacketsFreq.numberOfBuckets(); i++) { // Find index.
final float score = data.morePacketsFreq.bucketScore(i); int i;
if (score > 0f) { boolean used = false;
for (i = 1; i < data.morePacketsFreq.numberOfBuckets(); i++) {
if (data.morePacketsFreq.bucketScore(i) > 0f) {
if (used) { if (used) {
// Burn this one. break;
data.morePacketsFreq.setBucket(i, Math.max(score, burnScore)); } else {
}
else {
// Burn all after this.
used = true; used = true;
} }
} }
} }
final double fullCount;
if (i < data.morePacketsFreq.numberOfBuckets() - 1) {
// Assume all following time windows are burnt.
final float trailing = Math.max(data.morePacketsFreq.trailingScore(1, 1f), burnScore * (data.morePacketsFreq.numberOfBuckets() - (i + 1)));
final float leading = data.morePacketsFreq.leadingScore(1, 1f);
fullCount = leading + trailing;
} else {
// All time windows are used.
fullCount = data.morePacketsFreq.score(1f);
}
final double violation = (double) fullCount - (double) (burnScore * data.morePacketsFreq.numberOfBuckets());
// TODO: Burn time windows based on other activity counting [e.g. same resolution ActinFrequency with keep-alive]. // TODO: Burn time windows based on other activity counting [e.g. same resolution ActinFrequency with keep-alive].
// Compare score to maximum allowed.
final float fullCount = data.morePacketsFreq.score(1f);
final double violation = (double) fullCount - (double) (data.morePacketsFreq.bucketDuration() * data.morePacketsFreq.numberOfBuckets() * maxPackets / 1000);
// Player used up buffer, they fail the check. // Player used up buffer, they fail the check.
if (violation > 0.0) { if (violation > 0.0) {