d.smali
.class public Lb/b/a/a/d;
.super Lb/b/a/a/b;
.source "LinearCurveFit.java"
# instance fields
.field private a:[D
.field private b:[[D
.field private c:D
# direct methods
.method public constructor <init>([D[[D)V
.registers 16
.line 1
invoke-direct {p0}, Lb/b/a/a/b;-><init>()V
const-wide/high16 v0, 0x7ff8000000000000L # Double.NaN
.line 2
iput-wide v0, p0, Lb/b/a/a/d;->c:D
.line 3
array-length v0, p1
const/4 v0, 0x0
.line 4
aget-object v1, p2, v0
array-length v1, v1
.line 5
iput-object p1, p0, Lb/b/a/a/d;->a:[D
.line 6
iput-object p2, p0, Lb/b/a/a/d;->b:[[D
const/4 v2, 0x2
if-le v1, v2, :cond_33
const-wide/16 v1, 0x0
move-wide v4, v1
move-wide v6, v4
const/4 v3, 0x0
.line 7
:goto_18
array-length v8, p1
if-ge v3, v8, :cond_31
.line 8
aget-object v8, p2, v3
aget-wide v9, v8, v0
.line 9
aget-object v8, p2, v3
aget-wide v11, v8, v0
if-lez v3, :cond_2c
sub-double v4, v9, v4
sub-double v6, v11, v6
.line 10
invoke-static {v4, v5, v6, v7}, Ljava/lang/Math;->hypot(DD)D
:cond_2c
add-int/lit8 v3, v3, 0x1
move-wide v4, v9
move-wide v6, v11
goto :goto_18
.line 11
:cond_31
iput-wide v1, p0, Lb/b/a/a/d;->c:D
:cond_33
return-void
.end method
# virtual methods
.method public a(DI)D
.registers 12
.line 29
iget-object v0, p0, Lb/b/a/a/d;->a:[D
array-length v1, v0
const/4 v2, 0x0
.line 30
aget-wide v3, v0, v2
cmpg-double v5, p1, v3
if-gtz v5, :cond_11
.line 31
iget-object p1, p0, Lb/b/a/a/d;->b:[[D
aget-object p1, p1, v2
aget-wide p2, p1, p3
return-wide p2
:cond_11
add-int/lit8 v1, v1, -0x1
.line 32
aget-wide v3, v0, v1
cmpl-double v0, p1, v3
if-ltz v0, :cond_20
.line 33
iget-object p1, p0, Lb/b/a/a/d;->b:[[D
aget-object p1, p1, v1
aget-wide p2, p1, p3
return-wide p2
:cond_20
:goto_20
if-ge v2, v1, :cond_57
.line 34
iget-object v0, p0, Lb/b/a/a/d;->a:[D
aget-wide v3, v0, v2
cmpl-double v5, p1, v3
if-nez v5, :cond_31
.line 35
iget-object p1, p0, Lb/b/a/a/d;->b:[[D
aget-object p1, p1, v2
aget-wide p2, p1, p3
return-wide p2
:cond_31
add-int/lit8 v3, v2, 0x1
.line 36
aget-wide v4, v0, v3
cmpg-double v6, p1, v4
if-gez v6, :cond_55
.line 37
aget-wide v4, v0, v3
aget-wide v6, v0, v2
sub-double/2addr v4, v6
.line 38
aget-wide v6, v0, v2
sub-double/2addr p1, v6
div-double/2addr p1, v4
.line 39
iget-object v0, p0, Lb/b/a/a/d;->b:[[D
aget-object v1, v0, v2
aget-wide v4, v1, p3
.line 40
aget-object v0, v0, v3
aget-wide v1, v0, p3
const-wide/high16 v6, 0x3ff0000000000000L # 1.0
sub-double/2addr v6, p1
mul-double v4, v4, v6
mul-double v1, v1, p1
add-double/2addr v4, v1
return-wide v4
:cond_55
move v2, v3
goto :goto_20
:cond_57
const-wide/16 p1, 0x0
return-wide p1
.end method
.method public a(D[D)V
.registers 16
.line 1
iget-object v0, p0, Lb/b/a/a/d;->a:[D
array-length v1, v0
.line 2
iget-object v2, p0, Lb/b/a/a/d;->b:[[D
const/4 v3, 0x0
aget-object v2, v2, v3
array-length v2, v2
.line 3
aget-wide v4, v0, v3
cmpg-double v6, p1, v4
if-gtz v6, :cond_1e
const/4 p1, 0x0
:goto_10
if-ge p1, v2, :cond_1d
.line 4
iget-object p2, p0, Lb/b/a/a/d;->b:[[D
aget-object p2, p2, v3
aget-wide v0, p2, p1
aput-wide v0, p3, p1
add-int/lit8 p1, p1, 0x1
goto :goto_10
:cond_1d
return-void
:cond_1e
add-int/lit8 v1, v1, -0x1
.line 5
aget-wide v4, v0, v1
cmpl-double v0, p1, v4
if-ltz v0, :cond_34
:goto_26
if-ge v3, v2, :cond_33
.line 6
iget-object p1, p0, Lb/b/a/a/d;->b:[[D
aget-object p1, p1, v1
aget-wide v4, p1, v3
aput-wide v4, p3, v3
add-int/lit8 v3, v3, 0x1
goto :goto_26
:cond_33
return-void
:cond_34
const/4 v0, 0x0
:goto_35
if-ge v0, v1, :cond_7c
.line 7
iget-object v4, p0, Lb/b/a/a/d;->a:[D
aget-wide v5, v4, v0
cmpl-double v4, p1, v5
if-nez v4, :cond_4d
const/4 v4, 0x0
:goto_40
if-ge v4, v2, :cond_4d
.line 8
iget-object v5, p0, Lb/b/a/a/d;->b:[[D
aget-object v5, v5, v0
aget-wide v6, v5, v4
aput-wide v6, p3, v4
add-int/lit8 v4, v4, 0x1
goto :goto_40
.line 9
:cond_4d
iget-object v4, p0, Lb/b/a/a/d;->a:[D
add-int/lit8 v5, v0, 0x1
aget-wide v6, v4, v5
cmpg-double v8, p1, v6
if-gez v8, :cond_7a
.line 10
aget-wide v6, v4, v5
aget-wide v8, v4, v0
sub-double/2addr v6, v8
.line 11
aget-wide v8, v4, v0
sub-double/2addr p1, v8
div-double/2addr p1, v6
:goto_60
if-ge v3, v2, :cond_79
.line 12
iget-object v1, p0, Lb/b/a/a/d;->b:[[D
aget-object v4, v1, v0
aget-wide v6, v4, v3
.line 13
aget-object v1, v1, v5
aget-wide v8, v1, v3
const-wide/high16 v10, 0x3ff0000000000000L # 1.0
sub-double/2addr v10, p1
mul-double v6, v6, v10
mul-double v8, v8, p1
add-double/2addr v6, v8
.line 14
aput-wide v6, p3, v3
add-int/lit8 v3, v3, 0x1
goto :goto_60
:cond_79
return-void
:cond_7a
move v0, v5
goto :goto_35
:cond_7c
return-void
.end method
.method public a(D[F)V
.registers 16
.line 15
iget-object v0, p0, Lb/b/a/a/d;->a:[D
array-length v1, v0
.line 16
iget-object v2, p0, Lb/b/a/a/d;->b:[[D
const/4 v3, 0x0
aget-object v2, v2, v3
array-length v2, v2
.line 17
aget-wide v4, v0, v3
cmpg-double v6, p1, v4
if-gtz v6, :cond_1f
const/4 p1, 0x0
:goto_10
if-ge p1, v2, :cond_1e
.line 18
iget-object p2, p0, Lb/b/a/a/d;->b:[[D
aget-object p2, p2, v3
aget-wide v0, p2, p1
double-to-float p2, v0
aput p2, p3, p1
add-int/lit8 p1, p1, 0x1
goto :goto_10
:cond_1e
return-void
:cond_1f
add-int/lit8 v1, v1, -0x1
.line 19
aget-wide v4, v0, v1
cmpl-double v0, p1, v4
if-ltz v0, :cond_36
:goto_27
if-ge v3, v2, :cond_35
.line 20
iget-object p1, p0, Lb/b/a/a/d;->b:[[D
aget-object p1, p1, v1
aget-wide v4, p1, v3
double-to-float p1, v4
aput p1, p3, v3
add-int/lit8 v3, v3, 0x1
goto :goto_27
:cond_35
return-void
:cond_36
const/4 v0, 0x0
:goto_37
if-ge v0, v1, :cond_80
.line 21
iget-object v4, p0, Lb/b/a/a/d;->a:[D
aget-wide v5, v4, v0
cmpl-double v4, p1, v5
if-nez v4, :cond_50
const/4 v4, 0x0
:goto_42
if-ge v4, v2, :cond_50
.line 22
iget-object v5, p0, Lb/b/a/a/d;->b:[[D
aget-object v5, v5, v0
aget-wide v6, v5, v4
double-to-float v5, v6
aput v5, p3, v4
add-int/lit8 v4, v4, 0x1
goto :goto_42
.line 23
:cond_50
iget-object v4, p0, Lb/b/a/a/d;->a:[D
add-int/lit8 v5, v0, 0x1
aget-wide v6, v4, v5
cmpg-double v8, p1, v6
if-gez v8, :cond_7e
.line 24
aget-wide v6, v4, v5
aget-wide v8, v4, v0
sub-double/2addr v6, v8
.line 25
aget-wide v8, v4, v0
sub-double/2addr p1, v8
div-double/2addr p1, v6
:goto_63
if-ge v3, v2, :cond_7d
.line 26
iget-object v1, p0, Lb/b/a/a/d;->b:[[D
aget-object v4, v1, v0
aget-wide v6, v4, v3
.line 27
aget-object v1, v1, v5
aget-wide v8, v1, v3
const-wide/high16 v10, 0x3ff0000000000000L # 1.0
sub-double/2addr v10, p1
mul-double v6, v6, v10
mul-double v8, v8, p1
add-double/2addr v6, v8
double-to-float v1, v6
.line 28
aput v1, p3, v3
add-int/lit8 v3, v3, 0x1
goto :goto_63
:cond_7d
return-void
:cond_7e
move v0, v5
goto :goto_37
:cond_80
return-void
.end method
.method public a()[D
.registers 2
.line 41
iget-object v0, p0, Lb/b/a/a/d;->a:[D
return-object v0
.end method
.method public b(DI)D
.registers 11
.line 13
iget-object v0, p0, Lb/b/a/a/d;->a:[D
array-length v1, v0
const/4 v2, 0x0
.line 14
aget-wide v3, v0, v2
cmpg-double v5, p1, v3
if-gez v5, :cond_d
.line 15
aget-wide p1, v0, v2
goto :goto_17
:cond_d
add-int/lit8 v3, v1, -0x1
.line 16
aget-wide v4, v0, v3
cmpl-double v6, p1, v4
if-ltz v6, :cond_17
.line 17
aget-wide p1, v0, v3
:cond_17
:goto_17
add-int/lit8 v0, v1, -0x1
if-ge v2, v0, :cond_3b
.line 18
iget-object v0, p0, Lb/b/a/a/d;->a:[D
add-int/lit8 v3, v2, 0x1
aget-wide v4, v0, v3
cmpg-double v6, p1, v4
if-gtz v6, :cond_39
.line 19
aget-wide p1, v0, v3
aget-wide v4, v0, v2
sub-double/2addr p1, v4
.line 20
aget-wide v4, v0, v2
.line 21
iget-object v0, p0, Lb/b/a/a/d;->b:[[D
aget-object v1, v0, v2
aget-wide v4, v1, p3
.line 22
aget-object v0, v0, v3
aget-wide v1, v0, p3
sub-double/2addr v1, v4
div-double/2addr v1, p1
return-wide v1
:cond_39
move v2, v3
goto :goto_17
:cond_3b
const-wide/16 p1, 0x0
return-wide p1
.end method
.method public b(D[D)V
.registers 14
.line 1
iget-object v0, p0, Lb/b/a/a/d;->a:[D
array-length v1, v0
.line 2
iget-object v2, p0, Lb/b/a/a/d;->b:[[D
const/4 v3, 0x0
aget-object v2, v2, v3
array-length v2, v2
.line 3
aget-wide v4, v0, v3
cmpg-double v6, p1, v4
if-gtz v6, :cond_12
.line 4
aget-wide p1, v0, v3
goto :goto_1c
:cond_12
add-int/lit8 v4, v1, -0x1
.line 5
aget-wide v5, v0, v4
cmpl-double v7, p1, v5
if-ltz v7, :cond_1c
.line 6
aget-wide p1, v0, v4
:cond_1c
:goto_1c
const/4 v0, 0x0
:goto_1d
add-int/lit8 v4, v1, -0x1
if-ge v0, v4, :cond_47
.line 7
iget-object v4, p0, Lb/b/a/a/d;->a:[D
add-int/lit8 v5, v0, 0x1
aget-wide v6, v4, v5
cmpg-double v8, p1, v6
if-gtz v8, :cond_45
.line 8
aget-wide p1, v4, v5
aget-wide v6, v4, v0
sub-double/2addr p1, v6
.line 9
aget-wide v6, v4, v0
:goto_32
if-ge v3, v2, :cond_47
.line 10
iget-object v1, p0, Lb/b/a/a/d;->b:[[D
aget-object v4, v1, v0
aget-wide v6, v4, v3
.line 11
aget-object v1, v1, v5
aget-wide v8, v1, v3
sub-double/2addr v8, v6
div-double/2addr v8, p1
.line 12
aput-wide v8, p3, v3
add-int/lit8 v3, v3, 0x1
goto :goto_32
:cond_45
move v0, v5
goto :goto_1d
:cond_47
return-void
.end method