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

com.zpf.tool.StabilizerFloat Maven / Gradle / Ivy

package com.zpf.tool;

import java.util.Arrays;

public class StabilizerFloat {
    private final float[] records;
    private float lastValue;
    public StabilizerFloat(int size) {
        this(0f, size);
    }
    public StabilizerFloat(float initValue, int size) {
        records = new float[size];
        lastValue = initValue;
        if (initValue != 0.0) {
            Arrays.fill(records, initValue);
        }
    }

    public float add(float value) {
        int size = records.length;
        if (size < 2) {
            lastValue = value;
            return lastValue;
        }
        float sum = 0f;
        if (size < 5) {
            for (int i = 0; i < size; i++) {
                if (i == records.length - 1) {
                    records[i] = value;
                } else {
                    records[i] = records[i + 1];
                }
                sum = sum + records[i];
            }
            lastValue = sum / size;
        } else {
            float max = value;
            float min = value;
            for (int i = 0; i < size; i++) {
                if (i == records.length - 1) {
                    records[i] = value;
                } else {
                    records[i] = records[i + 1];
                }
                sum = sum + records[i];
                if (records[i] > max) {
                    max = records[i];
                }
                if (records[i] < min) {
                    min = records[i];
                }
            }
            sum = sum - max - min;
            lastValue = sum / (size - 2);
        }
        return lastValue;
    }

    public float getValue() {
        return lastValue;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy