package com.google.common.math; import androidx.compose.runtime.ComposerKt; import androidx.media3.exoplayer.upstream.CmcdHeadersFactory; import androidx.work.WorkRequest; import com.google.common.base.Ascii; import com.google.common.base.Preconditions; import com.google.common.primitives.Longs; import com.google.common.primitives.UnsignedLongs; import io.flutter.embedding.android.KeyboardMap; import io.sentry.protocol.ViewHierarchyNode; import java.math.RoundingMode; import okhttp3.internal.connection.RealConnection; @ElementTypesAreNonnullByDefault /* loaded from: classes3.dex */ public final class LongMath { static final long FLOOR_SQRT_MAX_LONG = 3037000499L; static final long MAX_POWER_OF_SQRT2_UNSIGNED = -5402926248376769404L; static final long MAX_SIGNED_POWER_OF_TWO = 4611686018427387904L; private static final int SIEVE_30 = -545925251; static final byte[] maxLog10ForLeadingZeros = {19, Ascii.DC2, Ascii.DC2, Ascii.DC2, Ascii.DC2, 17, 17, 17, Ascii.DLE, Ascii.DLE, Ascii.DLE, Ascii.SI, Ascii.SI, Ascii.SI, Ascii.SI, Ascii.SO, Ascii.SO, Ascii.SO, Ascii.CR, Ascii.CR, Ascii.CR, Ascii.FF, Ascii.FF, Ascii.FF, Ascii.FF, Ascii.VT, Ascii.VT, Ascii.VT, 10, 10, 10, 9, 9, 9, 9, 8, 8, 8, 7, 7, 7, 6, 6, 6, 6, 5, 5, 5, 4, 4, 4, 3, 3, 3, 3, 2, 2, 2, 1, 1, 1, 0, 0, 0}; static final long[] powersOf10 = {1, 10, 100, 1000, WorkRequest.MIN_BACKOFF_MILLIS, 100000, 1000000, 10000000, 100000000, 1000000000, RealConnection.IDLE_CONNECTION_HEALTHY_NS, 100000000000L, 1000000000000L, 10000000000000L, 100000000000000L, 1000000000000000L, 10000000000000000L, 100000000000000000L, 1000000000000000000L}; static final long[] halfPowersOf10 = {3, 31, 316, 3162, 31622, 316227, 3162277, 31622776, 316227766, 3162277660L, 31622776601L, 316227766016L, 3162277660168L, 31622776601683L, 316227766016837L, 3162277660168379L, 31622776601683793L, 316227766016837933L, 3162277660168379331L}; static final long[] factorials = {1, 1, 2, 6, 24, 120, 720, 5040, 40320, 362880, 3628800, 39916800, 479001600, 6227020800L, 87178291200L, 1307674368000L, 20922789888000L, 355687428096000L, 6402373705728000L, 121645100408832000L, 2432902008176640000L}; static final int[] biggestBinomials = {Integer.MAX_VALUE, Integer.MAX_VALUE, Integer.MAX_VALUE, 3810779, 121977, 16175, 4337, 1733, 887, 534, 361, 265, ComposerKt.referenceKey, 169, 143, 125, 111, 101, 94, 88, 83, 79, 76, 74, 72, 70, 69, 68, 67, 67, 66, 66, 66, 66}; static final int[] biggestSimpleBinomials = {Integer.MAX_VALUE, Integer.MAX_VALUE, Integer.MAX_VALUE, 2642246, 86251, 11724, 3218, 1313, 684, 419, 287, 214, 169, 139, 119, 105, 95, 87, 81, 76, 73, 70, 68, 66, 64, 63, 62, 62, 61, 61, 61}; private static final long[][] millerRabinBaseSets = {new long[]{291830, 126401071349994536L}, new long[]{885594168, 725270293939359937L, 3569819667048198375L}, new long[]{273919523040L, 15, 7363882082L, 992620450144556L}, new long[]{47636622961200L, 2, 2570940, 211991001, 3749873356L}, new long[]{7999252175582850L, 2, 4130806001517L, 149795463772692060L, 186635894390467037L, 3967304179347715805L}, new long[]{585226005592931976L, 2, 123635709730000L, 9233062284813009L, 43835965440333360L, 761179012939631437L, 1263739024124850375L}, new long[]{Long.MAX_VALUE, 2, 325, 9375, 28178, 450775, 9780504, 1795265022}}; static boolean fitsInInt(long j) { return ((long) ((int) j)) == j; } public static boolean isPowerOfTwo(long j) { return (j > 0) & ((j & (j - 1)) == 0); } static int lessThanBranchFree(long j, long j2) { return (int) ((~(~(j - j2))) >>> 63); } public static long mean(long j, long j2) { return (j & j2) + ((j ^ j2) >> 1); } public static long saturatedAdd(long j, long j2) { long j3 = j + j2; return (((j2 ^ j) > 0L ? 1 : ((j2 ^ j) == 0L ? 0 : -1)) < 0) | ((j ^ j3) >= 0) ? j3 : ((j3 >>> 63) ^ 1) + Long.MAX_VALUE; } public static long saturatedSubtract(long j, long j2) { long j3 = j - j2; return (((j2 ^ j) > 0L ? 1 : ((j2 ^ j) == 0L ? 0 : -1)) >= 0) | ((j ^ j3) >= 0) ? j3 : ((j3 >>> 63) ^ 1) + Long.MAX_VALUE; } public static long ceilingPowerOfTwo(long j) { MathPreconditions.checkPositive(ViewHierarchyNode.JsonKeys.X, j); if (j > 4611686018427387904L) { throw new ArithmeticException(new StringBuilder(70).append("ceilingPowerOfTwo(").append(j).append(") is not representable as a long").toString()); } return 1 << (-Long.numberOfLeadingZeros(j - 1)); } public static long floorPowerOfTwo(long j) { MathPreconditions.checkPositive(ViewHierarchyNode.JsonKeys.X, j); return 1 << (63 - Long.numberOfLeadingZeros(j)); } /* JADX INFO: Access modifiers changed from: package-private */ /* renamed from: com.google.common.math.LongMath$1, reason: invalid class name */ /* loaded from: classes3.dex */ public static /* synthetic */ class AnonymousClass1 { static final /* synthetic */ int[] $SwitchMap$java$math$RoundingMode; static { int[] iArr = new int[RoundingMode.values().length]; $SwitchMap$java$math$RoundingMode = iArr; try { iArr[RoundingMode.UNNECESSARY.ordinal()] = 1; } catch (NoSuchFieldError unused) { } try { $SwitchMap$java$math$RoundingMode[RoundingMode.DOWN.ordinal()] = 2; } catch (NoSuchFieldError unused2) { } try { $SwitchMap$java$math$RoundingMode[RoundingMode.FLOOR.ordinal()] = 3; } catch (NoSuchFieldError unused3) { } try { $SwitchMap$java$math$RoundingMode[RoundingMode.UP.ordinal()] = 4; } catch (NoSuchFieldError unused4) { } try { $SwitchMap$java$math$RoundingMode[RoundingMode.CEILING.ordinal()] = 5; } catch (NoSuchFieldError unused5) { } try { $SwitchMap$java$math$RoundingMode[RoundingMode.HALF_DOWN.ordinal()] = 6; } catch (NoSuchFieldError unused6) { } try { $SwitchMap$java$math$RoundingMode[RoundingMode.HALF_UP.ordinal()] = 7; } catch (NoSuchFieldError unused7) { } try { $SwitchMap$java$math$RoundingMode[RoundingMode.HALF_EVEN.ordinal()] = 8; } catch (NoSuchFieldError unused8) { } } } public static int log2(long j, RoundingMode roundingMode) { MathPreconditions.checkPositive(ViewHierarchyNode.JsonKeys.X, j); switch (AnonymousClass1.$SwitchMap$java$math$RoundingMode[roundingMode.ordinal()]) { case 1: MathPreconditions.checkRoundingUnnecessary(isPowerOfTwo(j)); break; case 2: case 3: break; case 4: case 5: return 64 - Long.numberOfLeadingZeros(j - 1); case 6: case 7: case 8: int numberOfLeadingZeros = Long.numberOfLeadingZeros(j); return (63 - numberOfLeadingZeros) + lessThanBranchFree(MAX_POWER_OF_SQRT2_UNSIGNED >>> numberOfLeadingZeros, j); default: throw new AssertionError("impossible"); } return 63 - Long.numberOfLeadingZeros(j); } /* JADX WARN: Failed to find 'out' block for switch in B:2:0x0015. Please report as an issue. */ public static int log10(long j, RoundingMode roundingMode) { int lessThanBranchFree; MathPreconditions.checkPositive(ViewHierarchyNode.JsonKeys.X, j); int log10Floor = log10Floor(j); long j2 = powersOf10[log10Floor]; switch (AnonymousClass1.$SwitchMap$java$math$RoundingMode[roundingMode.ordinal()]) { case 1: MathPreconditions.checkRoundingUnnecessary(j == j2); case 2: case 3: return log10Floor; case 4: case 5: lessThanBranchFree = lessThanBranchFree(j2, j); return log10Floor + lessThanBranchFree; case 6: case 7: case 8: lessThanBranchFree = lessThanBranchFree(halfPowersOf10[log10Floor], j); return log10Floor + lessThanBranchFree; default: throw new AssertionError(); } } static int log10Floor(long j) { byte b = maxLog10ForLeadingZeros[Long.numberOfLeadingZeros(j)]; return b - lessThanBranchFree(j, powersOf10[b]); } public static long pow(long j, int i) { MathPreconditions.checkNonNegative("exponent", i); if (-2 > j || j > 2) { long j2 = 1; while (i != 0) { if (i == 1) { return j2 * j; } j2 *= (i & 1) == 0 ? 1L : j; j *= j; i >>= 1; } return j2; } int i2 = (int) j; if (i2 == -2) { if (i < 64) { return (i & 1) == 0 ? 1 << i : -(1 << i); } return 0L; } if (i2 == -1) { return (i & 1) == 0 ? 1L : -1L; } if (i2 == 0) { return i == 0 ? 1L : 0L; } if (i2 == 1) { return 1L; } if (i2 != 2) { throw new AssertionError(); } if (i < 64) { return 1 << i; } return 0L; } public static long sqrt(long j, RoundingMode roundingMode) { MathPreconditions.checkNonNegative(ViewHierarchyNode.JsonKeys.X, j); if (fitsInInt(j)) { return IntMath.sqrt((int) j, roundingMode); } long sqrt = (long) Math.sqrt(j); long j2 = sqrt * sqrt; switch (AnonymousClass1.$SwitchMap$java$math$RoundingMode[roundingMode.ordinal()]) { case 1: MathPreconditions.checkRoundingUnnecessary(j2 == j); return sqrt; case 2: case 3: return j < j2 ? sqrt - 1 : sqrt; case 4: case 5: return j > j2 ? sqrt + 1 : sqrt; case 6: case 7: case 8: return (sqrt - (j >= j2 ? 0 : 1)) + lessThanBranchFree((r0 * r0) + r0, j); default: throw new AssertionError(); } } public static long divide(long j, long j2, RoundingMode roundingMode) { Preconditions.checkNotNull(roundingMode); long j3 = j / j2; long j4 = j - (j2 * j3); if (j4 == 0) { return j3; } int i = ((int) ((j ^ j2) >> 63)) | 1; switch (AnonymousClass1.$SwitchMap$java$math$RoundingMode[roundingMode.ordinal()]) { case 1: MathPreconditions.checkRoundingUnnecessary(j4 == 0); return j3; case 2: return j3; case 3: if (i >= 0) { return j3; } break; case 4: break; case 5: if (i <= 0) { return j3; } break; case 6: case 7: case 8: long abs = Math.abs(j4); long abs2 = abs - (Math.abs(j2) - abs); if (abs2 == 0) { if (roundingMode != RoundingMode.HALF_UP && (roundingMode != RoundingMode.HALF_EVEN || (1 & j3) == 0)) { return j3; } } else if (abs2 <= 0) { return j3; } break; default: throw new AssertionError(); } return j3 + i; } public static int mod(long j, int i) { return (int) mod(j, i); } public static long mod(long j, long j2) { if (j2 <= 0) { throw new ArithmeticException("Modulus must be positive"); } long j3 = j % j2; return j3 >= 0 ? j3 : j3 + j2; } public static long gcd(long j, long j2) { MathPreconditions.checkNonNegative(CmcdHeadersFactory.OBJECT_TYPE_AUDIO_ONLY, j); MathPreconditions.checkNonNegative("b", j2); if (j == 0) { return j2; } if (j2 == 0) { return j; } int numberOfTrailingZeros = Long.numberOfTrailingZeros(j); long j3 = j >> numberOfTrailingZeros; int numberOfTrailingZeros2 = Long.numberOfTrailingZeros(j2); long j4 = j2 >> numberOfTrailingZeros2; while (j3 != j4) { long j5 = j3 - j4; long j6 = (j5 >> 63) & j5; long j7 = (j5 - j6) - j6; j4 += j6; j3 = j7 >> Long.numberOfTrailingZeros(j7); } return j3 << Math.min(numberOfTrailingZeros, numberOfTrailingZeros2); } public static long checkedAdd(long j, long j2) { long j3 = j + j2; MathPreconditions.checkNoOverflow(((j ^ j2) < 0) | ((j ^ j3) >= 0), "checkedAdd", j, j2); return j3; } public static long checkedSubtract(long j, long j2) { long j3 = j - j2; MathPreconditions.checkNoOverflow(((j ^ j2) >= 0) | ((j ^ j3) >= 0), "checkedSubtract", j, j2); return j3; } public static long checkedMultiply(long j, long j2) { int numberOfLeadingZeros = Long.numberOfLeadingZeros(j) + Long.numberOfLeadingZeros(~j) + Long.numberOfLeadingZeros(j2) + Long.numberOfLeadingZeros(~j2); if (numberOfLeadingZeros > 65) { return j * j2; } MathPreconditions.checkNoOverflow(numberOfLeadingZeros >= 64, "checkedMultiply", j, j2); MathPreconditions.checkNoOverflow((j >= 0) | (j2 != Long.MIN_VALUE), "checkedMultiply", j, j2); long j3 = j * j2; MathPreconditions.checkNoOverflow(j == 0 || j3 / j == j2, "checkedMultiply", j, j2); return j3; } public static long checkedPow(long j, int i) { MathPreconditions.checkNonNegative("exponent", i); long j2 = 1; if ((j >= -2) && (j <= 2)) { int i2 = (int) j; if (i2 == -2) { MathPreconditions.checkNoOverflow(i < 64, "checkedPow", j, i); return (i & 1) == 0 ? 1 << i : (-1) << i; } if (i2 == -1) { return (i & 1) == 0 ? 1L : -1L; } if (i2 == 0) { return i == 0 ? 1L : 0L; } if (i2 == 1) { return 1L; } if (i2 == 2) { MathPreconditions.checkNoOverflow(i < 63, "checkedPow", j, i); return 1 << i; } throw new AssertionError(); } long j3 = j; int i3 = i; while (i3 != 0) { if (i3 == 1) { return checkedMultiply(j2, j3); } if ((i3 & 1) != 0) { j2 = checkedMultiply(j2, j3); } long j4 = j2; int i4 = i3 >> 1; if (i4 > 0) { MathPreconditions.checkNoOverflow(-3037000499L <= j3 && j3 <= FLOOR_SQRT_MAX_LONG, "checkedPow", j3, i4); j3 *= j3; } i3 = i4; j2 = j4; } return j2; } public static long saturatedMultiply(long j, long j2) { int numberOfLeadingZeros = Long.numberOfLeadingZeros(j) + Long.numberOfLeadingZeros(~j) + Long.numberOfLeadingZeros(j2) + Long.numberOfLeadingZeros(~j2); if (numberOfLeadingZeros > 65) { return j * j2; } long j3 = ((j ^ j2) >>> 63) + Long.MAX_VALUE; if ((numberOfLeadingZeros < 64) || ((j2 == Long.MIN_VALUE) & (j < 0))) { return j3; } long j4 = j * j2; return (j == 0 || j4 / j == j2) ? j4 : j3; } public static long saturatedPow(long j, int i) { MathPreconditions.checkNonNegative("exponent", i); long j2 = 1; if (!(j >= -2) || !(j <= 2)) { long j3 = ((j >>> 63) & i & 1) + Long.MAX_VALUE; while (i != 0) { if (i == 1) { return saturatedMultiply(j2, j); } if ((i & 1) != 0) { j2 = saturatedMultiply(j2, j); } i >>= 1; if (i > 0) { if ((-3037000499L > j) || (j > FLOOR_SQRT_MAX_LONG)) { return j3; } j *= j; } } return j2; } int i2 = (int) j; if (i2 == -2) { return i >= 64 ? (i & 1) + Long.MAX_VALUE : (i & 1) == 0 ? 1 << i : (-1) << i; } if (i2 == -1) { return (i & 1) == 0 ? 1L : -1L; } if (i2 == 0) { return i == 0 ? 1L : 0L; } if (i2 == 1) { return 1L; } if (i2 != 2) { throw new AssertionError(); } if (i >= 63) { return Long.MAX_VALUE; } return 1 << i; } public static long factorial(int i) { MathPreconditions.checkNonNegative("n", i); long[] jArr = factorials; if (i < jArr.length) { return jArr[i]; } return Long.MAX_VALUE; } public static long binomial(int i, int i2) { MathPreconditions.checkNonNegative("n", i); MathPreconditions.checkNonNegative("k", i2); Preconditions.checkArgument(i2 <= i, "k (%s) > n (%s)", i2, i); if (i2 > (i >> 1)) { i2 = i - i2; } long j = 1; if (i2 == 0) { return 1L; } if (i2 == 1) { return i; } long[] jArr = factorials; if (i < jArr.length) { return jArr[i] / (jArr[i2] * jArr[i - i2]); } int[] iArr = biggestBinomials; if (i2 >= iArr.length || i > iArr[i2]) { return Long.MAX_VALUE; } int[] iArr2 = biggestSimpleBinomials; if (i2 < iArr2.length && i <= iArr2[i2]) { int i3 = i - 1; long j2 = i; for (int i4 = 2; i4 <= i2; i4++) { j2 = (j2 * i3) / i4; i3--; } return j2; } long j3 = i; int log2 = log2(j3, RoundingMode.CEILING); int i5 = i - 1; int i6 = log2; int i7 = 2; long j4 = j3; long j5 = 1; while (i7 <= i2) { i6 += log2; if (i6 < 63) { j4 *= i5; j5 *= i7; } else { j = multiplyFraction(j, j4, j5); j4 = i5; j5 = i7; i6 = log2; } i7++; i5--; } return multiplyFraction(j, j4, j5); } static long multiplyFraction(long j, long j2, long j3) { if (j == 1) { return j2 / j3; } long gcd = gcd(j, j3); return (j / gcd) * (j2 / (j3 / gcd)); } public static boolean isPrime(long j) { if (j < 2) { MathPreconditions.checkNonNegative("n", j); return false; } if (j < 66) { return ((722865708377213483 >> (((int) j) + (-2))) & 1) != 0; } if (((1 << ((int) (j % 30))) & SIEVE_30) != 0 || j % 7 == 0 || j % 11 == 0 || j % 13 == 0) { return false; } if (j < 289) { return true; } for (long[] jArr : millerRabinBaseSets) { if (j <= jArr[0]) { for (int i = 1; i < jArr.length; i++) { if (!MillerRabinTester.test(jArr[i], j)) { return false; } } return true; } } throw new AssertionError(); } /* loaded from: classes3.dex */ private enum MillerRabinTester { SMALL { // from class: com.google.common.math.LongMath.MillerRabinTester.1 @Override // com.google.common.math.LongMath.MillerRabinTester long mulMod(long j, long j2, long j3) { return (j * j2) % j3; } @Override // com.google.common.math.LongMath.MillerRabinTester long squareMod(long j, long j2) { return (j * j) % j2; } }, LARGE { // from class: com.google.common.math.LongMath.MillerRabinTester.2 private long plusMod(long j, long j2, long j3) { long j4 = j + j2; return j >= j3 - j2 ? j4 - j3 : j4; } private long times2ToThe32Mod(long j, long j2) { int i = 32; do { int min = Math.min(i, Long.numberOfLeadingZeros(j)); j = UnsignedLongs.remainder(j << min, j2); i -= min; } while (i > 0); return j; } @Override // com.google.common.math.LongMath.MillerRabinTester long mulMod(long j, long j2, long j3) { long j4 = j >>> 32; long j5 = j2 >>> 32; long j6 = j & KeyboardMap.kValueMask; long j7 = j2 & KeyboardMap.kValueMask; long times2ToThe32Mod = times2ToThe32Mod(j4 * j5, j3) + (j4 * j7); if (times2ToThe32Mod < 0) { times2ToThe32Mod = UnsignedLongs.remainder(times2ToThe32Mod, j3); } return plusMod(times2ToThe32Mod(times2ToThe32Mod + (j5 * j6), j3), UnsignedLongs.remainder(j6 * j7, j3), j3); } @Override // com.google.common.math.LongMath.MillerRabinTester long squareMod(long j, long j2) { long j3 = j >>> 32; long j4 = j & KeyboardMap.kValueMask; long times2ToThe32Mod = times2ToThe32Mod(j3 * j3, j2); long j5 = j3 * j4 * 2; if (j5 < 0) { j5 = UnsignedLongs.remainder(j5, j2); } return plusMod(times2ToThe32Mod(times2ToThe32Mod + j5, j2), UnsignedLongs.remainder(j4 * j4, j2), j2); } }; abstract long mulMod(long j, long j2, long j3); abstract long squareMod(long j, long j2); /* synthetic */ MillerRabinTester(AnonymousClass1 anonymousClass1) { this(); } static boolean test(long j, long j2) { return (j2 <= LongMath.FLOOR_SQRT_MAX_LONG ? SMALL : LARGE).testWitness(j, j2); } private long powMod(long j, long j2, long j3) { long j4 = 1; while (j2 != 0) { if ((j2 & 1) != 0) { j4 = mulMod(j4, j, j3); } j = squareMod(j, j3); j2 >>= 1; } return j4; } private boolean testWitness(long j, long j2) { long j3 = j2 - 1; int numberOfTrailingZeros = Long.numberOfTrailingZeros(j3); long j4 = j3 >> numberOfTrailingZeros; long j5 = j % j2; if (j5 == 0) { return true; } long powMod = powMod(j5, j4, j2); if (powMod == 1) { return true; } int i = 0; while (powMod != j3) { i++; if (i == numberOfTrailingZeros) { return false; } powMod = squareMod(powMod, j2); } return true; } } public static double roundToDouble(long j, RoundingMode roundingMode) { long j2; double d; double d2 = j; long j3 = (long) d2; int compare = j3 == Long.MAX_VALUE ? -1 : Longs.compare(j, j3); switch (AnonymousClass1.$SwitchMap$java$math$RoundingMode[roundingMode.ordinal()]) { case 1: MathPreconditions.checkRoundingUnnecessary(compare == 0); return d2; case 2: return j >= 0 ? compare >= 0 ? d2 : DoubleUtils.nextDown(d2) : compare <= 0 ? d2 : Math.nextUp(d2); case 3: return compare >= 0 ? d2 : DoubleUtils.nextDown(d2); case 4: return j >= 0 ? compare <= 0 ? d2 : Math.nextUp(d2) : compare >= 0 ? d2 : DoubleUtils.nextDown(d2); case 5: return compare <= 0 ? d2 : Math.nextUp(d2); case 6: case 7: case 8: if (compare >= 0) { d = Math.nextUp(d2); j2 = (long) Math.ceil(d); } else { double nextDown = DoubleUtils.nextDown(d2); j3 = (long) Math.floor(nextDown); j2 = j3; d2 = nextDown; d = d2; } long j4 = j - j3; long j5 = j2 - j; if (j2 == Long.MAX_VALUE) { j5++; } int compare2 = Longs.compare(j4, j5); if (compare2 < 0) { return d2; } if (compare2 > 0) { return d; } int i = AnonymousClass1.$SwitchMap$java$math$RoundingMode[roundingMode.ordinal()]; if (i == 6) { return j >= 0 ? d2 : d; } if (i == 7) { return j >= 0 ? d : d2; } if (i == 8) { return (DoubleUtils.getSignificand(d2) & 1) == 0 ? d2 : d; } throw new AssertionError("impossible"); default: throw new AssertionError("impossible"); } } private LongMath() { } }