.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 ()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;->(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 ()V .locals 0 .line 1 invoke-direct {p0}, Ljava/lang/Object;->()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;->(Ljava/math/BigInteger;)V .line 2 new-instance p0, Ljava/math/BigDecimal; invoke-direct {p0, p1}, Ljava/math/BigDecimal;->(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;->(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;->()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;->()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;->()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