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; } }