mirror of
https://github.com/NoCheatPlus/NoCheatPlus.git
synced 2025-01-24 00:11:32 +01:00
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:
parent
b4ec7caa85
commit
901b2a45a2
@ -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".
|
||||||
burstFreq.add(time, 1f); // TODO: Remove float packets or do this properly.
|
if (burst > burstPackets * TickTask.getLag(winDur, true)) {
|
||||||
violation = Math.max(violation, burst - burstDirect);
|
// TODO: Does lag adaption suffice this way ?
|
||||||
violation = Math.max(violation, burstEPM * (double) (burstFreq.bucketDuration() * burstFreq.numberOfBuckets()) / 60000.0 - (double) burstFreq.score(0f));
|
burstFreq.add(time, 1f); // TODO: Remove float packets or do this properly.
|
||||||
|
violation = Math.max(violation, burst - burstDirect);
|
||||||
|
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);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user