Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Inconsistent latency causing false positives with perfect strafe detection #10

Open
pabp opened this issue Apr 10, 2018 · 0 comments
Open
Assignees

Comments

@pabp
Copy link

pabp commented Apr 10, 2018

One of our admins is on shitty cellular internet (lives out in the countryside, all he can get unfortunately) and when his latency significantly jumps Oryx starts returning false positives for the perfect strafe detection. I know for a fact he's not cheating (as in I've literally stood in his house and watched over his shoulder as he plays, he's a friend and co-owner of the server) so I suspect it's something to do with the connection variability causing Oryx to return strafe offsets as zero during these spikes. I think just increasing the sample size might mitigate this at least partially, but if ping is accessible via Sourcemod one possible solution could be to label or drop detections that occur during significant deviations from a rolling average of ping. I think (maybe) that'd be more robust than an average taken only once as a single derived sample could be exploited by joining, letting it set and then deliberately inducing network congestion with P2P software or some other lag-causing activity.

I'm going to try doubling the sample size to see if that has any effect on things for now.

E: Doubled the sample and detection thresholds for perfect strafes, he still kept showing up and I had a lightbulb moment. Checked status from rcon and his rate was only 20840, which is iirc the lowest possible on 128tick or maybe at all. Had him bump it to 64000 and checked strafe_stats, still some zeroes but below the low detection threshold. Going to install a rate enforcing plugin and set that as the lower bound, should cut the number of bad detections from people with old/weird configurations.

E2: Ok, I'm dumb as heck. sv_minrate was 16000, no wonder things were being weird. Whoops. I guess maybe note in the documentation that it has the potential to generate false positives if left at default.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants