a.smali

.class Lb/b/a/a/a;
.super Lb/b/a/a/b;
.source "ArcCurveFit.java"


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


# instance fields
.field private final a:[D

.field b:[Lb/b/a/a/a$a;


# direct methods
.method public constructor <init>([I[D[[D)V
    .registers 28

    move-object/from16 v0, p0

    move-object/from16 v1, p2

    .line 1
    invoke-direct/range {p0 .. p0}, Lb/b/a/a/b;-><init>()V

    .line 2
    iput-object v1, v0, Lb/b/a/a/a;->a:[D

    .line 3
    array-length v2, v1

    const/4 v3, 0x1

    sub-int/2addr v2, v3

    new-array v2, v2, [Lb/b/a/a/a$a;

    iput-object v2, v0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    const/4 v2, 0x0

    const/4 v4, 0x0

    const/4 v5, 0x1

    const/4 v6, 0x1

    .line 4
    :goto_14
    iget-object v7, v0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    array-length v7, v7

    if-ge v4, v7, :cond_57

    .line 5
    aget v7, p1, v4

    const/4 v8, 0x3

    const/4 v9, 0x2

    if-eqz v7, :cond_32

    if-eq v7, v3, :cond_2f

    if-eq v7, v9, :cond_2d

    if-eq v7, v8, :cond_27

    move v9, v6

    goto :goto_33

    :cond_27
    if-ne v5, v3, :cond_2a

    goto :goto_2b

    :cond_2a
    const/4 v9, 0x1

    :goto_2b
    move v5, v9

    goto :goto_33

    :cond_2d
    const/4 v5, 0x2

    goto :goto_33

    :cond_2f
    const/4 v5, 0x1

    const/4 v9, 0x1

    goto :goto_33

    :cond_32
    const/4 v9, 0x3

    .line 6
    :goto_33
    iget-object v6, v0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    new-instance v7, Lb/b/a/a/a$a;

    aget-wide v12, v1, v4

    add-int/lit8 v8, v4, 0x1

    aget-wide v14, v1, v8

    aget-object v10, p3, v4

    aget-wide v16, v10, v2

    aget-object v10, p3, v4

    aget-wide v18, v10, v3

    aget-object v10, p3, v8

    aget-wide v20, v10, v2

    aget-object v10, p3, v8

    aget-wide v22, v10, v3

    move-object v10, v7

    move v11, v9

    invoke-direct/range {v10 .. v23}, Lb/b/a/a/a$a;-><init>(IDDDDDD)V

    aput-object v7, v6, v4

    move v4, v8

    move v6, v9

    goto :goto_14

    :cond_57
    return-void
.end method


# virtual methods
.method public a(DI)D
    .registers 9

    .line 25
    iget-object v0, p0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    const/4 v1, 0x0

    aget-object v2, v0, v1

    iget-wide v2, v2, Lb/b/a/a/a$a;->d:D

    cmpg-double v4, p1, v2

    if-gez v4, :cond_10

    .line 26
    aget-object p1, v0, v1

    iget-wide p1, p1, Lb/b/a/a/a$a;->d:D

    goto :goto_22

    .line 27
    :cond_10
    array-length v2, v0

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

    aget-object v2, v0, v2

    iget-wide v2, v2, Lb/b/a/a/a$a;->e:D

    cmpl-double v4, p1, v2

    if-lez v4, :cond_22

    .line 28
    array-length p1, v0

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

    aget-object p1, v0, p1

    iget-wide p1, p1, Lb/b/a/a/a$a;->e:D

    .line 29
    :cond_22
    :goto_22
    iget-object v0, p0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    array-length v2, v0

    if-ge v1, v2, :cond_61

    .line 30
    aget-object v2, v0, v1

    iget-wide v2, v2, Lb/b/a/a/a$a;->e:D

    cmpg-double v4, p1, v2

    if-gtz v4, :cond_5e

    .line 31
    aget-object v2, v0, v1

    iget-boolean v2, v2, Lb/b/a/a/a$a;->s:Z

    if-eqz v2, :cond_45

    if-nez p3, :cond_3e

    .line 32
    aget-object p3, v0, v1

    invoke-virtual {p3, p1, p2}, Lb/b/a/a/a$a;->c(D)D

    move-result-wide p1

    return-wide p1

    .line 33
    :cond_3e
    aget-object p3, v0, v1

    invoke-virtual {p3, p1, p2}, Lb/b/a/a/a$a;->d(D)D

    move-result-wide p1

    return-wide p1

    .line 34
    :cond_45
    aget-object v0, v0, v1

    invoke-virtual {v0, p1, p2}, Lb/b/a/a/a$a;->f(D)V

    if-nez p3, :cond_55

    .line 35
    iget-object p1, p0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    aget-object p1, p1, v1

    invoke-virtual {p1}, Lb/b/a/a/a$a;->c()D

    move-result-wide p1

    return-wide p1

    .line 36
    :cond_55
    iget-object p1, p0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    aget-object p1, p1, v1

    invoke-virtual {p1}, Lb/b/a/a/a$a;->d()D

    move-result-wide p1

    return-wide p1

    :cond_5e
    add-int/lit8 v1, v1, 0x1

    goto :goto_22

    :cond_61
    const-wide/high16 p1, 0x7ff8000000000000L    # Double.NaN

    return-wide p1
.end method

.method public a(D[D)V
    .registers 11

    .line 1
    iget-object v0, p0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    const/4 v1, 0x0

    aget-object v2, v0, v1

    iget-wide v2, v2, Lb/b/a/a/a$a;->d:D

    cmpg-double v4, p1, v2

    if-gez v4, :cond_f

    .line 2
    aget-object p1, v0, v1

    iget-wide p1, p1, Lb/b/a/a/a$a;->d:D

    .line 3
    :cond_f
    iget-object v0, p0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    array-length v2, v0

    const/4 v3, 0x1

    sub-int/2addr v2, v3

    aget-object v2, v0, v2

    iget-wide v4, v2, Lb/b/a/a/a$a;->e:D

    cmpl-double v2, p1, v4

    if-lez v2, :cond_22

    .line 4
    array-length p1, v0

    sub-int/2addr p1, v3

    aget-object p1, v0, p1

    iget-wide p1, p1, Lb/b/a/a/a$a;->e:D

    :cond_22
    const/4 v0, 0x0

    .line 5
    :goto_23
    iget-object v2, p0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    array-length v4, v2

    if-ge v0, v4, :cond_66

    .line 6
    aget-object v4, v2, v0

    iget-wide v4, v4, Lb/b/a/a/a$a;->e:D

    cmpg-double v6, p1, v4

    if-gtz v6, :cond_63

    .line 7
    aget-object v4, v2, v0

    iget-boolean v4, v4, Lb/b/a/a/a$a;->s:Z

    if-eqz v4, :cond_49

    .line 8
    aget-object v2, v2, v0

    invoke-virtual {v2, p1, p2}, Lb/b/a/a/a$a;->c(D)D

    move-result-wide v4

    aput-wide v4, p3, v1

    .line 9
    iget-object v1, p0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    aget-object v0, v1, v0

    invoke-virtual {v0, p1, p2}, Lb/b/a/a/a$a;->d(D)D

    move-result-wide p1

    aput-wide p1, p3, v3

    return-void

    .line 10
    :cond_49
    aget-object v2, v2, v0

    invoke-virtual {v2, p1, p2}, Lb/b/a/a/a$a;->f(D)V

    .line 11
    iget-object p1, p0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    aget-object p1, p1, v0

    invoke-virtual {p1}, Lb/b/a/a/a$a;->c()D

    move-result-wide p1

    aput-wide p1, p3, v1

    .line 12
    iget-object p1, p0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    aget-object p1, p1, v0

    invoke-virtual {p1}, Lb/b/a/a/a$a;->d()D

    move-result-wide p1

    aput-wide p1, p3, v3

    return-void

    :cond_63
    add-int/lit8 v0, v0, 0x1

    goto :goto_23

    :cond_66
    return-void
.end method

.method public a(D[F)V
    .registers 11

    .line 13
    iget-object v0, p0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    const/4 v1, 0x0

    aget-object v2, v0, v1

    iget-wide v2, v2, Lb/b/a/a/a$a;->d:D

    const/4 v4, 0x1

    cmpg-double v5, p1, v2

    if-gez v5, :cond_11

    .line 14
    aget-object p1, v0, v1

    iget-wide p1, p1, Lb/b/a/a/a$a;->d:D

    goto :goto_21

    .line 15
    :cond_11
    array-length v2, v0

    sub-int/2addr v2, v4

    aget-object v2, v0, v2

    iget-wide v2, v2, Lb/b/a/a/a$a;->e:D

    cmpl-double v5, p1, v2

    if-lez v5, :cond_21

    .line 16
    array-length p1, v0

    sub-int/2addr p1, v4

    aget-object p1, v0, p1

    iget-wide p1, p1, Lb/b/a/a/a$a;->e:D

    :cond_21
    :goto_21
    const/4 v0, 0x0

    .line 17
    :goto_22
    iget-object v2, p0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    array-length v3, v2

    if-ge v0, v3, :cond_69

    .line 18
    aget-object v3, v2, v0

    iget-wide v5, v3, Lb/b/a/a/a$a;->e:D

    cmpg-double v3, p1, v5

    if-gtz v3, :cond_66

    .line 19
    aget-object v3, v2, v0

    iget-boolean v3, v3, Lb/b/a/a/a$a;->s:Z

    if-eqz v3, :cond_4a

    .line 20
    aget-object v2, v2, v0

    invoke-virtual {v2, p1, p2}, Lb/b/a/a/a$a;->c(D)D

    move-result-wide v2

    double-to-float v2, v2

    aput v2, p3, v1

    .line 21
    iget-object v1, p0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    aget-object v0, v1, v0

    invoke-virtual {v0, p1, p2}, Lb/b/a/a/a$a;->d(D)D

    move-result-wide p1

    double-to-float p1, p1

    aput p1, p3, v4

    return-void

    .line 22
    :cond_4a
    aget-object v2, v2, v0

    invoke-virtual {v2, p1, p2}, Lb/b/a/a/a$a;->f(D)V

    .line 23
    iget-object p1, p0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    aget-object p1, p1, v0

    invoke-virtual {p1}, Lb/b/a/a/a$a;->c()D

    move-result-wide p1

    double-to-float p1, p1

    aput p1, p3, v1

    .line 24
    iget-object p1, p0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    aget-object p1, p1, v0

    invoke-virtual {p1}, Lb/b/a/a/a$a;->d()D

    move-result-wide p1

    double-to-float p1, p1

    aput p1, p3, v4

    return-void

    :cond_66
    add-int/lit8 v0, v0, 0x1

    goto :goto_22

    :cond_69
    return-void
.end method

.method public a()[D
    .registers 2

    .line 37
    iget-object v0, p0, Lb/b/a/a/a;->a:[D

    return-object v0
.end method

.method public b(DI)D
    .registers 9

    .line 13
    iget-object v0, p0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    const/4 v1, 0x0

    aget-object v2, v0, v1

    iget-wide v2, v2, Lb/b/a/a/a$a;->d:D

    cmpg-double v4, p1, v2

    if-gez v4, :cond_f

    .line 14
    aget-object p1, v0, v1

    iget-wide p1, p1, Lb/b/a/a/a$a;->d:D

    .line 15
    :cond_f
    iget-object v0, p0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    array-length v2, v0

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

    aget-object v2, v0, v2

    iget-wide v2, v2, Lb/b/a/a/a$a;->e:D

    cmpl-double v4, p1, v2

    if-lez v4, :cond_23

    .line 16
    array-length p1, v0

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

    aget-object p1, v0, p1

    iget-wide p1, p1, Lb/b/a/a/a$a;->e:D

    .line 17
    :cond_23
    :goto_23
    iget-object v0, p0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    array-length v2, v0

    if-ge v1, v2, :cond_62

    .line 18
    aget-object v2, v0, v1

    iget-wide v2, v2, Lb/b/a/a/a$a;->e:D

    cmpg-double v4, p1, v2

    if-gtz v4, :cond_5f

    .line 19
    aget-object v2, v0, v1

    iget-boolean v2, v2, Lb/b/a/a/a$a;->s:Z

    if-eqz v2, :cond_46

    if-nez p3, :cond_3f

    .line 20
    aget-object p3, v0, v1

    invoke-virtual {p3, p1, p2}, Lb/b/a/a/a$a;->a(D)D

    move-result-wide p1

    return-wide p1

    .line 21
    :cond_3f
    aget-object p3, v0, v1

    invoke-virtual {p3, p1, p2}, Lb/b/a/a/a$a;->b(D)D

    move-result-wide p1

    return-wide p1

    .line 22
    :cond_46
    aget-object v0, v0, v1

    invoke-virtual {v0, p1, p2}, Lb/b/a/a/a$a;->f(D)V

    if-nez p3, :cond_56

    .line 23
    iget-object p1, p0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    aget-object p1, p1, v1

    invoke-virtual {p1}, Lb/b/a/a/a$a;->a()D

    move-result-wide p1

    return-wide p1

    .line 24
    :cond_56
    iget-object p1, p0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    aget-object p1, p1, v1

    invoke-virtual {p1}, Lb/b/a/a/a$a;->b()D

    move-result-wide p1

    return-wide p1

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

    goto :goto_23

    :cond_62
    const-wide/high16 p1, 0x7ff8000000000000L    # Double.NaN

    return-wide p1
.end method

.method public b(D[D)V
    .registers 11

    .line 1
    iget-object v0, p0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    const/4 v1, 0x0

    aget-object v2, v0, v1

    iget-wide v2, v2, Lb/b/a/a/a$a;->d:D

    const/4 v4, 0x1

    cmpg-double v5, p1, v2

    if-gez v5, :cond_11

    .line 2
    aget-object p1, v0, v1

    iget-wide p1, p1, Lb/b/a/a/a$a;->d:D

    goto :goto_21

    .line 3
    :cond_11
    array-length v2, v0

    sub-int/2addr v2, v4

    aget-object v2, v0, v2

    iget-wide v2, v2, Lb/b/a/a/a$a;->e:D

    cmpl-double v5, p1, v2

    if-lez v5, :cond_21

    .line 4
    array-length p1, v0

    sub-int/2addr p1, v4

    aget-object p1, v0, p1

    iget-wide p1, p1, Lb/b/a/a/a$a;->e:D

    :cond_21
    :goto_21
    const/4 v0, 0x0

    .line 5
    :goto_22
    iget-object v2, p0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    array-length v3, v2

    if-ge v0, v3, :cond_65

    .line 6
    aget-object v3, v2, v0

    iget-wide v5, v3, Lb/b/a/a/a$a;->e:D

    cmpg-double v3, p1, v5

    if-gtz v3, :cond_62

    .line 7
    aget-object v3, v2, v0

    iget-boolean v3, v3, Lb/b/a/a/a$a;->s:Z

    if-eqz v3, :cond_48

    .line 8
    aget-object v2, v2, v0

    invoke-virtual {v2, p1, p2}, Lb/b/a/a/a$a;->a(D)D

    move-result-wide v2

    aput-wide v2, p3, v1

    .line 9
    iget-object v1, p0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    aget-object v0, v1, v0

    invoke-virtual {v0, p1, p2}, Lb/b/a/a/a$a;->b(D)D

    move-result-wide p1

    aput-wide p1, p3, v4

    return-void

    .line 10
    :cond_48
    aget-object v2, v2, v0

    invoke-virtual {v2, p1, p2}, Lb/b/a/a/a$a;->f(D)V

    .line 11
    iget-object p1, p0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    aget-object p1, p1, v0

    invoke-virtual {p1}, Lb/b/a/a/a$a;->a()D

    move-result-wide p1

    aput-wide p1, p3, v1

    .line 12
    iget-object p1, p0, Lb/b/a/a/a;->b:[Lb/b/a/a/a$a;

    aget-object p1, p1, v0

    invoke-virtual {p1}, Lb/b/a/a/a$a;->b()D

    move-result-wide p1

    aput-wide p1, p3, v4

    return-void

    :cond_62
    add-int/lit8 v0, v0, 0x1

    goto :goto_22

    :cond_65
    return-void
.end method