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