Rabbit-R1/switch port/java/sources/com/google/common/math/BigIntegerMath.java
2024-05-21 17:08:36 -04:00

403 lines
15 KiB
Java

package com.google.common.math;
import com.google.common.base.Preconditions;
import io.sentry.protocol.ViewHierarchyNode;
import java.math.BigDecimal;
import java.math.BigInteger;
import java.math.RoundingMode;
import java.util.ArrayList;
import java.util.List;
@ElementTypesAreNonnullByDefault
/* loaded from: classes3.dex */
public final class BigIntegerMath {
static final int SQRT2_PRECOMPUTE_THRESHOLD = 256;
static final BigInteger SQRT2_PRECOMPUTED_BITS = new BigInteger("16a09e667f3bcc908b2fb1366ea957d3e3adec17512775099da2f590b0667322a", 16);
private static final double LN_10 = Math.log(10.0d);
private static final double LN_2 = Math.log(2.0d);
public static BigInteger ceilingPowerOfTwo(BigInteger bigInteger) {
return BigInteger.ZERO.setBit(log2(bigInteger, RoundingMode.CEILING));
}
public static BigInteger floorPowerOfTwo(BigInteger bigInteger) {
return BigInteger.ZERO.setBit(log2(bigInteger, RoundingMode.FLOOR));
}
public static boolean isPowerOfTwo(BigInteger bigInteger) {
Preconditions.checkNotNull(bigInteger);
return bigInteger.signum() > 0 && bigInteger.getLowestSetBit() == bigInteger.bitLength() - 1;
}
public static int log2(BigInteger bigInteger, RoundingMode roundingMode) {
MathPreconditions.checkPositive(ViewHierarchyNode.JsonKeys.X, (BigInteger) Preconditions.checkNotNull(bigInteger));
int bitLength = bigInteger.bitLength();
int i = bitLength - 1;
switch (AnonymousClass1.$SwitchMap$java$math$RoundingMode[roundingMode.ordinal()]) {
case 1:
MathPreconditions.checkRoundingUnnecessary(isPowerOfTwo(bigInteger));
case 2:
case 3:
return i;
case 4:
case 5:
return isPowerOfTwo(bigInteger) ? i : bitLength;
case 6:
case 7:
case 8:
return i < 256 ? bigInteger.compareTo(SQRT2_PRECOMPUTED_BITS.shiftRight(256 - i)) <= 0 ? i : bitLength : bigInteger.pow(2).bitLength() + (-1) < (i * 2) + 1 ? i : bitLength;
default:
throw new AssertionError();
}
}
/* JADX INFO: Access modifiers changed from: package-private */
/* renamed from: com.google.common.math.BigIntegerMath$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) {
}
}
}
/* JADX WARN: Removed duplicated region for block: B:13:0x006b */
/* JADX WARN: Removed duplicated region for block: B:15:0x0071 */
/* JADX WARN: Removed duplicated region for block: B:20:0x008a */
/* JADX WARN: Removed duplicated region for block: B:25:0x0094 */
/* JADX WARN: Removed duplicated region for block: B:29:0x009c A[FALL_THROUGH, RETURN] */
/*
Code decompiled incorrectly, please refer to instructions dump.
To view partially-correct add '--show-bad-code' argument
*/
public static int log10(java.math.BigInteger r7, java.math.RoundingMode r8) {
/*
java.lang.String r0 = "x"
com.google.common.math.MathPreconditions.checkPositive(r0, r7)
boolean r0 = fitsInLong(r7)
if (r0 == 0) goto L14
long r0 = r7.longValue()
int r7 = com.google.common.math.LongMath.log10(r0, r8)
return r7
L14:
java.math.RoundingMode r0 = java.math.RoundingMode.FLOOR
int r0 = log2(r7, r0)
double r0 = (double) r0
double r2 = com.google.common.math.BigIntegerMath.LN_2
double r0 = r0 * r2
double r2 = com.google.common.math.BigIntegerMath.LN_10
double r0 = r0 / r2
int r0 = (int) r0
java.math.BigInteger r1 = java.math.BigInteger.TEN
java.math.BigInteger r1 = r1.pow(r0)
int r2 = r1.compareTo(r7)
if (r2 <= 0) goto L3d
L2e:
int r0 = r0 + (-1)
java.math.BigInteger r2 = java.math.BigInteger.TEN
java.math.BigInteger r1 = r1.divide(r2)
int r2 = r1.compareTo(r7)
if (r2 > 0) goto L2e
goto L60
L3d:
java.math.BigInteger r3 = java.math.BigInteger.TEN
java.math.BigInteger r3 = r3.multiply(r1)
int r4 = r3.compareTo(r7)
r5 = r4
r4 = r2
r2 = r5
L4a:
if (r2 > 0) goto L5f
int r0 = r0 + 1
java.math.BigInteger r1 = java.math.BigInteger.TEN
java.math.BigInteger r1 = r1.multiply(r3)
int r4 = r1.compareTo(r7)
r5 = r3
r3 = r1
r1 = r5
r6 = r4
r4 = r2
r2 = r6
goto L4a
L5f:
r2 = r4
L60:
int[] r3 = com.google.common.math.BigIntegerMath.AnonymousClass1.$SwitchMap$java$math$RoundingMode
int r8 = r8.ordinal()
r8 = r3[r8]
switch(r8) {
case 1: goto L94;
case 2: goto L9c;
case 3: goto L9c;
case 4: goto L8a;
case 5: goto L8a;
case 6: goto L71;
case 7: goto L71;
case 8: goto L71;
default: goto L6b;
}
L6b:
java.lang.AssertionError r7 = new java.lang.AssertionError
r7.<init>()
throw r7
L71:
r8 = 2
java.math.BigInteger r7 = r7.pow(r8)
java.math.BigInteger r8 = r1.pow(r8)
java.math.BigInteger r1 = java.math.BigInteger.TEN
java.math.BigInteger r8 = r8.multiply(r1)
int r7 = r7.compareTo(r8)
if (r7 > 0) goto L87
goto L89
L87:
int r0 = r0 + 1
L89:
return r0
L8a:
boolean r7 = r1.equals(r7)
if (r7 == 0) goto L91
goto L93
L91:
int r0 = r0 + 1
L93:
return r0
L94:
if (r2 != 0) goto L98
r7 = 1
goto L99
L98:
r7 = 0
L99:
com.google.common.math.MathPreconditions.checkRoundingUnnecessary(r7)
L9c:
return r0
*/
throw new UnsupportedOperationException("Method not decompiled: com.google.common.math.BigIntegerMath.log10(java.math.BigInteger, java.math.RoundingMode):int");
}
public static BigInteger sqrt(BigInteger bigInteger, RoundingMode roundingMode) {
MathPreconditions.checkNonNegative(ViewHierarchyNode.JsonKeys.X, bigInteger);
if (fitsInLong(bigInteger)) {
return BigInteger.valueOf(LongMath.sqrt(bigInteger.longValue(), roundingMode));
}
BigInteger sqrtFloor = sqrtFloor(bigInteger);
switch (AnonymousClass1.$SwitchMap$java$math$RoundingMode[roundingMode.ordinal()]) {
case 1:
MathPreconditions.checkRoundingUnnecessary(sqrtFloor.pow(2).equals(bigInteger));
case 2:
case 3:
return sqrtFloor;
case 4:
case 5:
int intValue = sqrtFloor.intValue();
return (intValue * intValue == bigInteger.intValue() && sqrtFloor.pow(2).equals(bigInteger)) ? sqrtFloor : sqrtFloor.add(BigInteger.ONE);
case 6:
case 7:
case 8:
return sqrtFloor.pow(2).add(sqrtFloor).compareTo(bigInteger) >= 0 ? sqrtFloor : sqrtFloor.add(BigInteger.ONE);
default:
throw new AssertionError();
}
}
private static BigInteger sqrtFloor(BigInteger bigInteger) {
BigInteger shiftLeft;
int log2 = log2(bigInteger, RoundingMode.FLOOR);
if (log2 < 1023) {
shiftLeft = sqrtApproxWithDoubles(bigInteger);
} else {
int i = (log2 - 52) & (-2);
shiftLeft = sqrtApproxWithDoubles(bigInteger.shiftRight(i)).shiftLeft(i >> 1);
}
BigInteger shiftRight = shiftLeft.add(bigInteger.divide(shiftLeft)).shiftRight(1);
if (shiftLeft.equals(shiftRight)) {
return shiftLeft;
}
while (true) {
BigInteger shiftRight2 = shiftRight.add(bigInteger.divide(shiftRight)).shiftRight(1);
if (shiftRight2.compareTo(shiftRight) >= 0) {
return shiftRight;
}
shiftRight = shiftRight2;
}
}
private static BigInteger sqrtApproxWithDoubles(BigInteger bigInteger) {
return DoubleMath.roundToBigInteger(Math.sqrt(DoubleUtils.bigToDouble(bigInteger)), RoundingMode.HALF_EVEN);
}
public static double roundToDouble(BigInteger bigInteger, RoundingMode roundingMode) {
return BigIntegerToDoubleRounder.INSTANCE.roundToDouble(bigInteger, roundingMode);
}
/* loaded from: classes3.dex */
private static class BigIntegerToDoubleRounder extends ToDoubleRounder<BigInteger> {
static final BigIntegerToDoubleRounder INSTANCE = new BigIntegerToDoubleRounder();
private BigIntegerToDoubleRounder() {
}
/* JADX INFO: Access modifiers changed from: package-private */
@Override // com.google.common.math.ToDoubleRounder
public double roundToDoubleArbitrarily(BigInteger bigInteger) {
return DoubleUtils.bigToDouble(bigInteger);
}
/* JADX INFO: Access modifiers changed from: package-private */
@Override // com.google.common.math.ToDoubleRounder
public int sign(BigInteger bigInteger) {
return bigInteger.signum();
}
/* JADX INFO: Access modifiers changed from: package-private */
@Override // com.google.common.math.ToDoubleRounder
public BigInteger toX(double d, RoundingMode roundingMode) {
return DoubleMath.roundToBigInteger(d, roundingMode);
}
/* JADX INFO: Access modifiers changed from: package-private */
@Override // com.google.common.math.ToDoubleRounder
public BigInteger minus(BigInteger bigInteger, BigInteger bigInteger2) {
return bigInteger.subtract(bigInteger2);
}
}
public static BigInteger divide(BigInteger bigInteger, BigInteger bigInteger2, RoundingMode roundingMode) {
return new BigDecimal(bigInteger).divide(new BigDecimal(bigInteger2), 0, roundingMode).toBigIntegerExact();
}
public static BigInteger factorial(int i) {
MathPreconditions.checkNonNegative("n", i);
if (i < LongMath.factorials.length) {
return BigInteger.valueOf(LongMath.factorials[i]);
}
ArrayList arrayList = new ArrayList(IntMath.divide(IntMath.log2(i, RoundingMode.CEILING) * i, 64, RoundingMode.CEILING));
int length = LongMath.factorials.length;
long j = LongMath.factorials[length - 1];
int numberOfTrailingZeros = Long.numberOfTrailingZeros(j);
long j2 = j >> numberOfTrailingZeros;
int log2 = LongMath.log2(j2, RoundingMode.FLOOR) + 1;
long j3 = length;
int log22 = LongMath.log2(j3, RoundingMode.FLOOR);
int i2 = log22 + 1;
int i3 = 1 << log22;
while (j3 <= i) {
if ((j3 & i3) != 0) {
i3 <<= 1;
i2++;
}
int numberOfTrailingZeros2 = Long.numberOfTrailingZeros(j3);
long j4 = j3 >> numberOfTrailingZeros2;
numberOfTrailingZeros += numberOfTrailingZeros2;
if ((i2 - numberOfTrailingZeros2) + log2 >= 64) {
arrayList.add(BigInteger.valueOf(j2));
j2 = 1;
}
j2 *= j4;
log2 = LongMath.log2(j2, RoundingMode.FLOOR) + 1;
j3++;
}
if (j2 > 1) {
arrayList.add(BigInteger.valueOf(j2));
}
return listProduct(arrayList).shiftLeft(numberOfTrailingZeros);
}
static BigInteger listProduct(List<BigInteger> list) {
return listProduct(list, 0, list.size());
}
static BigInteger listProduct(List<BigInteger> list, int i, int i2) {
int i3 = i2 - i;
if (i3 == 0) {
return BigInteger.ONE;
}
if (i3 == 1) {
return list.get(i);
}
if (i3 == 2) {
return list.get(i).multiply(list.get(i + 1));
}
if (i3 == 3) {
return list.get(i).multiply(list.get(i + 1)).multiply(list.get(i + 2));
}
int i4 = (i2 + i) >>> 1;
return listProduct(list, i, i4).multiply(listProduct(list, i4, i2));
}
public static BigInteger binomial(int i, int i2) {
int i3;
MathPreconditions.checkNonNegative("n", i);
MathPreconditions.checkNonNegative("k", i2);
int i4 = 1;
Preconditions.checkArgument(i2 <= i, "k (%s) > n (%s)", i2, i);
if (i2 > (i >> 1)) {
i2 = i - i2;
}
if (i2 < LongMath.biggestBinomials.length && i <= LongMath.biggestBinomials[i2]) {
return BigInteger.valueOf(LongMath.binomial(i, i2));
}
BigInteger bigInteger = BigInteger.ONE;
long j = i;
int log2 = LongMath.log2(j, RoundingMode.CEILING);
long j2 = 1;
while (true) {
int i5 = log2;
while (i4 < i2) {
i3 = i - i4;
i4++;
i5 += log2;
if (i5 >= 63) {
break;
}
j *= i3;
j2 *= i4;
}
return bigInteger.multiply(BigInteger.valueOf(j)).divide(BigInteger.valueOf(j2));
bigInteger = bigInteger.multiply(BigInteger.valueOf(j)).divide(BigInteger.valueOf(j2));
j = i3;
j2 = i4;
}
}
static boolean fitsInLong(BigInteger bigInteger) {
return bigInteger.bitLength() <= 63;
}
private BigIntegerMath() {
}
}