Adapt to ActionFrequncy changes.

This commit is contained in:
asofold 2012-11-08 07:39:13 +01:00
parent 3bac9c9530
commit b3b88a7513
12 changed files with 23 additions and 21 deletions

View File

@ -74,7 +74,7 @@ public class FastBreak extends Check {
data.fastBreakPenalties.add(now, (float) missingTime); data.fastBreakPenalties.add(now, (float) missingTime);
// Only raise a violation, if the total penalty score exceeds the contention duration (for lag, delay). // Only raise a violation, if the total penalty score exceeds the contention duration (for lag, delay).
if (data.fastBreakPenalties.getScore(cc.fastBreakBucketFactor) > cc.fastBreakBucketContention){ if (data.fastBreakPenalties.score(cc.fastBreakBucketFactor) > cc.fastBreakBucketContention){
// TODO: maybe add one absolute penalty time for big amounts to stop breaking until then // TODO: maybe add one absolute penalty time for big amounts to stop breaking until then
final double vlAdded = (double) missingTime / 1000.0; final double vlAdded = (double) missingTime / 1000.0;
data.fastBreakVL += vlAdded; data.fastBreakVL += vlAdded;

View File

@ -24,7 +24,7 @@ public class Frequency extends Check {
data.frequencyBuckets.add(System.currentTimeMillis(), interval); data.frequencyBuckets.add(System.currentTimeMillis(), interval);
// Full period frequency. // Full period frequency.
final float fullScore = data.frequencyBuckets.getScore(cc.frequencyBucketFactor); final float fullScore = data.frequencyBuckets.score(cc.frequencyBucketFactor);
final float fullTime = cc.frequencyBuckets * cc.frequencyBucketDur; final float fullTime = cc.frequencyBuckets * cc.frequencyBucketDur;
// Short term arrivals. // Short term arrivals.

View File

@ -58,7 +58,7 @@ public class WrongBlock extends Check {
player.sendMessage("WrongBlock failure with dist: " + dist); player.sendMessage("WrongBlock failure with dist: " + dist);
} }
data.wrongBlockVL.add(now, (float) (dist + 1) / 2f); data.wrongBlockVL.add(now, (float) (dist + 1) / 2f);
final float score = data.wrongBlockVL.getScore(0.9f); final float score = data.wrongBlockVL.score(0.9f);
if (score > cc.wrongBLockLevel){ if (score > cc.wrongBLockLevel){
if (executeActions(player, score, 1D, cc.wrongBlockActions)) if (executeActions(player, score, 1D, cc.wrongBlockActions))
cancel = true; cancel = true;

View File

@ -51,7 +51,7 @@ public class Commands extends Check {
data.commandsShortTermWeight = 1.0; data.commandsShortTermWeight = 1.0;
} }
final float nw = data.commandsWeights.getScore(1f); final float nw = data.commandsWeights.score(1f);
final double violation = Math.max(nw - cc.commandsLevel, data.commandsShortTermWeight - cc.commandsShortTermLevel); final double violation = Math.max(nw - cc.commandsLevel, data.commandsShortTermWeight - cc.commandsShortTermLevel);
if (violation > 0.0){ if (violation > 0.0){

View File

@ -35,7 +35,7 @@ public class Logins extends Check {
final long durBucket = 1000L * cc.loginsSeconds / 6; final long durBucket = 1000L * cc.loginsSeconds / 6;
final ActionFrequency freq = getActionFrequency(player.getWorld().getName(), 6, durBucket, cc.loginsPerWorldCount); final ActionFrequency freq = getActionFrequency(player.getWorld().getName(), 6, durBucket, cc.loginsPerWorldCount);
freq.update(now); freq.update(now);
final boolean cancel = freq.getScore(1f) > cc.loginsLimit; final boolean cancel = freq.score(1f) > cc.loginsLimit;
if (!cancel) freq.add(now, 1f); if (!cancel) freq.add(now, 1f);
return cancel; return cancel;
} }

View File

@ -233,13 +233,13 @@ public class Text extends AsyncCheck implements INotifyReload{
// Add weight to frequency counts. // Add weight to frequency counts.
final float normalScore = Math.max(cc.textFreqNormMin, score); final float normalScore = Math.max(cc.textFreqNormMin, score);
data.chatFrequency.add(time, normalScore); data.chatFrequency.add(time, normalScore);
final float accumulated = cc.textFreqNormWeight * data.chatFrequency.getScore(cc.textFreqNormFactor); final float accumulated = cc.textFreqNormWeight * data.chatFrequency.score(cc.textFreqNormFactor);
final boolean normalViolation = accumulated > cc.textFreqNormLevel; final boolean normalViolation = accumulated > cc.textFreqNormLevel;
final float shortTermScore = Math.max(cc.textFreqShortTermMin, score); final float shortTermScore = Math.max(cc.textFreqShortTermMin, score);
data.chatShortTermFrequency.add(time, shortTermScore); data.chatShortTermFrequency.add(time, shortTermScore);
// TODO: very short term (1st bucket) or do it indirectly. // TODO: very short term (1st bucket) or do it indirectly.
final float shortTermAccumulated = cc.textFreqShortTermWeight * data.chatShortTermFrequency.getScore(cc.textFreqShortTermFactor); final float shortTermAccumulated = cc.textFreqShortTermWeight * data.chatShortTermFrequency.score(cc.textFreqShortTermFactor);
final boolean shortTermViolation = shortTermAccumulated > cc.textFreqShortTermLevel; final boolean shortTermViolation = shortTermAccumulated > cc.textFreqShortTermLevel;
if (normalViolation || shortTermViolation){ if (normalViolation || shortTermViolation){

View File

@ -79,7 +79,7 @@ public class FlatWords extends DigestedWords{
return 0.0f; return 0.0f;
} }
freq.update(ts); freq.update(ts);
float score = Math.min(1.0f, freq.getScore(factor)); float score = Math.min(1.0f, freq.score(factor));
freq.add(ts, 1.0f); freq.add(ts, 1.0f);
return score; return score;
} }

View File

@ -77,7 +77,7 @@ public class Combined {
final CombinedConfig cc = CombinedConfig.getConfig(player); final CombinedConfig cc = CombinedConfig.getConfig(player);
// Angle diff per second // Angle diff per second
final float total = Math.max(data.yawFreq.getScore(1f), data.yawFreq.getScore(0) * 3f); final float total = Math.max(data.yawFreq.score(1f), data.yawFreq.bucketScore(0) * 3f);
final float threshold = cc.yawRate; final float threshold = cc.yawRate;
boolean cancel = false; boolean cancel = false;
if (total > threshold){ if (total > threshold){

View File

@ -41,14 +41,14 @@ public class Improbable extends Check {
final CombinedData data = CombinedData.getData(player); final CombinedData data = CombinedData.getData(player);
final CombinedConfig cc = CombinedConfig.getConfig(player); final CombinedConfig cc = CombinedConfig.getConfig(player);
data.improbableCount.add(now, weight); data.improbableCount.add(now, weight);
final float shortTerm = data.improbableCount.getScore(0); final float shortTerm = data.improbableCount.bucketScore(0);
double violation = 0; double violation = 0;
boolean violated = false; boolean violated = false;
if (shortTerm * 0.8f > cc.improbableLevel / 20.0){ if (shortTerm * 0.8f > cc.improbableLevel / 20.0){
violation += shortTerm * 2d; violation += shortTerm * 2d;
violated = true; violated = true;
} }
final double full = data.improbableCount.getScore(1.0f); final double full = data.improbableCount.score(1.0f);
if (full > cc.improbableLevel){ if (full > cc.improbableLevel){
violation += full; violation += full;
violated = true; violated = true;

View File

@ -18,7 +18,7 @@ public class SelfHit extends Check {
// Treat self hitting as instant violation. // Treat self hitting as instant violation.
data.selfHitVL.add(System.currentTimeMillis(), 1.0f); data.selfHitVL.add(System.currentTimeMillis(), 1.0f);
// NOTE: This lets VL decrease slightly over 30 seconds, one could also use a number, but this is more tolerant. // NOTE: This lets VL decrease slightly over 30 seconds, one could also use a number, but this is more tolerant.
cancel = executeActions(damager, data.selfHitVL.getScore(0.99f), 1.0f, cc.selfHitActions); cancel = executeActions(damager, data.selfHitVL.score(0.99f), 1.0f, cc.selfHitActions);
return cancel; return cancel;
} }

View File

@ -51,7 +51,7 @@ public class Speed extends Check {
data.speedBuckets.add(now, 1f); data.speedBuckets.add(now, 1f);
// Medium term (normalized to one second). // Medium term (normalized to one second).
final float total = data.speedBuckets.getScore(cc.speedBucketFactor) * 1000f / (float) (cc.speedBucketDur * cc.speedBuckets); final float total = data.speedBuckets.score(cc.speedBucketFactor) * 1000f / (float) (cc.speedBucketDur * cc.speedBuckets);
// Short term. // Short term.
final int tick = TickTask.getTick(); final int tick = TickTask.getTick();

View File

@ -354,7 +354,7 @@ public class SurvivalFly extends Check {
System.out.println(player.getName() + " vertical freedom: " + data.verticalFreedom + " ("+data.verticalVelocity+"/"+data.verticalVelocityCounter+"), jumpphase: " + data.survivalFlyJumpPhase); System.out.println(player.getName() + " vertical freedom: " + data.verticalFreedom + " ("+data.verticalVelocity+"/"+data.verticalVelocityCounter+"), jumpphase: " + data.survivalFlyJumpPhase);
System.out.println(player.getName() + " hDist: " + hDistance + " / " + hAllowedDistance + " , vDist: " + (yDistance) + " ("+player.getVelocity().getY()+")" + " / " + vAllowedDistance); System.out.println(player.getName() + " hDist: " + hDistance + " / " + hAllowedDistance + " , vDist: " + (yDistance) + " ("+player.getVelocity().getY()+")" + " / " + vAllowedDistance);
System.out.println(player.getName() + " y" + (fromOnGround?"(onground)":"") + (data.noFallAssumeGround?"(assumeonground)":"") + ": " + from.getY() +"(" + player.getLocation().getY() + ") -> " + to.getY()+ (toOnGround?"(onground)":"")); System.out.println(player.getName() + " y" + (fromOnGround?"(onground)":"") + (data.noFallAssumeGround?"(assumeonground)":"") + ": " + from.getY() +"(" + player.getLocation().getY() + ") -> " + to.getY()+ (toOnGround?"(onground)":""));
if (cc.survivalFlyAccounting) System.out.println(player.getName() + " h=" + data.hDistSum.getScore(1f)+"/" + data.hDistSum.getScore(1) + " , v=" + data.vDistSum.getScore(1f)+"/"+data.vDistSum.getScore(1) ); if (cc.survivalFlyAccounting) System.out.println(player.getName() + " h=" + data.hDistSum.score(1f)+"/" + data.hDistSum.bucketScore(1) + " , v=" + data.vDistSum.score(1f)+"/"+data.vDistSum.bucketScore(1) );
System.out.println(player.getName() + " tags: " + CheckUtils.join(tags, "+")); System.out.println(player.getName() + " tags: " + CheckUtils.join(tags, "+"));
} }
@ -437,25 +437,27 @@ public class SurvivalFly extends Check {
/** /**
* Keep track of values, demanding that with time the values decrease.<br> * Keep track of values, demanding that with time the values decrease.<br>
* The ActionFrequency objects have 3 buckets. * The ActionFrequency objects have 3 buckets, bucket 1 is checked against bucket 2, 0 is ignored.
* @param now * @param now
* @param value * @param value
* @param sum * @param sum
* @param count * @param count
* @param tags * @param tags
* @param tag * @param tag
* @return * @return absolute difference on violation.;
*/ */
private static final double doAccounting(final long now, final double value, final ActionFrequency sum, final ActionFrequency count, final ArrayList<String> tags, String tag) private static final double doAccounting(final long now, final double value, final ActionFrequency sum, final ActionFrequency count, final ArrayList<String> tags, String tag)
{ {
sum.add(now, (float) value); sum.add(now, (float) value);
count.add(now, 1f); count.add(now, 1f);
if (count.getScore(2) > 0 && count.getScore(1) > 0) { // TODO: This does not make sense (vertical vs horizontal up vs down: needs parameter !).
final float sc0 = sum.getScore(1); // TODO: Add hover return parameter
final float sc1 = sum.getScore(2); if (count.bucketScore(2) > 0 && count.bucketScore(1) > 0) {
if (sc0 < sc1 || value < 3.9 && sc0 == sc1) { final float sc1 = sum.bucketScore(1);
final float sc2 = sum.bucketScore(2);
if (sc1 < sc2 || value < 3.9 && sc1 == sc2) {
tags.add(tag); tags.add(tag);
return sc0 - sc1; return sc1 - sc2;
} }
} }
return 0; return 0;