tmap/smali_classes3/com/google/common/math/BigIntegerMath.smali
2022-06-10 21:38:30 +09:00

1361 lines
30 KiB
Smali

.class public final Lcom/google/common/math/BigIntegerMath;
.super Ljava/lang/Object;
.source "BigIntegerMath.java"
# annotations
.annotation build Lcom/google/common/annotations/GwtCompatible;
emulated = true
.end annotation
.annotation runtime Lcom/google/common/math/ElementTypesAreNonnullByDefault;
.end annotation
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/google/common/math/BigIntegerMath$BigIntegerToDoubleRounder;
}
.end annotation
# static fields
.field private static final LN_10:D
.field private static final LN_2:D
.field public static final SQRT2_PRECOMPUTED_BITS:Ljava/math/BigInteger;
.annotation build Lcom/google/common/annotations/VisibleForTesting;
.end annotation
.end field
.field public static final SQRT2_PRECOMPUTE_THRESHOLD:I = 0x100
.annotation build Lcom/google/common/annotations/VisibleForTesting;
.end annotation
.end field
# direct methods
.method public static constructor <clinit>()V
.locals 3
.line 1
new-instance v0, Ljava/math/BigInteger;
const-string v1, "16a09e667f3bcc908b2fb1366ea957d3e3adec17512775099da2f590b0667322a"
const/16 v2, 0x10
invoke-direct {v0, v1, v2}, Ljava/math/BigInteger;-><init>(Ljava/lang/String;I)V
sput-object v0, Lcom/google/common/math/BigIntegerMath;->SQRT2_PRECOMPUTED_BITS:Ljava/math/BigInteger;
const-wide/high16 v0, 0x4024000000000000L # 10.0
.line 2
invoke-static {v0, v1}, Ljava/lang/Math;->log(D)D
move-result-wide v0
sput-wide v0, Lcom/google/common/math/BigIntegerMath;->LN_10:D
const-wide/high16 v0, 0x4000000000000000L # 2.0
.line 3
invoke-static {v0, v1}, Ljava/lang/Math;->log(D)D
move-result-wide v0
sput-wide v0, Lcom/google/common/math/BigIntegerMath;->LN_2:D
return-void
.end method
.method private constructor <init>()V
.locals 0
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method public static binomial(II)Ljava/math/BigInteger;
.locals 10
const-string v0, "n"
.line 1
invoke-static {v0, p0}, Lcom/google/common/math/MathPreconditions;->checkNonNegative(Ljava/lang/String;I)I
const-string v0, "k"
.line 2
invoke-static {v0, p1}, Lcom/google/common/math/MathPreconditions;->checkNonNegative(Ljava/lang/String;I)I
const/4 v0, 0x1
if-gt p1, p0, :cond_0
move v1, v0
goto :goto_0
:cond_0
const/4 v1, 0x0
:goto_0
const-string v2, "k (%s) > n (%s)"
.line 3
invoke-static {v1, v2, p1, p0}, Lcom/google/common/base/Preconditions;->checkArgument(ZLjava/lang/String;II)V
shr-int/lit8 v1, p0, 0x1
if-le p1, v1, :cond_1
sub-int p1, p0, p1
.line 4
:cond_1
sget-object v1, Lcom/google/common/math/LongMath;->biggestBinomials:[I
array-length v2, v1
if-ge p1, v2, :cond_2
aget v1, v1, p1
if-gt p0, v1, :cond_2
.line 5
invoke-static {p0, p1}, Lcom/google/common/math/LongMath;->binomial(II)J
move-result-wide p0
invoke-static {p0, p1}, Ljava/math/BigInteger;->valueOf(J)Ljava/math/BigInteger;
move-result-object p0
return-object p0
.line 6
:cond_2
sget-object v1, Ljava/math/BigInteger;->ONE:Ljava/math/BigInteger;
int-to-long v2, p0
const-wide/16 v4, 0x1
.line 7
sget-object v6, Ljava/math/RoundingMode;->CEILING:Ljava/math/RoundingMode;
invoke-static {v2, v3, v6}, Lcom/google/common/math/LongMath;->log2(JLjava/math/RoundingMode;)I
move-result v6
:goto_1
move v7, v6
:goto_2
if-ge v0, p1, :cond_4
sub-int v8, p0, v0
add-int/lit8 v0, v0, 0x1
add-int/2addr v7, v6
const/16 v9, 0x3f
if-lt v7, v9, :cond_3
.line 8
invoke-static {v2, v3}, Ljava/math/BigInteger;->valueOf(J)Ljava/math/BigInteger;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v1
.line 9
invoke-static {v4, v5}, Ljava/math/BigInteger;->valueOf(J)Ljava/math/BigInteger;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/math/BigInteger;->divide(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v1
int-to-long v2, v8
int-to-long v4, v0
goto :goto_1
:cond_3
int-to-long v8, v8
mul-long/2addr v2, v8
int-to-long v8, v0
mul-long/2addr v4, v8
goto :goto_2
.line 10
:cond_4
invoke-static {v2, v3}, Ljava/math/BigInteger;->valueOf(J)Ljava/math/BigInteger;
move-result-object p0
invoke-virtual {v1, p0}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object p0
.line 11
invoke-static {v4, v5}, Ljava/math/BigInteger;->valueOf(J)Ljava/math/BigInteger;
move-result-object p1
invoke-virtual {p0, p1}, Ljava/math/BigInteger;->divide(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object p0
return-object p0
.end method
.method public static ceilingPowerOfTwo(Ljava/math/BigInteger;)Ljava/math/BigInteger;
.locals 2
.annotation build Lcom/google/common/annotations/Beta;
.end annotation
.line 1
sget-object v0, Ljava/math/BigInteger;->ZERO:Ljava/math/BigInteger;
sget-object v1, Ljava/math/RoundingMode;->CEILING:Ljava/math/RoundingMode;
invoke-static {p0, v1}, Lcom/google/common/math/BigIntegerMath;->log2(Ljava/math/BigInteger;Ljava/math/RoundingMode;)I
move-result p0
invoke-virtual {v0, p0}, Ljava/math/BigInteger;->setBit(I)Ljava/math/BigInteger;
move-result-object p0
return-object p0
.end method
.method public static divide(Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/RoundingMode;)Ljava/math/BigInteger;
.locals 1
.annotation build Lcom/google/common/annotations/GwtIncompatible;
.end annotation
.line 1
new-instance v0, Ljava/math/BigDecimal;
invoke-direct {v0, p0}, Ljava/math/BigDecimal;-><init>(Ljava/math/BigInteger;)V
.line 2
new-instance p0, Ljava/math/BigDecimal;
invoke-direct {p0, p1}, Ljava/math/BigDecimal;-><init>(Ljava/math/BigInteger;)V
const/4 p1, 0x0
.line 3
invoke-virtual {v0, p0, p1, p2}, Ljava/math/BigDecimal;->divide(Ljava/math/BigDecimal;ILjava/math/RoundingMode;)Ljava/math/BigDecimal;
move-result-object p0
invoke-virtual {p0}, Ljava/math/BigDecimal;->toBigIntegerExact()Ljava/math/BigInteger;
move-result-object p0
return-object p0
.end method
.method public static factorial(I)Ljava/math/BigInteger;
.locals 17
move/from16 v0, p0
const-string v1, "n"
.line 1
invoke-static {v1, v0}, Lcom/google/common/math/MathPreconditions;->checkNonNegative(Ljava/lang/String;I)I
.line 2
sget-object v1, Lcom/google/common/math/LongMath;->factorials:[J
array-length v2, v1
if-ge v0, v2, :cond_0
.line 3
aget-wide v0, v1, v0
invoke-static {v0, v1}, Ljava/math/BigInteger;->valueOf(J)Ljava/math/BigInteger;
move-result-object v0
return-object v0
.line 4
:cond_0
sget-object v2, Ljava/math/RoundingMode;->CEILING:Ljava/math/RoundingMode;
invoke-static {v0, v2}, Lcom/google/common/math/IntMath;->log2(ILjava/math/RoundingMode;)I
move-result v2
mul-int/2addr v2, v0
sget-object v3, Ljava/math/RoundingMode;->CEILING:Ljava/math/RoundingMode;
const/16 v4, 0x40
invoke-static {v2, v4, v3}, Lcom/google/common/math/IntMath;->divide(IILjava/math/RoundingMode;)I
move-result v2
.line 5
new-instance v3, Ljava/util/ArrayList;
invoke-direct {v3, v2}, Ljava/util/ArrayList;-><init>(I)V
.line 6
array-length v2, v1
add-int/lit8 v5, v2, -0x1
.line 7
aget-wide v5, v1, v5
.line 8
invoke-static {v5, v6}, Ljava/lang/Long;->numberOfTrailingZeros(J)I
move-result v1
shr-long/2addr v5, v1
.line 9
sget-object v7, Ljava/math/RoundingMode;->FLOOR:Ljava/math/RoundingMode;
invoke-static {v5, v6, v7}, Lcom/google/common/math/LongMath;->log2(JLjava/math/RoundingMode;)I
move-result v7
const/4 v8, 0x1
add-int/2addr v7, v8
int-to-long v9, v2
.line 10
sget-object v2, Ljava/math/RoundingMode;->FLOOR:Ljava/math/RoundingMode;
invoke-static {v9, v10, v2}, Lcom/google/common/math/LongMath;->log2(JLjava/math/RoundingMode;)I
move-result v2
add-int/2addr v2, v8
add-int/lit8 v11, v2, -0x1
shl-int v11, v8, v11
:goto_0
int-to-long v12, v0
cmp-long v12, v9, v12
if-gtz v12, :cond_3
int-to-long v13, v11
and-long v12, v9, v13
const-wide/16 v15, 0x0
cmp-long v12, v12, v15
if-eqz v12, :cond_1
shl-int/lit8 v11, v11, 0x1
add-int/lit8 v2, v2, 0x1
.line 11
:cond_1
invoke-static {v9, v10}, Ljava/lang/Long;->numberOfTrailingZeros(J)I
move-result v12
shr-long v13, v9, v12
add-int/2addr v1, v12
sub-int v12, v2, v12
add-int/2addr v12, v7
if-lt v12, v4, :cond_2
.line 12
invoke-static {v5, v6}, Ljava/math/BigInteger;->valueOf(J)Ljava/math/BigInteger;
move-result-object v5
invoke-virtual {v3, v5}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
const-wide/16 v5, 0x1
:cond_2
mul-long/2addr v5, v13
.line 13
sget-object v7, Ljava/math/RoundingMode;->FLOOR:Ljava/math/RoundingMode;
invoke-static {v5, v6, v7}, Lcom/google/common/math/LongMath;->log2(JLjava/math/RoundingMode;)I
move-result v7
add-int/2addr v7, v8
const-wide/16 v12, 0x1
add-long/2addr v9, v12
goto :goto_0
:cond_3
const-wide/16 v12, 0x1
cmp-long v0, v5, v12
if-lez v0, :cond_4
.line 14
invoke-static {v5, v6}, Ljava/math/BigInteger;->valueOf(J)Ljava/math/BigInteger;
move-result-object v0
invoke-virtual {v3, v0}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
.line 15
:cond_4
invoke-static {v3}, Lcom/google/common/math/BigIntegerMath;->listProduct(Ljava/util/List;)Ljava/math/BigInteger;
move-result-object v0
invoke-virtual {v0, v1}, Ljava/math/BigInteger;->shiftLeft(I)Ljava/math/BigInteger;
move-result-object v0
return-object v0
.end method
.method public static fitsInLong(Ljava/math/BigInteger;)Z
.locals 1
.annotation build Lcom/google/common/annotations/GwtIncompatible;
.end annotation
.line 1
invoke-virtual {p0}, Ljava/math/BigInteger;->bitLength()I
move-result p0
const/16 v0, 0x3f
if-gt p0, v0, :cond_0
const/4 p0, 0x1
goto :goto_0
:cond_0
const/4 p0, 0x0
:goto_0
return p0
.end method
.method public static floorPowerOfTwo(Ljava/math/BigInteger;)Ljava/math/BigInteger;
.locals 2
.annotation build Lcom/google/common/annotations/Beta;
.end annotation
.line 1
sget-object v0, Ljava/math/BigInteger;->ZERO:Ljava/math/BigInteger;
sget-object v1, Ljava/math/RoundingMode;->FLOOR:Ljava/math/RoundingMode;
invoke-static {p0, v1}, Lcom/google/common/math/BigIntegerMath;->log2(Ljava/math/BigInteger;Ljava/math/RoundingMode;)I
move-result p0
invoke-virtual {v0, p0}, Ljava/math/BigInteger;->setBit(I)Ljava/math/BigInteger;
move-result-object p0
return-object p0
.end method
.method public static isPowerOfTwo(Ljava/math/BigInteger;)Z
.locals 2
.line 1
invoke-static {p0}, Lcom/google/common/base/Preconditions;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
.line 2
invoke-virtual {p0}, Ljava/math/BigInteger;->signum()I
move-result v0
const/4 v1, 0x1
if-lez v0, :cond_0
invoke-virtual {p0}, Ljava/math/BigInteger;->getLowestSetBit()I
move-result v0
invoke-virtual {p0}, Ljava/math/BigInteger;->bitLength()I
move-result p0
sub-int/2addr p0, v1
if-ne v0, p0, :cond_0
goto :goto_0
:cond_0
const/4 v1, 0x0
:goto_0
return v1
.end method
.method public static listProduct(Ljava/util/List;)Ljava/math/BigInteger;
.locals 2
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/List<",
"Ljava/math/BigInteger;",
">;)",
"Ljava/math/BigInteger;"
}
.end annotation
.line 1
invoke-interface {p0}, Ljava/util/List;->size()I
move-result v0
const/4 v1, 0x0
invoke-static {p0, v1, v0}, Lcom/google/common/math/BigIntegerMath;->listProduct(Ljava/util/List;II)Ljava/math/BigInteger;
move-result-object p0
return-object p0
.end method
.method public static listProduct(Ljava/util/List;II)Ljava/math/BigInteger;
.locals 4
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/List<",
"Ljava/math/BigInteger;",
">;II)",
"Ljava/math/BigInteger;"
}
.end annotation
sub-int v0, p2, p1
if-eqz v0, :cond_3
const/4 v1, 0x1
if-eq v0, v1, :cond_2
const/4 v2, 0x2
if-eq v0, v2, :cond_1
const/4 v3, 0x3
if-eq v0, v3, :cond_0
add-int v0, p2, p1
ushr-int/2addr v0, v1
.line 2
invoke-static {p0, p1, v0}, Lcom/google/common/math/BigIntegerMath;->listProduct(Ljava/util/List;II)Ljava/math/BigInteger;
move-result-object p1
invoke-static {p0, v0, p2}, Lcom/google/common/math/BigIntegerMath;->listProduct(Ljava/util/List;II)Ljava/math/BigInteger;
move-result-object p0
invoke-virtual {p1, p0}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object p0
return-object p0
.line 3
:cond_0
invoke-interface {p0, p1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object p2
check-cast p2, Ljava/math/BigInteger;
add-int/lit8 v0, p1, 0x1
invoke-interface {p0, v0}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/math/BigInteger;
invoke-virtual {p2, v0}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object p2
add-int/2addr p1, v2
invoke-interface {p0, p1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object p0
check-cast p0, Ljava/math/BigInteger;
invoke-virtual {p2, p0}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object p0
return-object p0
.line 4
:cond_1
invoke-interface {p0, p1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object p2
check-cast p2, Ljava/math/BigInteger;
add-int/2addr p1, v1
invoke-interface {p0, p1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object p0
check-cast p0, Ljava/math/BigInteger;
invoke-virtual {p2, p0}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object p0
return-object p0
.line 5
:cond_2
invoke-interface {p0, p1}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object p0
check-cast p0, Ljava/math/BigInteger;
return-object p0
.line 6
:cond_3
sget-object p0, Ljava/math/BigInteger;->ONE:Ljava/math/BigInteger;
return-object p0
.end method
.method public static log10(Ljava/math/BigInteger;Ljava/math/RoundingMode;)I
.locals 7
.annotation build Lcom/google/common/annotations/GwtIncompatible;
.end annotation
const-string v0, "x"
.line 1
invoke-static {v0, p0}, Lcom/google/common/math/MathPreconditions;->checkPositive(Ljava/lang/String;Ljava/math/BigInteger;)Ljava/math/BigInteger;
.line 2
invoke-static {p0}, Lcom/google/common/math/BigIntegerMath;->fitsInLong(Ljava/math/BigInteger;)Z
move-result v0
if-eqz v0, :cond_0
.line 3
invoke-virtual {p0}, Ljava/math/BigInteger;->longValue()J
move-result-wide v0
invoke-static {v0, v1, p1}, Lcom/google/common/math/LongMath;->log10(JLjava/math/RoundingMode;)I
move-result p0
return p0
.line 4
:cond_0
sget-object v0, Ljava/math/RoundingMode;->FLOOR:Ljava/math/RoundingMode;
invoke-static {p0, v0}, Lcom/google/common/math/BigIntegerMath;->log2(Ljava/math/BigInteger;Ljava/math/RoundingMode;)I
move-result v0
int-to-double v0, v0
sget-wide v2, Lcom/google/common/math/BigIntegerMath;->LN_2:D
mul-double/2addr v0, v2
sget-wide v2, Lcom/google/common/math/BigIntegerMath;->LN_10:D
div-double/2addr v0, v2
double-to-int v0, v0
.line 5
sget-object v1, Ljava/math/BigInteger;->TEN:Ljava/math/BigInteger;
invoke-virtual {v1, v0}, Ljava/math/BigInteger;->pow(I)Ljava/math/BigInteger;
move-result-object v1
.line 6
invoke-virtual {v1, p0}, Ljava/math/BigInteger;->compareTo(Ljava/math/BigInteger;)I
move-result v2
if-lez v2, :cond_2
:cond_1
add-int/lit8 v0, v0, -0x1
.line 7
sget-object v2, Ljava/math/BigInteger;->TEN:Ljava/math/BigInteger;
invoke-virtual {v1, v2}, Ljava/math/BigInteger;->divide(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v1
.line 8
invoke-virtual {v1, p0}, Ljava/math/BigInteger;->compareTo(Ljava/math/BigInteger;)I
move-result v2
if-gtz v2, :cond_1
goto :goto_1
.line 9
:cond_2
sget-object v3, Ljava/math/BigInteger;->TEN:Ljava/math/BigInteger;
invoke-virtual {v3, v1}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v3
.line 10
invoke-virtual {v3, p0}, Ljava/math/BigInteger;->compareTo(Ljava/math/BigInteger;)I
move-result v4
move v5, v4
move v4, v2
move v2, v5
:goto_0
if-gtz v2, :cond_3
add-int/lit8 v0, v0, 0x1
.line 11
sget-object v1, Ljava/math/BigInteger;->TEN:Ljava/math/BigInteger;
invoke-virtual {v1, v3}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v1
.line 12
invoke-virtual {v1, p0}, Ljava/math/BigInteger;->compareTo(Ljava/math/BigInteger;)I
move-result v4
move-object v5, v3
move-object v3, v1
move-object v1, v5
move v6, v4
move v4, v2
move v2, v6
goto :goto_0
:cond_3
move v2, v4
.line 13
:goto_1
sget-object v3, Lcom/google/common/math/BigIntegerMath$1;->$SwitchMap$java$math$RoundingMode:[I
invoke-virtual {p1}, Ljava/math/RoundingMode;->ordinal()I
move-result p1
aget p1, v3, p1
packed-switch p1, :pswitch_data_0
.line 14
new-instance p0, Ljava/lang/AssertionError;
invoke-direct {p0}, Ljava/lang/AssertionError;-><init>()V
throw p0
:pswitch_0
const/4 p1, 0x2
.line 15
invoke-virtual {p0, p1}, Ljava/math/BigInteger;->pow(I)Ljava/math/BigInteger;
move-result-object p0
.line 16
invoke-virtual {v1, p1}, Ljava/math/BigInteger;->pow(I)Ljava/math/BigInteger;
move-result-object p1
sget-object v1, Ljava/math/BigInteger;->TEN:Ljava/math/BigInteger;
invoke-virtual {p1, v1}, Ljava/math/BigInteger;->multiply(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object p1
.line 17
invoke-virtual {p0, p1}, Ljava/math/BigInteger;->compareTo(Ljava/math/BigInteger;)I
move-result p0
if-gtz p0, :cond_4
goto :goto_2
:cond_4
add-int/lit8 v0, v0, 0x1
:goto_2
return v0
.line 18
:pswitch_1
invoke-virtual {v1, p0}, Ljava/math/BigInteger;->equals(Ljava/lang/Object;)Z
move-result p0
if-eqz p0, :cond_5
goto :goto_3
:cond_5
add-int/lit8 v0, v0, 0x1
:goto_3
return v0
:pswitch_2
if-nez v2, :cond_6
const/4 p0, 0x1
goto :goto_4
:cond_6
const/4 p0, 0x0
.line 19
:goto_4
invoke-static {p0}, Lcom/google/common/math/MathPreconditions;->checkRoundingUnnecessary(Z)V
:pswitch_3
return v0
nop
:pswitch_data_0
.packed-switch 0x1
:pswitch_2
:pswitch_3
:pswitch_3
:pswitch_1
:pswitch_1
:pswitch_0
:pswitch_0
:pswitch_0
.end packed-switch
.end method
.method public static log2(Ljava/math/BigInteger;Ljava/math/RoundingMode;)I
.locals 2
.line 1
invoke-static {p0}, Lcom/google/common/base/Preconditions;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/math/BigInteger;
const-string v1, "x"
invoke-static {v1, v0}, Lcom/google/common/math/MathPreconditions;->checkPositive(Ljava/lang/String;Ljava/math/BigInteger;)Ljava/math/BigInteger;
.line 2
invoke-virtual {p0}, Ljava/math/BigInteger;->bitLength()I
move-result v0
add-int/lit8 v0, v0, -0x1
.line 3
sget-object v1, Lcom/google/common/math/BigIntegerMath$1;->$SwitchMap$java$math$RoundingMode:[I
invoke-virtual {p1}, Ljava/math/RoundingMode;->ordinal()I
move-result p1
aget p1, v1, p1
packed-switch p1, :pswitch_data_0
.line 4
new-instance p0, Ljava/lang/AssertionError;
invoke-direct {p0}, Ljava/lang/AssertionError;-><init>()V
throw p0
:pswitch_0
const/16 p1, 0x100
if-ge v0, p1, :cond_1
.line 5
sget-object p1, Lcom/google/common/math/BigIntegerMath;->SQRT2_PRECOMPUTED_BITS:Ljava/math/BigInteger;
rsub-int v1, v0, 0x100
.line 6
invoke-virtual {p1, v1}, Ljava/math/BigInteger;->shiftRight(I)Ljava/math/BigInteger;
move-result-object p1
.line 7
invoke-virtual {p0, p1}, Ljava/math/BigInteger;->compareTo(Ljava/math/BigInteger;)I
move-result p0
if-gtz p0, :cond_0
return v0
:cond_0
add-int/lit8 v0, v0, 0x1
return v0
:cond_1
const/4 p1, 0x2
.line 8
invoke-virtual {p0, p1}, Ljava/math/BigInteger;->pow(I)Ljava/math/BigInteger;
move-result-object p0
.line 9
invoke-virtual {p0}, Ljava/math/BigInteger;->bitLength()I
move-result p0
add-int/lit8 p0, p0, -0x1
mul-int/lit8 p1, v0, 0x2
add-int/lit8 p1, p1, 0x1
if-ge p0, p1, :cond_2
goto :goto_0
:cond_2
add-int/lit8 v0, v0, 0x1
:goto_0
return v0
.line 10
:pswitch_1
invoke-static {p0}, Lcom/google/common/math/BigIntegerMath;->isPowerOfTwo(Ljava/math/BigInteger;)Z
move-result p0
if-eqz p0, :cond_3
goto :goto_1
:cond_3
add-int/lit8 v0, v0, 0x1
:goto_1
return v0
.line 11
:pswitch_2
invoke-static {p0}, Lcom/google/common/math/BigIntegerMath;->isPowerOfTwo(Ljava/math/BigInteger;)Z
move-result p0
invoke-static {p0}, Lcom/google/common/math/MathPreconditions;->checkRoundingUnnecessary(Z)V
:pswitch_3
return v0
nop
:pswitch_data_0
.packed-switch 0x1
:pswitch_2
:pswitch_3
:pswitch_3
:pswitch_1
:pswitch_1
:pswitch_0
:pswitch_0
:pswitch_0
.end packed-switch
.end method
.method public static roundToDouble(Ljava/math/BigInteger;Ljava/math/RoundingMode;)D
.locals 1
.annotation build Lcom/google/common/annotations/GwtIncompatible;
.end annotation
.line 1
sget-object v0, Lcom/google/common/math/BigIntegerMath$BigIntegerToDoubleRounder;->INSTANCE:Lcom/google/common/math/BigIntegerMath$BigIntegerToDoubleRounder;
invoke-virtual {v0, p0, p1}, Lcom/google/common/math/ToDoubleRounder;->roundToDouble(Ljava/lang/Number;Ljava/math/RoundingMode;)D
move-result-wide p0
return-wide p0
.end method
.method public static sqrt(Ljava/math/BigInteger;Ljava/math/RoundingMode;)Ljava/math/BigInteger;
.locals 3
.annotation build Lcom/google/common/annotations/GwtIncompatible;
.end annotation
const-string v0, "x"
.line 1
invoke-static {v0, p0}, Lcom/google/common/math/MathPreconditions;->checkNonNegative(Ljava/lang/String;Ljava/math/BigInteger;)Ljava/math/BigInteger;
.line 2
invoke-static {p0}, Lcom/google/common/math/BigIntegerMath;->fitsInLong(Ljava/math/BigInteger;)Z
move-result v0
if-eqz v0, :cond_0
.line 3
invoke-virtual {p0}, Ljava/math/BigInteger;->longValue()J
move-result-wide v0
invoke-static {v0, v1, p1}, Lcom/google/common/math/LongMath;->sqrt(JLjava/math/RoundingMode;)J
move-result-wide p0
invoke-static {p0, p1}, Ljava/math/BigInteger;->valueOf(J)Ljava/math/BigInteger;
move-result-object p0
return-object p0
.line 4
:cond_0
invoke-static {p0}, Lcom/google/common/math/BigIntegerMath;->sqrtFloor(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v0
.line 5
sget-object v1, Lcom/google/common/math/BigIntegerMath$1;->$SwitchMap$java$math$RoundingMode:[I
invoke-virtual {p1}, Ljava/math/RoundingMode;->ordinal()I
move-result p1
aget p1, v1, p1
const/4 v1, 0x2
packed-switch p1, :pswitch_data_0
.line 6
new-instance p0, Ljava/lang/AssertionError;
invoke-direct {p0}, Ljava/lang/AssertionError;-><init>()V
throw p0
.line 7
:pswitch_0
invoke-virtual {v0, v1}, Ljava/math/BigInteger;->pow(I)Ljava/math/BigInteger;
move-result-object p1
invoke-virtual {p1, v0}, Ljava/math/BigInteger;->add(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object p1
.line 8
invoke-virtual {p1, p0}, Ljava/math/BigInteger;->compareTo(Ljava/math/BigInteger;)I
move-result p0
if-ltz p0, :cond_1
goto :goto_0
:cond_1
sget-object p0, Ljava/math/BigInteger;->ONE:Ljava/math/BigInteger;
invoke-virtual {v0, p0}, Ljava/math/BigInteger;->add(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v0
:goto_0
return-object v0
.line 9
:pswitch_1
invoke-virtual {v0}, Ljava/math/BigInteger;->intValue()I
move-result p1
mul-int/2addr p1, p1
.line 10
invoke-virtual {p0}, Ljava/math/BigInteger;->intValue()I
move-result v2
if-ne p1, v2, :cond_2
.line 11
invoke-virtual {v0, v1}, Ljava/math/BigInteger;->pow(I)Ljava/math/BigInteger;
move-result-object p1
invoke-virtual {p1, p0}, Ljava/math/BigInteger;->equals(Ljava/lang/Object;)Z
move-result p0
if-eqz p0, :cond_2
const/4 p0, 0x1
goto :goto_1
:cond_2
const/4 p0, 0x0
:goto_1
if-eqz p0, :cond_3
goto :goto_2
.line 12
:cond_3
sget-object p0, Ljava/math/BigInteger;->ONE:Ljava/math/BigInteger;
invoke-virtual {v0, p0}, Ljava/math/BigInteger;->add(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v0
:goto_2
return-object v0
.line 13
:pswitch_2
invoke-virtual {v0, v1}, Ljava/math/BigInteger;->pow(I)Ljava/math/BigInteger;
move-result-object p1
invoke-virtual {p1, p0}, Ljava/math/BigInteger;->equals(Ljava/lang/Object;)Z
move-result p0
invoke-static {p0}, Lcom/google/common/math/MathPreconditions;->checkRoundingUnnecessary(Z)V
:pswitch_3
return-object v0
:pswitch_data_0
.packed-switch 0x1
:pswitch_2
:pswitch_3
:pswitch_3
:pswitch_1
:pswitch_1
:pswitch_0
:pswitch_0
:pswitch_0
.end packed-switch
.end method
.method private static sqrtApproxWithDoubles(Ljava/math/BigInteger;)Ljava/math/BigInteger;
.locals 2
.annotation build Lcom/google/common/annotations/GwtIncompatible;
.end annotation
.line 1
invoke-static {p0}, Lcom/google/common/math/DoubleUtils;->bigToDouble(Ljava/math/BigInteger;)D
move-result-wide v0
invoke-static {v0, v1}, Ljava/lang/Math;->sqrt(D)D
move-result-wide v0
sget-object p0, Ljava/math/RoundingMode;->HALF_EVEN:Ljava/math/RoundingMode;
invoke-static {v0, v1, p0}, Lcom/google/common/math/DoubleMath;->roundToBigInteger(DLjava/math/RoundingMode;)Ljava/math/BigInteger;
move-result-object p0
return-object p0
.end method
.method private static sqrtFloor(Ljava/math/BigInteger;)Ljava/math/BigInteger;
.locals 4
.annotation build Lcom/google/common/annotations/GwtIncompatible;
.end annotation
.line 1
sget-object v0, Ljava/math/RoundingMode;->FLOOR:Ljava/math/RoundingMode;
invoke-static {p0, v0}, Lcom/google/common/math/BigIntegerMath;->log2(Ljava/math/BigInteger;Ljava/math/RoundingMode;)I
move-result v0
const/4 v1, 0x1
const/16 v2, 0x3ff
if-ge v0, v2, :cond_0
.line 2
invoke-static {p0}, Lcom/google/common/math/BigIntegerMath;->sqrtApproxWithDoubles(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v0
goto :goto_0
:cond_0
add-int/lit8 v0, v0, -0x34
and-int/lit8 v0, v0, -0x2
.line 3
invoke-virtual {p0, v0}, Ljava/math/BigInteger;->shiftRight(I)Ljava/math/BigInteger;
move-result-object v2
invoke-static {v2}, Lcom/google/common/math/BigIntegerMath;->sqrtApproxWithDoubles(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v2
shr-int/2addr v0, v1
invoke-virtual {v2, v0}, Ljava/math/BigInteger;->shiftLeft(I)Ljava/math/BigInteger;
move-result-object v0
.line 4
:goto_0
invoke-virtual {p0, v0}, Ljava/math/BigInteger;->divide(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v2
invoke-virtual {v0, v2}, Ljava/math/BigInteger;->add(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v2
invoke-virtual {v2, v1}, Ljava/math/BigInteger;->shiftRight(I)Ljava/math/BigInteger;
move-result-object v2
.line 5
invoke-virtual {v0, v2}, Ljava/math/BigInteger;->equals(Ljava/lang/Object;)Z
move-result v3
if-eqz v3, :cond_1
return-object v0
.line 6
:cond_1
:goto_1
invoke-virtual {p0, v2}, Ljava/math/BigInteger;->divide(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v0
invoke-virtual {v2, v0}, Ljava/math/BigInteger;->add(Ljava/math/BigInteger;)Ljava/math/BigInteger;
move-result-object v0
invoke-virtual {v0, v1}, Ljava/math/BigInteger;->shiftRight(I)Ljava/math/BigInteger;
move-result-object v0
.line 7
invoke-virtual {v0, v2}, Ljava/math/BigInteger;->compareTo(Ljava/math/BigInteger;)I
move-result v3
if-ltz v3, :cond_2
return-object v2
:cond_2
move-object v2, v0
goto :goto_1
.end method