b.smali

.class public Lc6/b;
.super Ljava/lang/Object;
.source "HeatmapTileProvider.java"

# interfaces
.implements Lcom/google/android/gms/maps/model/TileProvider;


# annotations
.annotation system Ldalvik/annotation/MemberClasses;
    value = {
        Lc6/b$b;
    }
.end annotation


# static fields
.field public static final j:[I

.field public static final k:[F

.field public static final l:Lc6/a;


# instance fields
.field public a:Le6/a;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Le6/a<",
            "Lc6/c;",
            ">;"
        }
    .end annotation
.end field

.field public b:Ljava/util/Collection;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/Collection<",
            "Lc6/c;",
            ">;"
        }
    .end annotation
.end field

.field public c:Lb6/a;

.field public d:I

.field public e:Lc6/a;

.field public f:[I

.field public g:[D

.field public h:D

.field public i:[D


# direct methods
.method public static constructor <clinit>()V
    .registers 5

    const/4 v0, 0x2

    new-array v1, v0, [I

    const/4 v2, 0x0

    const/16 v3, 0x66

    const/16 v4, 0xe1

    invoke-static {v3, v4, v2}, Landroid/graphics/Color;->rgb(III)I

    move-result v3

    aput v3, v1, v2

    const/16 v3, 0xff

    invoke-static {v3, v2, v2}, Landroid/graphics/Color;->rgb(III)I

    move-result v2

    const/4 v3, 0x1

    aput v2, v1, v3

    sput-object v1, Lc6/b;->j:[I

    new-array v0, v0, [F

    fill-array-data v0, :array_28

    sput-object v0, Lc6/b;->k:[F

    new-instance v2, Lc6/a;

    invoke-direct {v2, v1, v0}, Lc6/a;-><init>([I[F)V

    sput-object v2, Lc6/b;->l:Lc6/a;

    return-void

    :array_28
    .array-data 4
        0x3e4ccccd    # 0.2f
        0x3f800000    # 1.0f
    .end array-data
.end method

.method public constructor <init>(Lc6/b$b;)V
    .registers 6

    invoke-direct {p0}, Ljava/lang/Object;-><init>()V

    invoke-static {p1}, Lc6/b$b;->a(Lc6/b$b;)Ljava/util/Collection;

    move-result-object v0

    iput-object v0, p0, Lc6/b;->b:Ljava/util/Collection;

    invoke-static {p1}, Lc6/b$b;->b(Lc6/b$b;)I

    move-result v0

    iput v0, p0, Lc6/b;->d:I

    invoke-static {p1}, Lc6/b$b;->c(Lc6/b$b;)Lc6/a;

    move-result-object v0

    iput-object v0, p0, Lc6/b;->e:Lc6/a;

    invoke-static {p1}, Lc6/b$b;->d(Lc6/b$b;)D

    move-result-wide v0

    iput-wide v0, p0, Lc6/b;->h:D

    iget p1, p0, Lc6/b;->d:I

    int-to-double v0, p1

    const-wide/high16 v2, 0x4008000000000000L    # 3.0

    invoke-static {v0, v1}, Ljava/lang/Double;->isNaN(D)Z

    div-double/2addr v0, v2

    invoke-static {p1, v0, v1}, Lc6/b;->a(ID)[D

    move-result-object p1

    iput-object p1, p0, Lc6/b;->g:[D

    iget-object p1, p0, Lc6/b;->e:Lc6/a;

    invoke-virtual {p0, p1}, Lc6/b;->a(Lc6/a;)V

    iget-object p1, p0, Lc6/b;->b:Ljava/util/Collection;

    invoke-virtual {p0, p1}, Lc6/b;->a(Ljava/util/Collection;)V

    return-void
.end method

.method public synthetic constructor <init>(Lc6/b$b;Lc6/b$a;)V
    .registers 3

    invoke-direct {p0, p1}, Lc6/b;-><init>(Lc6/b$b;)V

    return-void
.end method

.method public static a(Ljava/util/Collection;Lb6/a;II)D
    .registers 25
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Ljava/util/Collection<",
            "Lc6/c;",
            ">;",
            "Lb6/a;",
            "II)D"
        }
    .end annotation

    move-object/from16 v0, p1

    iget-wide v1, v0, Lb6/a;->a:D

    iget-wide v3, v0, Lb6/a;->c:D

    iget-wide v5, v0, Lb6/a;->b:D

    iget-wide v7, v0, Lb6/a;->d:D

    sub-double/2addr v3, v1

    sub-double/2addr v7, v5

    cmpl-double v0, v3, v7

    if-lez v0, :cond_11

    goto :goto_12

    :cond_11
    move-wide v3, v7

    :goto_12
    mul-int/lit8 v0, p2, 0x2

    div-int v0, p3, v0

    int-to-double v7, v0

    const-wide/high16 v9, 0x3fe0000000000000L    # 0.5

    invoke-static {v7, v8}, Ljava/lang/Double;->isNaN(D)Z

    add-double/2addr v7, v9

    double-to-int v0, v7

    int-to-double v7, v0

    invoke-static {v7, v8}, Ljava/lang/Double;->isNaN(D)Z

    div-double/2addr v7, v3

    new-instance v0, Landroidx/collection/LongSparseArray;

    invoke-direct {v0}, Landroidx/collection/LongSparseArray;-><init>()V

    invoke-interface/range {p0 .. p0}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;

    move-result-object v3

    const-wide/16 v11, 0x0

    :cond_2e
    :goto_2e
    invoke-interface {v3}, Ljava/util/Iterator;->hasNext()Z

    move-result v4

    if-eqz v4, :cond_8c

    invoke-interface {v3}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v4

    check-cast v4, Lc6/c;

    invoke-virtual {v4}, Lc6/c;->a()Lb6/b;

    move-result-object v13

    iget-wide v13, v13, Lb6/b;->a:D

    invoke-virtual {v4}, Lc6/c;->a()Lb6/b;

    move-result-object v15

    iget-wide v9, v15, Lb6/b;->b:D

    sub-double/2addr v13, v1

    mul-double v13, v13, v7

    double-to-int v13, v13

    sub-double/2addr v9, v5

    mul-double v9, v9, v7

    double-to-int v9, v9

    int-to-long v13, v13

    invoke-virtual {v0, v13, v14}, Landroidx/collection/LongSparseArray;->get(J)Ljava/lang/Object;

    move-result-object v10

    check-cast v10, Landroidx/collection/LongSparseArray;

    if-nez v10, :cond_5f

    new-instance v10, Landroidx/collection/LongSparseArray;

    invoke-direct {v10}, Landroidx/collection/LongSparseArray;-><init>()V

    invoke-virtual {v0, v13, v14, v10}, Landroidx/collection/LongSparseArray;->put(JLjava/lang/Object;)V

    :cond_5f
    int-to-long v13, v9

    invoke-virtual {v10, v13, v14}, Landroidx/collection/LongSparseArray;->get(J)Ljava/lang/Object;

    move-result-object v9

    check-cast v9, Ljava/lang/Double;

    const-wide/16 v15, 0x0

    if-nez v9, :cond_6e

    invoke-static/range {v15 .. v16}, Ljava/lang/Double;->valueOf(D)Ljava/lang/Double;

    move-result-object v9

    :cond_6e
    invoke-virtual {v9}, Ljava/lang/Double;->doubleValue()D

    move-result-wide v17

    invoke-virtual {v4}, Lc6/c;->b()D

    move-result-wide v19

    add-double v17, v17, v19

    invoke-static/range {v17 .. v18}, Ljava/lang/Double;->valueOf(D)Ljava/lang/Double;

    move-result-object v4

    invoke-virtual {v10, v13, v14, v4}, Landroidx/collection/LongSparseArray;->put(JLjava/lang/Object;)V

    invoke-virtual {v4}, Ljava/lang/Double;->doubleValue()D

    move-result-wide v9

    cmpl-double v13, v9, v11

    if-lez v13, :cond_2e

    invoke-virtual {v4}, Ljava/lang/Double;->doubleValue()D

    move-result-wide v11

    goto :goto_2e

    :cond_8c
    return-wide v11
.end method

.method public static a([[D[ID)Landroid/graphics/Bitmap;
    .registers 21

    move-object/from16 v0, p0

    move-object/from16 v1, p1

    array-length v2, v1

    add-int/lit8 v2, v2, -0x1

    aget v2, v1, v2

    array-length v3, v1

    add-int/lit8 v3, v3, -0x1

    int-to-double v3, v3

    invoke-static {v3, v4}, Ljava/lang/Double;->isNaN(D)Z

    div-double v3, v3, p2

    array-length v12, v0

    mul-int v5, v12, v12

    new-array v6, v5, [I

    const/4 v5, 0x0

    const/4 v7, 0x0

    :goto_19
    if-ge v7, v12, :cond_41

    const/4 v8, 0x0

    :goto_1c
    if-ge v8, v12, :cond_3e

    aget-object v9, v0, v8

    aget-wide v10, v9, v7

    mul-int v9, v7, v12

    add-int/2addr v9, v8

    mul-double v13, v10, v3

    double-to-int v13, v13

    const-wide/16 v14, 0x0

    cmpl-double v16, v10, v14

    if-eqz v16, :cond_39

    array-length v10, v1

    if-ge v13, v10, :cond_36

    aget v10, v1, v13

    aput v10, v6, v9

    goto :goto_3b

    :cond_36
    aput v2, v6, v9

    goto :goto_3b

    :cond_39
    aput v5, v6, v9

    :goto_3b
    add-int/lit8 v8, v8, 0x1

    goto :goto_1c

    :cond_3e
    add-int/lit8 v7, v7, 0x1

    goto :goto_19

    :cond_41
    sget-object v0, Landroid/graphics/Bitmap$Config;->ARGB_8888:Landroid/graphics/Bitmap$Config;

    invoke-static {v12, v12, v0}, Landroid/graphics/Bitmap;->createBitmap(IILandroid/graphics/Bitmap$Config;)Landroid/graphics/Bitmap;

    move-result-object v0

    const/4 v7, 0x0

    const/4 v9, 0x0

    const/4 v10, 0x0

    move-object v5, v0

    move v8, v12

    move v11, v12

    invoke-virtual/range {v5 .. v12}, Landroid/graphics/Bitmap;->setPixels([IIIIIII)V

    return-object v0
.end method

.method public static a(Landroid/graphics/Bitmap;)Lcom/google/android/gms/maps/model/Tile;
    .registers 4

    new-instance v0, Ljava/io/ByteArrayOutputStream;

    invoke-direct {v0}, Ljava/io/ByteArrayOutputStream;-><init>()V

    sget-object v1, Landroid/graphics/Bitmap$CompressFormat;->PNG:Landroid/graphics/Bitmap$CompressFormat;

    const/16 v2, 0x64

    invoke-virtual {p0, v1, v2, v0}, Landroid/graphics/Bitmap;->compress(Landroid/graphics/Bitmap$CompressFormat;ILjava/io/OutputStream;)Z

    invoke-virtual {v0}, Ljava/io/ByteArrayOutputStream;->toByteArray()[B

    move-result-object p0

    new-instance v0, Lcom/google/android/gms/maps/model/Tile;

    const/16 v1, 0x200

    invoke-direct {v0, v1, v1, p0}, Lcom/google/android/gms/maps/model/Tile;-><init>(II[B)V

    return-object v0
.end method

.method public static a(ID)[D
    .registers 10

    mul-int/lit8 v0, p0, 0x2

    add-int/lit8 v0, v0, 0x1

    new-array v0, v0, [D

    neg-int v1, p0

    :goto_7
    if-gt v1, p0, :cond_22

    add-int v2, v1, p0

    neg-int v3, v1

    mul-int v3, v3, v1

    int-to-double v3, v3

    const-wide/high16 v5, 0x4000000000000000L    # 2.0

    mul-double v5, v5, p1

    mul-double v5, v5, p1

    invoke-static {v3, v4}, Ljava/lang/Double;->isNaN(D)Z

    div-double/2addr v3, v5

    invoke-static {v3, v4}, Ljava/lang/Math;->exp(D)D

    move-result-wide v3

    aput-wide v3, v0, v2

    add-int/lit8 v1, v1, 0x1

    goto :goto_7

    :cond_22
    return-object v0
.end method

.method public static a([[D[D)[[D
    .registers 27

    move-object/from16 v0, p0

    move-object/from16 v1, p1

    const-class v2, D

    array-length v3, v1

    int-to-double v3, v3

    const-wide/high16 v5, 0x4000000000000000L    # 2.0

    invoke-static {v3, v4}, Ljava/lang/Double;->isNaN(D)Z

    div-double/2addr v3, v5

    invoke-static {v3, v4}, Ljava/lang/Math;->floor(D)D

    move-result-wide v3

    double-to-int v3, v3

    array-length v4, v0

    mul-int/lit8 v5, v3, 0x2

    sub-int v5, v4, v5

    add-int v6, v3, v5

    const/4 v7, 0x1

    sub-int/2addr v6, v7

    const/4 v8, 0x2

    new-array v9, v8, [I

    aput v4, v9, v7

    const/4 v10, 0x0

    aput v4, v9, v10

    invoke-static {v2, v9}, Ljava/lang/reflect/Array;->newInstance(Ljava/lang/Class;[I)Ljava/lang/Object;

    move-result-object v9

    check-cast v9, [[D

    const/4 v11, 0x0

    :goto_2b
    const-wide/16 v12, 0x0

    if-ge v11, v4, :cond_62

    const/4 v14, 0x0

    :goto_30
    if-ge v14, v4, :cond_5f

    aget-object v15, v0, v11

    aget-wide v16, v15, v14

    cmpl-double v15, v16, v12

    if-eqz v15, :cond_5a

    add-int v15, v11, v3

    if-ge v6, v15, :cond_3f

    move v15, v6

    :cond_3f
    add-int/2addr v15, v7

    sub-int v12, v11, v3

    if-le v3, v12, :cond_46

    move v13, v3

    goto :goto_47

    :cond_46
    move v13, v12

    :goto_47
    if-ge v13, v15, :cond_5a

    aget-object v20, v9, v13

    aget-wide v21, v20, v14

    sub-int v23, v13, v12

    aget-wide v23, v1, v23

    mul-double v23, v23, v16

    add-double v21, v21, v23

    aput-wide v21, v20, v14

    add-int/lit8 v13, v13, 0x1

    goto :goto_47

    :cond_5a
    add-int/lit8 v14, v14, 0x1

    const-wide/16 v12, 0x0

    goto :goto_30

    :cond_5f
    add-int/lit8 v11, v11, 0x1

    goto :goto_2b

    :cond_62
    new-array v0, v8, [I

    aput v5, v0, v7

    aput v5, v0, v10

    invoke-static {v2, v0}, Ljava/lang/reflect/Array;->newInstance(Ljava/lang/Class;[I)Ljava/lang/Object;

    move-result-object v0

    check-cast v0, [[D

    move v2, v3

    :goto_6f
    add-int/lit8 v5, v6, 0x1

    if-ge v2, v5, :cond_b2

    const/4 v5, 0x0

    :goto_74
    if-ge v5, v4, :cond_ac

    aget-object v8, v9, v2

    aget-wide v11, v8, v5

    const-wide/16 v13, 0x0

    cmpl-double v8, v11, v13

    if-eqz v8, :cond_a8

    add-int v8, v5, v3

    if-ge v6, v8, :cond_85

    move v8, v6

    :cond_85
    add-int/2addr v8, v7

    sub-int v15, v5, v3

    if-le v3, v15, :cond_8d

    move/from16 v16, v3

    goto :goto_8f

    :cond_8d
    move/from16 v16, v15

    :goto_8f
    move/from16 v7, v16

    :goto_91
    if-ge v7, v8, :cond_a8

    sub-int v16, v2, v3

    aget-object v16, v0, v16

    sub-int v18, v7, v3

    aget-wide v19, v16, v18

    sub-int v21, v7, v15

    aget-wide v21, v1, v21

    mul-double v21, v21, v11

    add-double v19, v19, v21

    aput-wide v19, v16, v18

    add-int/lit8 v7, v7, 0x1

    goto :goto_91

    :cond_a8
    add-int/lit8 v5, v5, 0x1

    const/4 v7, 0x1

    goto :goto_74

    :cond_ac
    const-wide/16 v13, 0x0

    add-int/lit8 v2, v2, 0x1

    const/4 v7, 0x1

    goto :goto_6f

    :cond_b2
    return-object v0
.end method

.method public static b(Ljava/util/Collection;)Lb6/a;
    .registers 20
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Ljava/util/Collection<",
            "Lc6/c;",
            ">;)",
            "Lb6/a;"
        }
    .end annotation

    invoke-interface/range {p0 .. p0}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;

    move-result-object v0

    invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v1

    check-cast v1, Lc6/c;

    invoke-virtual {v1}, Lc6/c;->a()Lb6/b;

    move-result-object v2

    iget-wide v2, v2, Lb6/b;->a:D

    invoke-virtual {v1}, Lc6/c;->a()Lb6/b;

    move-result-object v4

    iget-wide v4, v4, Lb6/b;->a:D

    invoke-virtual {v1}, Lc6/c;->a()Lb6/b;

    move-result-object v6

    iget-wide v6, v6, Lb6/b;->b:D

    invoke-virtual {v1}, Lc6/c;->a()Lb6/b;

    move-result-object v1

    iget-wide v8, v1, Lb6/b;->b:D

    move-wide v11, v2

    move-wide v13, v4

    move-wide v15, v6

    move-wide/from16 v17, v8

    :cond_27
    :goto_27
    invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z

    move-result v1

    if-eqz v1, :cond_55

    invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v1

    check-cast v1, Lc6/c;

    invoke-virtual {v1}, Lc6/c;->a()Lb6/b;

    move-result-object v2

    iget-wide v2, v2, Lb6/b;->a:D

    invoke-virtual {v1}, Lc6/c;->a()Lb6/b;

    move-result-object v1

    iget-wide v4, v1, Lb6/b;->b:D

    cmpg-double v1, v2, v11

    if-gez v1, :cond_44

    move-wide v11, v2

    :cond_44
    cmpl-double v1, v2, v13

    if-lez v1, :cond_49

    move-wide v13, v2

    :cond_49
    cmpg-double v1, v4, v15

    if-gez v1, :cond_4e

    move-wide v15, v4

    :cond_4e
    cmpl-double v1, v4, v17

    if-lez v1, :cond_27

    move-wide/from16 v17, v4

    goto :goto_27

    :cond_55
    new-instance v0, Lb6/a;

    move-object v10, v0

    invoke-direct/range {v10 .. v18}, Lb6/a;-><init>(DDDD)V

    return-object v0
.end method


# virtual methods
.method public a(D)V
    .registers 3

    iput-wide p1, p0, Lc6/b;->h:D

    iget-object p1, p0, Lc6/b;->e:Lc6/a;

    invoke-virtual {p0, p1}, Lc6/b;->a(Lc6/a;)V

    return-void
.end method

.method public a(Lc6/a;)V
    .registers 4

    iput-object p1, p0, Lc6/b;->e:Lc6/a;

    iget-wide v0, p0, Lc6/b;->h:D

    invoke-virtual {p1, v0, v1}, Lc6/a;->a(D)[I

    move-result-object p1

    iput-object p1, p0, Lc6/b;->f:[I

    return-void
.end method

.method public a(Ljava/util/Collection;)V
    .registers 4
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Ljava/util/Collection<",
            "Lc6/c;",
            ">;)V"
        }
    .end annotation

    iput-object p1, p0, Lc6/b;->b:Ljava/util/Collection;

    invoke-interface {p1}, Ljava/util/Collection;->isEmpty()Z

    move-result p1

    if-nez p1, :cond_38

    iget-object p1, p0, Lc6/b;->b:Ljava/util/Collection;

    invoke-static {p1}, Lc6/b;->b(Ljava/util/Collection;)Lb6/a;

    move-result-object p1

    iput-object p1, p0, Lc6/b;->c:Lb6/a;

    new-instance v0, Le6/a;

    invoke-direct {v0, p1}, Le6/a;-><init>(Lb6/a;)V

    iput-object v0, p0, Lc6/b;->a:Le6/a;

    iget-object p1, p0, Lc6/b;->b:Ljava/util/Collection;

    invoke-interface {p1}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;

    move-result-object p1

    :goto_1d
    invoke-interface {p1}, Ljava/util/Iterator;->hasNext()Z

    move-result v0

    if-eqz v0, :cond_2f

    invoke-interface {p1}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lc6/c;

    iget-object v1, p0, Lc6/b;->a:Le6/a;

    invoke-virtual {v1, v0}, Le6/a;->a(Le6/a$a;)V

    goto :goto_1d

    :cond_2f
    iget p1, p0, Lc6/b;->d:I

    invoke-virtual {p0, p1}, Lc6/b;->a(I)[D

    move-result-object p1

    iput-object p1, p0, Lc6/b;->i:[D

    return-void

    :cond_38
    new-instance p1, Ljava/lang/IllegalArgumentException;

    const-string v0, "No input points."

    invoke-direct {p1, v0}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V

    goto :goto_41

    :goto_40
    throw p1

    :goto_41
    goto :goto_40
.end method

.method public final a(I)[D
    .registers 14

    const/16 v0, 0x16

    new-array v1, v0, [D

    const/4 v2, 0x5

    const/4 v3, 0x5

    :goto_6
    const/16 v4, 0xb

    if-ge v3, v4, :cond_31

    iget-object v4, p0, Lc6/b;->b:Ljava/util/Collection;

    iget-object v5, p0, Lc6/b;->c:Lb6/a;

    const-wide/high16 v6, 0x4094000000000000L    # 1280.0

    const-wide/high16 v8, 0x4000000000000000L    # 2.0

    add-int/lit8 v10, v3, -0x3

    int-to-double v10, v10

    invoke-static {v8, v9, v10, v11}, Ljava/lang/Math;->pow(DD)D

    move-result-wide v8

    mul-double v8, v8, v6

    double-to-int v6, v8

    invoke-static {v4, v5, p1, v6}, Lc6/b;->a(Ljava/util/Collection;Lb6/a;II)D

    move-result-wide v4

    aput-wide v4, v1, v3

    if-ne v3, v2, :cond_2e

    const/4 v4, 0x0

    :goto_25
    if-ge v4, v3, :cond_2e

    aget-wide v5, v1, v3

    aput-wide v5, v1, v4

    add-int/lit8 v4, v4, 0x1

    goto :goto_25

    :cond_2e
    add-int/lit8 v3, v3, 0x1

    goto :goto_6

    :cond_31
    :goto_31
    if-ge v4, v0, :cond_3c

    const/16 p1, 0xa

    aget-wide v2, v1, p1

    aput-wide v2, v1, v4

    add-int/lit8 v4, v4, 0x1

    goto :goto_31

    :cond_3c
    return-object v1
.end method

.method public b(I)V
    .registers 6

    iput p1, p0, Lc6/b;->d:I

    int-to-double v0, p1

    const-wide/high16 v2, 0x4008000000000000L    # 3.0

    invoke-static {v0, v1}, Ljava/lang/Double;->isNaN(D)Z

    div-double/2addr v0, v2

    invoke-static {p1, v0, v1}, Lc6/b;->a(ID)[D

    move-result-object p1

    iput-object p1, p0, Lc6/b;->g:[D

    iget p1, p0, Lc6/b;->d:I

    invoke-virtual {p0, p1}, Lc6/b;->a(I)[D

    move-result-object p1

    iput-object p1, p0, Lc6/b;->i:[D

    return-void
.end method

.method public getTile(III)Lcom/google/android/gms/maps/model/Tile;
    .registers 40

    move-object/from16 v0, p0

    move/from16 v1, p1

    move/from16 v2, p2

    move/from16 v3, p3

    int-to-double v4, v3

    const-wide/high16 v6, 0x4000000000000000L    # 2.0

    invoke-static {v6, v7, v4, v5}, Ljava/lang/Math;->pow(DD)D

    move-result-wide v4

    const-wide/high16 v8, 0x3ff0000000000000L    # 1.0

    div-double v4, v8, v4

    iget v10, v0, Lc6/b;->d:I

    int-to-double v11, v10

    invoke-static {v11, v12}, Ljava/lang/Double;->isNaN(D)Z

    mul-double v11, v11, v4

    const-wide/high16 v13, 0x4080000000000000L    # 512.0

    div-double/2addr v11, v13

    mul-double v6, v6, v11

    add-double/2addr v6, v4

    const/4 v13, 0x2

    mul-int/lit8 v10, v10, 0x2

    add-int/lit16 v10, v10, 0x200

    int-to-double v14, v10

    invoke-static {v14, v15}, Ljava/lang/Double;->isNaN(D)Z

    div-double/2addr v6, v14

    int-to-double v14, v1

    invoke-static {v14, v15}, Ljava/lang/Double;->isNaN(D)Z

    mul-double v14, v14, v4

    sub-double/2addr v14, v11

    const/4 v10, 0x1

    add-int/2addr v1, v10

    int-to-double v8, v1

    invoke-static {v8, v9}, Ljava/lang/Double;->isNaN(D)Z

    mul-double v8, v8, v4

    add-double v19, v8, v11

    int-to-double v8, v2

    invoke-static {v8, v9}, Ljava/lang/Double;->isNaN(D)Z

    mul-double v8, v8, v4

    sub-double/2addr v8, v11

    add-int/lit8 v1, v2, 0x1

    int-to-double v1, v1

    invoke-static {v1, v2}, Ljava/lang/Double;->isNaN(D)Z

    mul-double v1, v1, v4

    add-double/2addr v1, v11

    new-instance v4, Ljava/util/ArrayList;

    invoke-direct {v4}, Ljava/util/ArrayList;-><init>()V

    const-wide/16 v21, 0x0

    cmpg-double v5, v14, v21

    if-gez v5, :cond_73

    new-instance v4, Lb6/a;

    const-wide/high16 v16, 0x3ff0000000000000L    # 1.0

    add-double v22, v14, v16

    const-wide/high16 v24, 0x3ff0000000000000L    # 1.0

    move-object/from16 v21, v4

    move-wide/from16 v26, v8

    move-wide/from16 v28, v1

    invoke-direct/range {v21 .. v29}, Lb6/a;-><init>(DDDD)V

    const-wide/high16 v16, -0x4010000000000000L    # -1.0

    iget-object v5, v0, Lc6/b;->a:Le6/a;

    invoke-virtual {v5, v4}, Le6/a;->a(Lb6/a;)Ljava/util/Collection;

    move-result-object v4

    :goto_70
    move-wide/from16 v25, v16

    goto :goto_91

    :cond_73
    const-wide/high16 v16, 0x3ff0000000000000L    # 1.0

    cmpl-double v5, v19, v16

    if-lez v5, :cond_8f

    new-instance v4, Lb6/a;

    const-wide/16 v22, 0x0

    sub-double v24, v19, v16

    move-object/from16 v21, v4

    move-wide/from16 v26, v8

    move-wide/from16 v28, v1

    invoke-direct/range {v21 .. v29}, Lb6/a;-><init>(DDDD)V

    iget-object v5, v0, Lc6/b;->a:Le6/a;

    invoke-virtual {v5, v4}, Le6/a;->a(Lb6/a;)Ljava/util/Collection;

    move-result-object v4

    goto :goto_70

    :cond_8f
    move-wide/from16 v25, v21

    :goto_91
    new-instance v5, Lb6/a;

    move-object/from16 v16, v5

    move-wide/from16 v17, v14

    move-wide/from16 v21, v8

    move-wide/from16 v23, v1

    invoke-direct/range {v16 .. v24}, Lb6/a;-><init>(DDDD)V

    new-instance v1, Lb6/a;

    iget-object v2, v0, Lc6/b;->c:Lb6/a;

    iget-wide v13, v2, Lb6/a;->a:D

    sub-double v28, v13, v11

    iget-wide v13, v2, Lb6/a;->c:D

    add-double v30, v13, v11

    iget-wide v13, v2, Lb6/a;->b:D

    sub-double v32, v13, v11

    iget-wide v13, v2, Lb6/a;->d:D

    add-double v34, v13, v11

    move-object/from16 v27, v1

    invoke-direct/range {v27 .. v35}, Lb6/a;-><init>(DDDD)V

    invoke-virtual {v5, v1}, Lb6/a;->b(Lb6/a;)Z

    move-result v1

    if-nez v1, :cond_c0

    sget-object v1, Lcom/google/android/gms/maps/model/TileProvider;->NO_TILE:Lcom/google/android/gms/maps/model/Tile;

    return-object v1

    :cond_c0
    iget-object v1, v0, Lc6/b;->a:Le6/a;

    invoke-virtual {v1, v5}, Le6/a;->a(Lb6/a;)Ljava/util/Collection;

    move-result-object v1

    invoke-interface {v1}, Ljava/util/Collection;->isEmpty()Z

    move-result v2

    if-eqz v2, :cond_cf

    sget-object v1, Lcom/google/android/gms/maps/model/TileProvider;->NO_TILE:Lcom/google/android/gms/maps/model/Tile;

    return-object v1

    :cond_cf
    iget v2, v0, Lc6/b;->d:I

    mul-int/lit8 v5, v2, 0x2

    add-int/lit16 v5, v5, 0x200

    const/4 v11, 0x2

    mul-int/lit8 v2, v2, 0x2

    add-int/lit16 v2, v2, 0x200

    new-array v11, v11, [I

    aput v2, v11, v10

    const/4 v2, 0x0

    aput v5, v11, v2

    const-class v2, D

    invoke-static {v2, v11}, Ljava/lang/reflect/Array;->newInstance(Ljava/lang/Class;[I)Ljava/lang/Object;

    move-result-object v2

    check-cast v2, [[D

    invoke-interface {v1}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;

    move-result-object v1

    :goto_ed
    invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z

    move-result v5

    if-eqz v5, :cond_114

    invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v5

    check-cast v5, Lc6/c;

    invoke-virtual {v5}, Lc6/c;->a()Lb6/b;

    move-result-object v10

    iget-wide v11, v10, Lb6/b;->a:D

    sub-double v11, v11, v17

    div-double/2addr v11, v6

    double-to-int v11, v11

    iget-wide v12, v10, Lb6/b;->b:D

    sub-double/2addr v12, v8

    div-double/2addr v12, v6

    double-to-int v10, v12

    aget-object v11, v2, v11

    aget-wide v12, v11, v10

    invoke-virtual {v5}, Lc6/c;->b()D

    move-result-wide v14

    add-double/2addr v12, v14

    aput-wide v12, v11, v10

    goto :goto_ed

    :cond_114
    invoke-interface {v4}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;

    move-result-object v1

    :goto_118
    invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z

    move-result v4

    if-eqz v4, :cond_141

    invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v4

    check-cast v4, Lc6/c;

    invoke-virtual {v4}, Lc6/c;->a()Lb6/b;

    move-result-object v5

    iget-wide v10, v5, Lb6/b;->a:D

    add-double v10, v10, v25

    sub-double v10, v10, v17

    div-double/2addr v10, v6

    double-to-int v10, v10

    iget-wide v11, v5, Lb6/b;->b:D

    sub-double/2addr v11, v8

    div-double/2addr v11, v6

    double-to-int v5, v11

    aget-object v10, v2, v10

    aget-wide v11, v10, v5

    invoke-virtual {v4}, Lc6/c;->b()D

    move-result-wide v13

    add-double/2addr v11, v13

    aput-wide v11, v10, v5

    goto :goto_118

    :cond_141
    iget-object v1, v0, Lc6/b;->g:[D

    invoke-static {v2, v1}, Lc6/b;->a([[D[D)[[D

    move-result-object v1

    iget-object v2, v0, Lc6/b;->f:[I

    iget-object v4, v0, Lc6/b;->i:[D

    aget-wide v3, v4, v3

    invoke-static {v1, v2, v3, v4}, Lc6/b;->a([[D[ID)Landroid/graphics/Bitmap;

    move-result-object v1

    invoke-static {v1}, Lc6/b;->a(Landroid/graphics/Bitmap;)Lcom/google/android/gms/maps/model/Tile;

    move-result-object v1

    return-object v1
.end method