mirror of
https://github.com/Pinball3D/Rabbit-R1.git
synced 2025-01-09 13:43:22 +00:00
183 lines
5.3 KiB
Java
183 lines
5.3 KiB
Java
|
package com.google.common.math;
|
||
|
|
||
|
import com.google.common.base.Preconditions;
|
||
|
import com.google.common.primitives.Doubles;
|
||
|
import java.util.Iterator;
|
||
|
import tech.rabbit.r1launcher.BuildConfig;
|
||
|
|
||
|
@ElementTypesAreNonnullByDefault
|
||
|
/* loaded from: classes3.dex */
|
||
|
public final class StatsAccumulator {
|
||
|
private long count = 0;
|
||
|
private double mean = BuildConfig.SENTRY_SAMPLE_RATE;
|
||
|
private double sumOfSquaresOfDeltas = BuildConfig.SENTRY_SAMPLE_RATE;
|
||
|
private double min = Double.NaN;
|
||
|
private double max = Double.NaN;
|
||
|
|
||
|
public long count() {
|
||
|
return this.count;
|
||
|
}
|
||
|
|
||
|
public final double sum() {
|
||
|
return this.mean * this.count;
|
||
|
}
|
||
|
|
||
|
/* JADX INFO: Access modifiers changed from: package-private */
|
||
|
public double sumOfSquaresOfDeltas() {
|
||
|
return this.sumOfSquaresOfDeltas;
|
||
|
}
|
||
|
|
||
|
public void add(double d) {
|
||
|
long j = this.count;
|
||
|
if (j == 0) {
|
||
|
this.count = 1L;
|
||
|
this.mean = d;
|
||
|
this.min = d;
|
||
|
this.max = d;
|
||
|
if (Doubles.isFinite(d)) {
|
||
|
return;
|
||
|
}
|
||
|
this.sumOfSquaresOfDeltas = Double.NaN;
|
||
|
return;
|
||
|
}
|
||
|
this.count = j + 1;
|
||
|
if (Doubles.isFinite(d) && Doubles.isFinite(this.mean)) {
|
||
|
double d2 = this.mean;
|
||
|
double d3 = d - d2;
|
||
|
double d4 = d2 + (d3 / this.count);
|
||
|
this.mean = d4;
|
||
|
this.sumOfSquaresOfDeltas += d3 * (d - d4);
|
||
|
} else {
|
||
|
this.mean = calculateNewMeanNonFinite(this.mean, d);
|
||
|
this.sumOfSquaresOfDeltas = Double.NaN;
|
||
|
}
|
||
|
this.min = Math.min(this.min, d);
|
||
|
this.max = Math.max(this.max, d);
|
||
|
}
|
||
|
|
||
|
public void addAll(Iterable<? extends Number> iterable) {
|
||
|
Iterator<? extends Number> it = iterable.iterator();
|
||
|
while (it.hasNext()) {
|
||
|
add(it.next().doubleValue());
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public void addAll(Iterator<? extends Number> it) {
|
||
|
while (it.hasNext()) {
|
||
|
add(it.next().doubleValue());
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public void addAll(double... dArr) {
|
||
|
for (double d : dArr) {
|
||
|
add(d);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public void addAll(int... iArr) {
|
||
|
for (int i : iArr) {
|
||
|
add(i);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public void addAll(long... jArr) {
|
||
|
for (long j : jArr) {
|
||
|
add(j);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public void addAll(Stats stats) {
|
||
|
if (stats.count() == 0) {
|
||
|
return;
|
||
|
}
|
||
|
merge(stats.count(), stats.mean(), stats.sumOfSquaresOfDeltas(), stats.min(), stats.max());
|
||
|
}
|
||
|
|
||
|
public void addAll(StatsAccumulator statsAccumulator) {
|
||
|
if (statsAccumulator.count() == 0) {
|
||
|
return;
|
||
|
}
|
||
|
merge(statsAccumulator.count(), statsAccumulator.mean(), statsAccumulator.sumOfSquaresOfDeltas(), statsAccumulator.min(), statsAccumulator.max());
|
||
|
}
|
||
|
|
||
|
private void merge(long j, double d, double d2, double d3, double d4) {
|
||
|
long j2 = this.count;
|
||
|
if (j2 == 0) {
|
||
|
this.count = j;
|
||
|
this.mean = d;
|
||
|
this.sumOfSquaresOfDeltas = d2;
|
||
|
this.min = d3;
|
||
|
this.max = d4;
|
||
|
return;
|
||
|
}
|
||
|
this.count = j2 + j;
|
||
|
if (Doubles.isFinite(this.mean) && Doubles.isFinite(d)) {
|
||
|
double d5 = this.mean;
|
||
|
double d6 = d - d5;
|
||
|
double d7 = j;
|
||
|
double d8 = d5 + ((d6 * d7) / this.count);
|
||
|
this.mean = d8;
|
||
|
this.sumOfSquaresOfDeltas += d2 + (d6 * (d - d8) * d7);
|
||
|
} else {
|
||
|
this.mean = calculateNewMeanNonFinite(this.mean, d);
|
||
|
this.sumOfSquaresOfDeltas = Double.NaN;
|
||
|
}
|
||
|
this.min = Math.min(this.min, d3);
|
||
|
this.max = Math.max(this.max, d4);
|
||
|
}
|
||
|
|
||
|
public Stats snapshot() {
|
||
|
return new Stats(this.count, this.mean, this.sumOfSquaresOfDeltas, this.min, this.max);
|
||
|
}
|
||
|
|
||
|
public double mean() {
|
||
|
Preconditions.checkState(this.count != 0);
|
||
|
return this.mean;
|
||
|
}
|
||
|
|
||
|
public final double populationVariance() {
|
||
|
Preconditions.checkState(this.count != 0);
|
||
|
if (Double.isNaN(this.sumOfSquaresOfDeltas)) {
|
||
|
return Double.NaN;
|
||
|
}
|
||
|
return this.count == 1 ? BuildConfig.SENTRY_SAMPLE_RATE : DoubleUtils.ensureNonNegative(this.sumOfSquaresOfDeltas) / this.count;
|
||
|
}
|
||
|
|
||
|
public final double populationStandardDeviation() {
|
||
|
return Math.sqrt(populationVariance());
|
||
|
}
|
||
|
|
||
|
public final double sampleVariance() {
|
||
|
Preconditions.checkState(this.count > 1);
|
||
|
if (Double.isNaN(this.sumOfSquaresOfDeltas)) {
|
||
|
return Double.NaN;
|
||
|
}
|
||
|
return DoubleUtils.ensureNonNegative(this.sumOfSquaresOfDeltas) / (this.count - 1);
|
||
|
}
|
||
|
|
||
|
public final double sampleStandardDeviation() {
|
||
|
return Math.sqrt(sampleVariance());
|
||
|
}
|
||
|
|
||
|
public double min() {
|
||
|
Preconditions.checkState(this.count != 0);
|
||
|
return this.min;
|
||
|
}
|
||
|
|
||
|
public double max() {
|
||
|
Preconditions.checkState(this.count != 0);
|
||
|
return this.max;
|
||
|
}
|
||
|
|
||
|
/* JADX INFO: Access modifiers changed from: package-private */
|
||
|
public static double calculateNewMeanNonFinite(double d, double d2) {
|
||
|
if (Doubles.isFinite(d)) {
|
||
|
return d2;
|
||
|
}
|
||
|
if (Doubles.isFinite(d2) || d == d2) {
|
||
|
return d;
|
||
|
}
|
||
|
return Double.NaN;
|
||
|
}
|
||
|
}
|