All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.tenio.engine.physic2d.utility.Smoother Maven / Gradle / Ivy

Go to download

TenIO is a java NIO (Non-blocking I/O) based server specifically designed for multiplayer games. It supports UDP and TCP transports which are handled by Netty for high-speed network transmission. This is the engine module for the game related handlers of the framework.

There is a newer version: 0.6.0
Show newest version
package com.tenio.engine.physic2d.utility;

import com.tenio.engine.physic2d.math.Vector2;
import java.util.ArrayList;
import java.util.List;

/**
 * Template class to help calculate the average value of a history of values.
 * This can only be used with types that have a 'zero' value and that have the
 * += and / operators overloaded.
 * 
* Example: Used to smooth frame rate calculations. */ public class Smoother { /** * This holds the history. */ private final List histories; /** * an example of the 'zero' value of the type to be smoothed. This would be * something like Vector2D(0,0), see {@link Vector2}. */ private final T zeroValue; private int nextUpdateSlot; /** * To instantiate a Smoother, pass it the number of samples you want to use in the smoothing, * and an example of a 'zero' type. * * @param sampleSize the sample size * @param zeroValue the zero value */ public Smoother(int sampleSize, T zeroValue) { histories = new ArrayList(sampleSize); for (int i = 0; i < sampleSize; i++) { histories.add(zeroValue); } this.zeroValue = zeroValue; nextUpdateSlot = 0; } /** * Each time you want to get a new average, feed it the most recent value and * this method will return an average over the last SampleSize updates. * * @param mostRecentValue the most recent value * @return an average over the last SampleSize updates */ // @SuppressWarnings("unchecked") public T update(T mostRecentValue) { // overwrite the oldest value with the newest histories.set(nextUpdateSlot++, mostRecentValue); // make sure m_iNextUpdateSlot wraps around. if (nextUpdateSlot == histories.size()) { nextUpdateSlot = 0; } // now to calculate the average of the history list T sum = null; try { sum = (T) zeroValue.getClass().getConstructor(Float.TYPE).newInstance(0); } catch (Exception e) { e.printStackTrace(); System.exit(1); } var it = histories.listIterator(); while (it.hasNext()) { sum = add(sum, it.next()); } sum = div(sum, (float) histories.size()); return sum; } @SuppressWarnings("unchecked") public X add(X a, X b) { return (X) Float.valueOf(a.floatValue() + b.floatValue()); } @SuppressWarnings("unchecked") public X div(X a, float b) { return (X) Float.valueOf(a.floatValue() / b); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy