package com.google.common.math; import androidx.compose.material3.MenuKt; import androidx.media3.exoplayer.upstream.CmcdHeadersFactory; import com.google.common.base.Preconditions; import com.google.common.primitives.Ints; import io.sentry.protocol.ViewHierarchyNode; import java.math.RoundingMode; @ElementTypesAreNonnullByDefault /* loaded from: classes3.dex */ public final class IntMath { static final int FLOOR_SQRT_MAX_INT = 46340; static final int MAX_POWER_OF_SQRT2_UNSIGNED = -1257966797; static final int MAX_SIGNED_POWER_OF_TWO = 1073741824; static final byte[] maxLog10ForLeadingZeros = {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, 0}; static final int[] powersOf10 = {1, 10, 100, 1000, 10000, 100000, 1000000, 10000000, 100000000, 1000000000}; static final int[] halfPowersOf10 = {3, 31, 316, 3162, 31622, 316227, 3162277, 31622776, 316227766, Integer.MAX_VALUE}; private static final int[] factorials = {1, 1, 2, 6, 24, MenuKt.InTransitionDuration, 720, 5040, 40320, 362880, 3628800, 39916800, 479001600}; static int[] biggestBinomials = {Integer.MAX_VALUE, Integer.MAX_VALUE, 65536, 2345, 477, 193, 110, 75, 58, 49, 43, 39, 37, 35, 34, 34, 33}; public static boolean isPowerOfTwo(int i) { return (i > 0) & ((i & (i + (-1))) == 0); } static int lessThanBranchFree(int i, int i2) { return (~(~(i - i2))) >>> 31; } public static int mean(int i, int i2) { return (i & i2) + ((i ^ i2) >> 1); } public static int ceilingPowerOfTwo(int i) { MathPreconditions.checkPositive(ViewHierarchyNode.JsonKeys.X, i); if (i > 1073741824) { throw new ArithmeticException(new StringBuilder(58).append("ceilingPowerOfTwo(").append(i).append(") not representable as an int").toString()); } return 1 << (-Integer.numberOfLeadingZeros(i - 1)); } public static int floorPowerOfTwo(int i) { MathPreconditions.checkPositive(ViewHierarchyNode.JsonKeys.X, i); return Integer.highestOneBit(i); } /* JADX INFO: Access modifiers changed from: package-private */ /* renamed from: com.google.common.math.IntMath$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(int i, RoundingMode roundingMode) { MathPreconditions.checkPositive(ViewHierarchyNode.JsonKeys.X, i); switch (AnonymousClass1.$SwitchMap$java$math$RoundingMode[roundingMode.ordinal()]) { case 1: MathPreconditions.checkRoundingUnnecessary(isPowerOfTwo(i)); break; case 2: case 3: break; case 4: case 5: return 32 - Integer.numberOfLeadingZeros(i - 1); case 6: case 7: case 8: int numberOfLeadingZeros = Integer.numberOfLeadingZeros(i); return (31 - numberOfLeadingZeros) + lessThanBranchFree(MAX_POWER_OF_SQRT2_UNSIGNED >>> numberOfLeadingZeros, i); default: throw new AssertionError(); } return 31 - Integer.numberOfLeadingZeros(i); } /* JADX WARN: Failed to find 'out' block for switch in B:2:0x0015. Please report as an issue. */ public static int log10(int i, RoundingMode roundingMode) { int lessThanBranchFree; MathPreconditions.checkPositive(ViewHierarchyNode.JsonKeys.X, i); int log10Floor = log10Floor(i); int i2 = powersOf10[log10Floor]; switch (AnonymousClass1.$SwitchMap$java$math$RoundingMode[roundingMode.ordinal()]) { case 1: MathPreconditions.checkRoundingUnnecessary(i == i2); case 2: case 3: return log10Floor; case 4: case 5: lessThanBranchFree = lessThanBranchFree(i2, i); return log10Floor + lessThanBranchFree; case 6: case 7: case 8: lessThanBranchFree = lessThanBranchFree(halfPowersOf10[log10Floor], i); return log10Floor + lessThanBranchFree; default: throw new AssertionError(); } } private static int log10Floor(int i) { byte b = maxLog10ForLeadingZeros[Integer.numberOfLeadingZeros(i)]; return b - lessThanBranchFree(i, powersOf10[b]); } public static int pow(int i, int i2) { MathPreconditions.checkNonNegative("exponent", i2); if (i == -2) { if (i2 < 32) { return (i2 & 1) == 0 ? 1 << i2 : -(1 << i2); } return 0; } if (i == -1) { return (i2 & 1) == 0 ? 1 : -1; } if (i == 0) { return i2 == 0 ? 1 : 0; } if (i == 1) { return 1; } if (i == 2) { if (i2 < 32) { return 1 << i2; } return 0; } int i3 = 1; while (i2 != 0) { if (i2 == 1) { return i * i3; } i3 *= (i2 & 1) == 0 ? 1 : i; i *= i; i2 >>= 1; } return i3; } /* JADX WARN: Failed to find 'out' block for switch in B:2:0x0011. Please report as an issue. */ public static int sqrt(int i, RoundingMode roundingMode) { int lessThanBranchFree; MathPreconditions.checkNonNegative(ViewHierarchyNode.JsonKeys.X, i); int sqrtFloor = sqrtFloor(i); switch (AnonymousClass1.$SwitchMap$java$math$RoundingMode[roundingMode.ordinal()]) { case 1: MathPreconditions.checkRoundingUnnecessary(sqrtFloor * sqrtFloor == i); case 2: case 3: return sqrtFloor; case 4: case 5: lessThanBranchFree = lessThanBranchFree(sqrtFloor * sqrtFloor, i); return sqrtFloor + lessThanBranchFree; case 6: case 7: case 8: lessThanBranchFree = lessThanBranchFree((sqrtFloor * sqrtFloor) + sqrtFloor, i); return sqrtFloor + lessThanBranchFree; default: throw new AssertionError(); } } private static int sqrtFloor(int i) { return (int) Math.sqrt(i); } public static int divide(int i, int i2, RoundingMode roundingMode) { Preconditions.checkNotNull(roundingMode); if (i2 == 0) { throw new ArithmeticException("/ by zero"); } int i3 = i / i2; int i4 = i - (i2 * i3); if (i4 == 0) { return i3; } int i5 = ((i ^ i2) >> 31) | 1; switch (AnonymousClass1.$SwitchMap$java$math$RoundingMode[roundingMode.ordinal()]) { case 1: MathPreconditions.checkRoundingUnnecessary(i4 == 0); return i3; case 2: return i3; case 3: if (i5 >= 0) { return i3; } break; case 4: break; case 5: if (i5 <= 0) { return i3; } break; case 6: case 7: case 8: int abs = Math.abs(i4); int abs2 = abs - (Math.abs(i2) - abs); if (abs2 == 0) { if (roundingMode != RoundingMode.HALF_UP) { if (!((roundingMode == RoundingMode.HALF_EVEN) & ((i3 & 1) != 0))) { return i3; } } } else if (abs2 <= 0) { return i3; } break; default: throw new AssertionError(); } return i3 + i5; } public static int mod(int i, int i2) { if (i2 <= 0) { throw new ArithmeticException(new StringBuilder(31).append("Modulus ").append(i2).append(" must be > 0").toString()); } int i3 = i % i2; return i3 >= 0 ? i3 : i3 + i2; } public static int gcd(int i, int i2) { MathPreconditions.checkNonNegative(CmcdHeadersFactory.OBJECT_TYPE_AUDIO_ONLY, i); MathPreconditions.checkNonNegative("b", i2); if (i == 0) { return i2; } if (i2 == 0) { return i; } int numberOfTrailingZeros = Integer.numberOfTrailingZeros(i); int i3 = i >> numberOfTrailingZeros; int numberOfTrailingZeros2 = Integer.numberOfTrailingZeros(i2); int i4 = i2 >> numberOfTrailingZeros2; while (i3 != i4) { int i5 = i3 - i4; int i6 = (i5 >> 31) & i5; int i7 = (i5 - i6) - i6; i4 += i6; i3 = i7 >> Integer.numberOfTrailingZeros(i7); } return i3 << Math.min(numberOfTrailingZeros, numberOfTrailingZeros2); } public static int checkedAdd(int i, int i2) { long j = i + i2; int i3 = (int) j; MathPreconditions.checkNoOverflow(j == ((long) i3), "checkedAdd", i, i2); return i3; } public static int checkedSubtract(int i, int i2) { long j = i - i2; int i3 = (int) j; MathPreconditions.checkNoOverflow(j == ((long) i3), "checkedSubtract", i, i2); return i3; } public static int checkedMultiply(int i, int i2) { long j = i * i2; int i3 = (int) j; MathPreconditions.checkNoOverflow(j == ((long) i3), "checkedMultiply", i, i2); return i3; } public static int checkedPow(int i, int i2) { MathPreconditions.checkNonNegative("exponent", i2); if (i == -2) { MathPreconditions.checkNoOverflow(i2 < 32, "checkedPow", i, i2); return (i2 & 1) == 0 ? 1 << i2 : (-1) << i2; } if (i == -1) { return (i2 & 1) == 0 ? 1 : -1; } if (i == 0) { return i2 == 0 ? 1 : 0; } if (i == 1) { return 1; } if (i == 2) { MathPreconditions.checkNoOverflow(i2 < 31, "checkedPow", i, i2); return 1 << i2; } int i3 = 1; while (i2 != 0) { if (i2 == 1) { return checkedMultiply(i3, i); } if ((i2 & 1) != 0) { i3 = checkedMultiply(i3, i); } i2 >>= 1; if (i2 > 0) { MathPreconditions.checkNoOverflow((-46340 <= i) & (i <= FLOOR_SQRT_MAX_INT), "checkedPow", i, i2); i *= i; } } return i3; } public static int saturatedAdd(int i, int i2) { return Ints.saturatedCast(i + i2); } public static int saturatedSubtract(int i, int i2) { return Ints.saturatedCast(i - i2); } public static int saturatedMultiply(int i, int i2) { return Ints.saturatedCast(i * i2); } public static int saturatedPow(int i, int i2) { MathPreconditions.checkNonNegative("exponent", i2); if (i == -2) { return i2 >= 32 ? (i2 & 1) + Integer.MAX_VALUE : (i2 & 1) == 0 ? 1 << i2 : (-1) << i2; } if (i == -1) { return (i2 & 1) == 0 ? 1 : -1; } if (i == 0) { return i2 == 0 ? 1 : 0; } if (i == 1) { return 1; } if (i == 2) { if (i2 >= 31) { return Integer.MAX_VALUE; } return 1 << i2; } int i3 = ((i >>> 31) & i2 & 1) + Integer.MAX_VALUE; int i4 = 1; while (i2 != 0) { if (i2 == 1) { return saturatedMultiply(i4, i); } if ((i2 & 1) != 0) { i4 = saturatedMultiply(i4, i); } i2 >>= 1; if (i2 > 0) { if ((-46340 > i) || (i > FLOOR_SQRT_MAX_INT)) { return i3; } i *= i; } } return i4; } public static int factorial(int i) { MathPreconditions.checkNonNegative("n", i); int[] iArr = factorials; if (i < iArr.length) { return iArr[i]; } return Integer.MAX_VALUE; } public static int binomial(int i, int i2) { MathPreconditions.checkNonNegative("n", i); MathPreconditions.checkNonNegative("k", i2); int i3 = 0; Preconditions.checkArgument(i2 <= i, "k (%s) > n (%s)", i2, i); if (i2 > (i >> 1)) { i2 = i - i2; } int[] iArr = biggestBinomials; if (i2 >= iArr.length || i > iArr[i2]) { return Integer.MAX_VALUE; } if (i2 == 0) { return 1; } if (i2 == 1) { return i; } long j = 1; while (i3 < i2) { long j2 = j * (i - i3); i3++; j = j2 / i3; } return (int) j; } public static boolean isPrime(int i) { return LongMath.isPrime(i); } private IntMath() { } }