LinearCurveFit.smali

.class public Landroidx/constraintlayout/motion/utils/LinearCurveFit;
.super Landroidx/constraintlayout/motion/utils/CurveFit;
.source "LinearCurveFit.java"


# static fields
.field private static final TAG:Ljava/lang/String; = "LinearCurveFit"


# instance fields
.field private mT:[D

.field private mTotalLength:D

.field private mY:[[D


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

    return-void
.end method

.method public constructor <init>([D[[D)V
    .registers 24
    .param p1, "time"    # [D
    .param p2, "y"    # [[D

    .line 30
    move-object/from16 v0, p0

    move-object/from16 v1, p1

    move-object/from16 v2, p2

    invoke-direct/range {p0 .. p0}, Landroidx/constraintlayout/motion/utils/CurveFit;-><init>()V

    .line 28
    const-wide/high16 v3, 0x7ff8000000000000L    # Double.NaN

    iput-wide v3, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mTotalLength:D

    .line 31
    array-length v3, v1

    .line 32
    .local v3, "N":I
    const/4 v4, 0x0

    aget-object v5, v2, v4

    array-length v5, v5

    .line 33
    .local v5, "dim":I
    iput-object v1, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mT:[D

    .line 34
    iput-object v2, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mY:[[D

    .line 35
    const/4 v6, 0x2

    if-le v5, v6, :cond_50

    .line 36
    const-wide/16 v6, 0x0

    .line 37
    .local v6, "sum":D
    const-wide/16 v8, 0x0

    .local v8, "lastx":D
    const-wide/16 v10, 0x0

    .line 38
    .local v10, "lasty":D
    const/4 v12, 0x0

    .local v12, "i":I
    :goto_20
    array-length v13, v1

    if-ge v12, v13, :cond_49

    .line 39
    aget-object v13, v2, v12

    aget-wide v14, v13, v4

    .line 40
    .local v14, "px":D
    aget-object v13, v2, v12

    aget-wide v16, v13, v4

    .line 41
    .local v16, "py":D
    if-lez v12, :cond_3b

    .line 42
    move/from16 v18, v5

    .end local v5    # "dim":I
    .local v18, "dim":I
    sub-double v4, v14, v8

    move-wide/from16 v19, v14

    .end local v14    # "px":D
    .local v19, "px":D
    sub-double v13, v16, v10

    invoke-static {v4, v5, v13, v14}, Ljava/lang/Math;->hypot(DD)D

    move-result-wide v4

    add-double/2addr v6, v4

    goto :goto_3f

    .line 41
    .end local v18    # "dim":I
    .end local v19    # "px":D
    .restart local v5    # "dim":I
    .restart local v14    # "px":D
    :cond_3b
    move/from16 v18, v5

    move-wide/from16 v19, v14

    .line 44
    .end local v5    # "dim":I
    .end local v14    # "px":D
    .restart local v18    # "dim":I
    .restart local v19    # "px":D
    :goto_3f
    move-wide/from16 v8, v19

    .line 45
    move-wide/from16 v10, v16

    .line 38
    .end local v16    # "py":D
    .end local v19    # "px":D
    add-int/lit8 v12, v12, 0x1

    move/from16 v5, v18

    const/4 v4, 0x0

    goto :goto_20

    .end local v18    # "dim":I
    .restart local v5    # "dim":I
    :cond_49
    move/from16 v18, v5

    .line 47
    .end local v5    # "dim":I
    .end local v12    # "i":I
    .restart local v18    # "dim":I
    const-wide/16 v4, 0x0

    iput-wide v4, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mTotalLength:D

    goto :goto_52

    .line 35
    .end local v6    # "sum":D
    .end local v8    # "lastx":D
    .end local v10    # "lasty":D
    .end local v18    # "dim":I
    .restart local v5    # "dim":I
    :cond_50
    move/from16 v18, v5

    .line 49
    .end local v5    # "dim":I
    .restart local v18    # "dim":I
    :goto_52
    return-void
.end method

.method private getLength2D(D)D
    .registers 37
    .param p1, "t"    # D

    .line 58
    move-object/from16 v0, p0

    iget-wide v1, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mTotalLength:D

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

    move-result v1

    const-wide/16 v2, 0x0

    if-eqz v1, :cond_d

    .line 59
    return-wide v2

    .line 61
    :cond_d
    iget-object v1, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mT:[D

    array-length v4, v1

    .line 62
    .local v4, "n":I
    const/4 v5, 0x0

    aget-wide v6, v1, v5

    cmpg-double v8, p1, v6

    if-gtz v8, :cond_18

    .line 63
    return-wide v2

    .line 65
    :cond_18
    add-int/lit8 v6, v4, -0x1

    aget-wide v6, v1, v6

    cmpl-double v1, p1, v6

    if-ltz v1, :cond_23

    .line 66
    iget-wide v1, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mTotalLength:D

    return-wide v1

    .line 68
    :cond_23
    const-wide/16 v6, 0x0

    .line 69
    .local v6, "sum":D
    const-wide/16 v8, 0x0

    .local v8, "last_x":D
    const-wide/16 v10, 0x0

    .line 71
    .local v10, "last_y":D
    const/4 v1, 0x0

    .local v1, "i":I
    :goto_2a
    add-int/lit8 v12, v4, -0x1

    if-ge v1, v12, :cond_a7

    .line 72
    iget-object v12, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mY:[[D

    aget-object v13, v12, v1

    aget-wide v14, v13, v5

    .line 73
    .local v14, "px":D
    aget-object v12, v12, v1

    const/4 v13, 0x1

    aget-wide v16, v12, v13

    .line 74
    .local v16, "py":D
    if-lez v1, :cond_47

    .line 75
    sub-double v2, v14, v8

    move-wide/from16 v20, v14

    .end local v14    # "px":D
    .local v20, "px":D
    sub-double v13, v16, v10

    invoke-static {v2, v3, v13, v14}, Ljava/lang/Math;->hypot(DD)D

    move-result-wide v2

    add-double/2addr v6, v2

    goto :goto_49

    .line 74
    .end local v20    # "px":D
    .restart local v14    # "px":D
    :cond_47
    move-wide/from16 v20, v14

    .line 77
    .end local v14    # "px":D
    .restart local v20    # "px":D
    :goto_49
    move-wide/from16 v8, v20

    .line 78
    move-wide/from16 v10, v16

    .line 79
    iget-object v2, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mT:[D

    aget-wide v13, v2, v1

    cmpl-double v3, p1, v13

    if-nez v3, :cond_56

    .line 80
    return-wide v6

    .line 82
    :cond_56
    add-int/lit8 v3, v1, 0x1

    aget-wide v13, v2, v3

    cmpg-double v3, p1, v13

    if-gez v3, :cond_a1

    .line 83
    add-int/lit8 v3, v1, 0x1

    aget-wide v13, v2, v3

    aget-wide v18, v2, v1

    sub-double v13, v13, v18

    .line 84
    .local v13, "h":D
    aget-wide v18, v2, v1

    sub-double v2, p1, v18

    div-double/2addr v2, v13

    .line 85
    .local v2, "x":D
    iget-object v15, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mY:[[D

    aget-object v18, v15, v1

    aget-wide v22, v18, v5

    .line 86
    .local v22, "x1":D
    add-int/lit8 v18, v1, 0x1

    aget-object v18, v15, v18

    aget-wide v24, v18, v5

    .line 87
    .local v24, "x2":D
    aget-object v5, v15, v1

    const/4 v12, 0x1

    aget-wide v18, v5, v12

    .line 88
    .local v18, "y1":D
    add-int/lit8 v5, v1, 0x1

    aget-object v5, v15, v5

    aget-wide v26, v5, v12

    .line 90
    .local v26, "y2":D
    const-wide/high16 v28, 0x3ff0000000000000L    # 1.0

    sub-double v30, v28, v2

    mul-double v30, v30, v18

    mul-double v32, v26, v2

    add-double v30, v30, v32

    move v12, v4

    .end local v4    # "n":I
    .local v12, "n":I
    sub-double v4, v16, v30

    .line 91
    .end local v16    # "py":D
    .local v4, "py":D
    sub-double v28, v28, v2

    mul-double v28, v28, v22

    mul-double v15, v24, v2

    add-double v28, v28, v15

    move-wide/from16 v30, v2

    .end local v2    # "x":D
    .local v30, "x":D
    sub-double v2, v20, v28

    .line 92
    .end local v20    # "px":D
    .local v2, "px":D
    invoke-static {v4, v5, v2, v3}, Ljava/lang/Math;->hypot(DD)D

    move-result-wide v15

    add-double/2addr v6, v15

    .line 94
    return-wide v6

    .line 82
    .end local v2    # "px":D
    .end local v12    # "n":I
    .end local v13    # "h":D
    .end local v18    # "y1":D
    .end local v22    # "x1":D
    .end local v24    # "x2":D
    .end local v26    # "y2":D
    .end local v30    # "x":D
    .local v4, "n":I
    .restart local v16    # "py":D
    .restart local v20    # "px":D
    :cond_a1
    move v12, v4

    .line 71
    .end local v4    # "n":I
    .end local v16    # "py":D
    .end local v20    # "px":D
    .restart local v12    # "n":I
    add-int/lit8 v1, v1, 0x1

    const-wide/16 v2, 0x0

    goto :goto_2a

    .line 97
    .end local v1    # "i":I
    .end local v12    # "n":I
    .restart local v4    # "n":I
    :cond_a7
    const-wide/16 v1, 0x0

    return-wide v1
.end method


# virtual methods
.method public getPos(DI)D
    .registers 21
    .param p1, "t"    # D
    .param p3, "j"    # I

    .line 173
    move-object/from16 v0, p0

    iget-object v1, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mT:[D

    array-length v2, v1

    .line 174
    .local v2, "n":I
    const/4 v3, 0x0

    aget-wide v4, v1, v3

    cmpg-double v6, p1, v4

    if-gtz v6, :cond_13

    .line 175
    iget-object v1, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mY:[[D

    aget-object v1, v1, v3

    aget-wide v3, v1, p3

    return-wide v3

    .line 177
    :cond_13
    add-int/lit8 v3, v2, -0x1

    aget-wide v3, v1, v3

    cmpl-double v1, p1, v3

    if-ltz v1, :cond_24

    .line 178
    iget-object v1, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mY:[[D

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

    aget-object v1, v1, v3

    aget-wide v3, v1, p3

    return-wide v3

    .line 181
    :cond_24
    const/4 v1, 0x0

    .local v1, "i":I
    :goto_25
    add-int/lit8 v3, v2, -0x1

    if-ge v1, v3, :cond_64

    .line 182
    iget-object v3, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mT:[D

    aget-wide v4, v3, v1

    cmpl-double v6, p1, v4

    if-nez v6, :cond_38

    .line 183
    iget-object v3, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mY:[[D

    aget-object v3, v3, v1

    aget-wide v4, v3, p3

    return-wide v4

    .line 185
    :cond_38
    add-int/lit8 v4, v1, 0x1

    aget-wide v4, v3, v4

    cmpg-double v6, p1, v4

    if-gez v6, :cond_61

    .line 186
    add-int/lit8 v4, v1, 0x1

    aget-wide v4, v3, v4

    aget-wide v6, v3, v1

    sub-double/2addr v4, v6

    .line 187
    .local v4, "h":D
    aget-wide v6, v3, v1

    sub-double v6, p1, v6

    div-double/2addr v6, v4

    .line 188
    .local v6, "x":D
    iget-object v3, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mY:[[D

    aget-object v8, v3, v1

    aget-wide v9, v8, p3

    .line 189
    .local v9, "y1":D
    add-int/lit8 v8, v1, 0x1

    aget-object v3, v3, v8

    aget-wide v11, v3, p3

    .line 190
    .local v11, "y2":D
    const-wide/high16 v13, 0x3ff0000000000000L    # 1.0

    sub-double/2addr v13, v6

    mul-double v13, v13, v9

    mul-double v15, v11, v6

    add-double/2addr v13, v15

    return-wide v13

    .line 181
    .end local v4    # "h":D
    .end local v6    # "x":D
    .end local v9    # "y1":D
    .end local v11    # "y2":D
    :cond_61
    add-int/lit8 v1, v1, 0x1

    goto :goto_25

    .line 194
    .end local v1    # "i":I
    :cond_64
    const-wide/16 v3, 0x0

    return-wide v3
.end method

.method public getPos(D[D)V
    .registers 21
    .param p1, "t"    # D
    .param p3, "v"    # [D

    .line 101
    move-object/from16 v0, p0

    iget-object v1, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mT:[D

    array-length v2, v1

    .line 102
    .local v2, "n":I
    iget-object v3, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mY:[[D

    const/4 v4, 0x0

    aget-object v3, v3, v4

    array-length v3, v3

    .line 103
    .local v3, "dim":I
    aget-wide v5, v1, v4

    cmpg-double v7, p1, v5

    if-gtz v7, :cond_20

    .line 104
    const/4 v1, 0x0

    .local v1, "j":I
    :goto_12
    if-ge v1, v3, :cond_1f

    .line 105
    iget-object v5, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mY:[[D

    aget-object v5, v5, v4

    aget-wide v6, v5, v1

    aput-wide v6, p3, v1

    .line 104
    add-int/lit8 v1, v1, 0x1

    goto :goto_12

    .line 107
    .end local v1    # "j":I
    :cond_1f
    return-void

    .line 109
    :cond_20
    add-int/lit8 v4, v2, -0x1

    aget-wide v4, v1, v4

    cmpl-double v1, p1, v4

    if-ltz v1, :cond_39

    .line 110
    const/4 v1, 0x0

    .restart local v1    # "j":I
    :goto_29
    if-ge v1, v3, :cond_38

    .line 111
    iget-object v4, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mY:[[D

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

    aget-object v4, v4, v5

    aget-wide v5, v4, v1

    aput-wide v5, p3, v1

    .line 110
    add-int/lit8 v1, v1, 0x1

    goto :goto_29

    .line 113
    .end local v1    # "j":I
    :cond_38
    return-void

    .line 116
    :cond_39
    const/4 v1, 0x0

    .local v1, "i":I
    :goto_3a
    add-int/lit8 v4, v2, -0x1

    if-ge v1, v4, :cond_8a

    .line 117
    iget-object v4, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mT:[D

    aget-wide v5, v4, v1

    cmpl-double v4, p1, v5

    if-nez v4, :cond_54

    .line 118
    const/4 v4, 0x0

    .local v4, "j":I
    :goto_47
    if-ge v4, v3, :cond_54

    .line 119
    iget-object v5, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mY:[[D

    aget-object v5, v5, v1

    aget-wide v6, v5, v4

    aput-wide v6, p3, v4

    .line 118
    add-int/lit8 v4, v4, 0x1

    goto :goto_47

    .line 122
    .end local v4    # "j":I
    :cond_54
    iget-object v4, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mT:[D

    add-int/lit8 v5, v1, 0x1

    aget-wide v5, v4, v5

    cmpg-double v7, p1, v5

    if-gez v7, :cond_87

    .line 123
    add-int/lit8 v5, v1, 0x1

    aget-wide v5, v4, v5

    aget-wide v7, v4, v1

    sub-double/2addr v5, v7

    .line 124
    .local v5, "h":D
    aget-wide v7, v4, v1

    sub-double v7, p1, v7

    div-double/2addr v7, v5

    .line 125
    .local v7, "x":D
    const/4 v4, 0x0

    .restart local v4    # "j":I
    :goto_6b
    if-ge v4, v3, :cond_86

    .line 126
    iget-object v9, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mY:[[D

    aget-object v10, v9, v1

    aget-wide v11, v10, v4

    .line 127
    .local v11, "y1":D
    add-int/lit8 v10, v1, 0x1

    aget-object v9, v9, v10

    aget-wide v13, v9, v4

    .line 129
    .local v13, "y2":D
    const-wide/high16 v9, 0x3ff0000000000000L    # 1.0

    sub-double/2addr v9, v7

    mul-double v9, v9, v11

    mul-double v15, v13, v7

    add-double/2addr v9, v15

    aput-wide v9, p3, v4

    .line 125
    .end local v11    # "y1":D
    .end local v13    # "y2":D
    add-int/lit8 v4, v4, 0x1

    goto :goto_6b

    .line 131
    .end local v4    # "j":I
    :cond_86
    return-void

    .line 116
    .end local v5    # "h":D
    .end local v7    # "x":D
    :cond_87
    add-int/lit8 v1, v1, 0x1

    goto :goto_3a

    .line 134
    .end local v1    # "i":I
    :cond_8a
    return-void
.end method

.method public getPos(D[F)V
    .registers 21
    .param p1, "t"    # D
    .param p3, "v"    # [F

    .line 137
    move-object/from16 v0, p0

    iget-object v1, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mT:[D

    array-length v2, v1

    .line 138
    .local v2, "n":I
    iget-object v3, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mY:[[D

    const/4 v4, 0x0

    aget-object v3, v3, v4

    array-length v3, v3

    .line 139
    .local v3, "dim":I
    aget-wide v5, v1, v4

    cmpg-double v7, p1, v5

    if-gtz v7, :cond_21

    .line 140
    const/4 v1, 0x0

    .local v1, "j":I
    :goto_12
    if-ge v1, v3, :cond_20

    .line 141
    iget-object v5, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mY:[[D

    aget-object v5, v5, v4

    aget-wide v6, v5, v1

    double-to-float v5, v6

    aput v5, p3, v1

    .line 140
    add-int/lit8 v1, v1, 0x1

    goto :goto_12

    .line 143
    .end local v1    # "j":I
    :cond_20
    return-void

    .line 145
    :cond_21
    add-int/lit8 v4, v2, -0x1

    aget-wide v4, v1, v4

    cmpl-double v1, p1, v4

    if-ltz v1, :cond_3b

    .line 146
    const/4 v1, 0x0

    .restart local v1    # "j":I
    :goto_2a
    if-ge v1, v3, :cond_3a

    .line 147
    iget-object v4, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mY:[[D

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

    aget-object v4, v4, v5

    aget-wide v5, v4, v1

    double-to-float v4, v5

    aput v4, p3, v1

    .line 146
    add-int/lit8 v1, v1, 0x1

    goto :goto_2a

    .line 149
    .end local v1    # "j":I
    :cond_3a
    return-void

    .line 152
    :cond_3b
    const/4 v1, 0x0

    .local v1, "i":I
    :goto_3c
    add-int/lit8 v4, v2, -0x1

    if-ge v1, v4, :cond_8e

    .line 153
    iget-object v4, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mT:[D

    aget-wide v5, v4, v1

    cmpl-double v4, p1, v5

    if-nez v4, :cond_57

    .line 154
    const/4 v4, 0x0

    .local v4, "j":I
    :goto_49
    if-ge v4, v3, :cond_57

    .line 155
    iget-object v5, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mY:[[D

    aget-object v5, v5, v1

    aget-wide v6, v5, v4

    double-to-float v5, v6

    aput v5, p3, v4

    .line 154
    add-int/lit8 v4, v4, 0x1

    goto :goto_49

    .line 158
    .end local v4    # "j":I
    :cond_57
    iget-object v4, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mT:[D

    add-int/lit8 v5, v1, 0x1

    aget-wide v5, v4, v5

    cmpg-double v7, p1, v5

    if-gez v7, :cond_8b

    .line 159
    add-int/lit8 v5, v1, 0x1

    aget-wide v5, v4, v5

    aget-wide v7, v4, v1

    sub-double/2addr v5, v7

    .line 160
    .local v5, "h":D
    aget-wide v7, v4, v1

    sub-double v7, p1, v7

    div-double/2addr v7, v5

    .line 161
    .local v7, "x":D
    const/4 v4, 0x0

    .restart local v4    # "j":I
    :goto_6e
    if-ge v4, v3, :cond_8a

    .line 162
    iget-object v9, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mY:[[D

    aget-object v10, v9, v1

    aget-wide v11, v10, v4

    .line 163
    .local v11, "y1":D
    add-int/lit8 v10, v1, 0x1

    aget-object v9, v9, v10

    aget-wide v13, v9, v4

    .line 165
    .local v13, "y2":D
    const-wide/high16 v9, 0x3ff0000000000000L    # 1.0

    sub-double/2addr v9, v7

    mul-double v9, v9, v11

    mul-double v15, v13, v7

    add-double/2addr v9, v15

    double-to-float v9, v9

    aput v9, p3, v4

    .line 161
    .end local v11    # "y1":D
    .end local v13    # "y2":D
    add-int/lit8 v4, v4, 0x1

    goto :goto_6e

    .line 167
    .end local v4    # "j":I
    :cond_8a
    return-void

    .line 152
    .end local v5    # "h":D
    .end local v7    # "x":D
    :cond_8b
    add-int/lit8 v1, v1, 0x1

    goto :goto_3c

    .line 170
    .end local v1    # "i":I
    :cond_8e
    return-void
.end method

.method public getSlope(DI)D
    .registers 21
    .param p1, "t"    # D
    .param p3, "j"    # I

    .line 223
    move-object/from16 v0, p0

    iget-object v1, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mT:[D

    array-length v2, v1

    .line 225
    .local v2, "n":I
    const/4 v3, 0x0

    aget-wide v4, v1, v3

    cmpg-double v6, p1, v4

    if-gez v6, :cond_f

    .line 226
    aget-wide v3, v1, v3

    .end local p1    # "t":D
    .local v3, "t":D
    goto :goto_1e

    .line 227
    .end local v3    # "t":D
    .restart local p1    # "t":D
    :cond_f
    add-int/lit8 v3, v2, -0x1

    aget-wide v3, v1, v3

    cmpl-double v5, p1, v3

    if-ltz v5, :cond_1c

    .line 228
    add-int/lit8 v3, v2, -0x1

    aget-wide v3, v1, v3

    .end local p1    # "t":D
    .restart local v3    # "t":D
    goto :goto_1e

    .line 227
    .end local v3    # "t":D
    .restart local p1    # "t":D
    :cond_1c
    move-wide/from16 v3, p1

    .line 230
    .end local p1    # "t":D
    .restart local v3    # "t":D
    :goto_1e
    const/4 v1, 0x0

    .local v1, "i":I
    :goto_1f
    add-int/lit8 v5, v2, -0x1

    if-ge v1, v5, :cond_4c

    .line 231
    iget-object v5, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mT:[D

    add-int/lit8 v6, v1, 0x1

    aget-wide v6, v5, v6

    cmpg-double v8, v3, v6

    if-gtz v8, :cond_49

    .line 232
    add-int/lit8 v6, v1, 0x1

    aget-wide v6, v5, v6

    aget-wide v8, v5, v1

    sub-double/2addr v6, v8

    .line 233
    .local v6, "h":D
    aget-wide v8, v5, v1

    sub-double v8, v3, v8

    div-double/2addr v8, v6

    .line 234
    .local v8, "x":D
    iget-object v5, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mY:[[D

    aget-object v10, v5, v1

    aget-wide v11, v10, p3

    .line 235
    .local v11, "y1":D
    add-int/lit8 v10, v1, 0x1

    aget-object v5, v5, v10

    aget-wide v13, v5, p3

    .line 236
    .local v13, "y2":D
    sub-double v15, v13, v11

    div-double/2addr v15, v6

    return-wide v15

    .line 230
    .end local v6    # "h":D
    .end local v8    # "x":D
    .end local v11    # "y1":D
    .end local v13    # "y2":D
    :cond_49
    add-int/lit8 v1, v1, 0x1

    goto :goto_1f

    .line 239
    .end local v1    # "i":I
    :cond_4c
    const-wide/16 v5, 0x0

    return-wide v5
.end method

.method public getSlope(D[D)V
    .registers 21
    .param p1, "t"    # D
    .param p3, "v"    # [D

    .line 198
    move-object/from16 v0, p0

    iget-object v1, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mT:[D

    array-length v2, v1

    .line 199
    .local v2, "n":I
    iget-object v3, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mY:[[D

    const/4 v4, 0x0

    aget-object v3, v3, v4

    array-length v3, v3

    .line 200
    .local v3, "dim":I
    aget-wide v5, v1, v4

    cmpg-double v7, p1, v5

    if-gtz v7, :cond_14

    .line 201
    aget-wide v4, v1, v4

    .end local p1    # "t":D
    .local v4, "t":D
    goto :goto_23

    .line 202
    .end local v4    # "t":D
    .restart local p1    # "t":D
    :cond_14
    add-int/lit8 v4, v2, -0x1

    aget-wide v4, v1, v4

    cmpl-double v6, p1, v4

    if-ltz v6, :cond_21

    .line 203
    add-int/lit8 v4, v2, -0x1

    aget-wide v4, v1, v4

    .end local p1    # "t":D
    .restart local v4    # "t":D
    goto :goto_23

    .line 202
    .end local v4    # "t":D
    .restart local p1    # "t":D
    :cond_21
    move-wide/from16 v4, p1

    .line 206
    .end local p1    # "t":D
    .restart local v4    # "t":D
    :goto_23
    const/4 v1, 0x0

    .local v1, "i":I
    :goto_24
    add-int/lit8 v6, v2, -0x1

    if-ge v1, v6, :cond_59

    .line 207
    iget-object v6, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mT:[D

    add-int/lit8 v7, v1, 0x1

    aget-wide v7, v6, v7

    cmpg-double v9, v4, v7

    if-gtz v9, :cond_56

    .line 208
    add-int/lit8 v7, v1, 0x1

    aget-wide v7, v6, v7

    aget-wide v9, v6, v1

    sub-double/2addr v7, v9

    .line 209
    .local v7, "h":D
    aget-wide v9, v6, v1

    sub-double v9, v4, v9

    div-double/2addr v9, v7

    .line 210
    .local v9, "x":D
    const/4 v6, 0x0

    .local v6, "j":I
    :goto_3f
    if-ge v6, v3, :cond_55

    .line 211
    iget-object v11, v0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mY:[[D

    aget-object v12, v11, v1

    aget-wide v13, v12, v6

    .line 212
    .local v13, "y1":D
    add-int/lit8 v12, v1, 0x1

    aget-object v11, v11, v12

    aget-wide v15, v11, v6

    .line 214
    .local v15, "y2":D
    sub-double v11, v15, v13

    div-double/2addr v11, v7

    aput-wide v11, p3, v6

    .line 210
    .end local v13    # "y1":D
    .end local v15    # "y2":D
    add-int/lit8 v6, v6, 0x1

    goto :goto_3f

    .line 216
    .end local v6    # "j":I
    :cond_55
    goto :goto_59

    .line 206
    .end local v7    # "h":D
    .end local v9    # "x":D
    :cond_56
    add-int/lit8 v1, v1, 0x1

    goto :goto_24

    .line 219
    .end local v1    # "i":I
    :cond_59
    :goto_59
    return-void
.end method

.method public getTimePoints()[D
    .registers 2

    .line 244
    iget-object v0, p0, Landroidx/constraintlayout/motion/utils/LinearCurveFit;->mT:[D

    return-object v0
.end method