e.smali
.class public Lb/b/a/a/e;
.super Lb/b/a/a/b;
.source "MonotonicCurveFit.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 25
move-object/from16 v0, p0
move-object/from16 v1, p1
move-object/from16 v2, p2
.line 1
invoke-direct/range {p0 .. p0}, Lb/b/a/a/b;-><init>()V
.line 2
array-length v3, v1
const/4 v4, 0x0
.line 3
aget-object v5, v2, v4
array-length v5, v5
add-int/lit8 v6, v3, -0x1
.line 4
filled-new-array {v6, v5}, [I
move-result-object v7
const-class v8, D
invoke-static {v8, v7}, Ljava/lang/reflect/Array;->newInstance(Ljava/lang/Class;[I)Ljava/lang/Object;
move-result-object v7
check-cast v7, [[D
.line 5
filled-new-array {v3, v5}, [I
move-result-object v8
const-class v9, D
invoke-static {v9, v8}, Ljava/lang/reflect/Array;->newInstance(Ljava/lang/Class;[I)Ljava/lang/Object;
move-result-object v8
check-cast v8, [[D
const/4 v9, 0x0
:goto_29
if-ge v9, v5, :cond_73
const/4 v10, 0x0
:goto_2c
if-ge v10, v6, :cond_66
add-int/lit8 v11, v10, 0x1
.line 6
aget-wide v12, v1, v11
aget-wide v14, v1, v10
sub-double/2addr v12, v14
.line 7
aget-object v14, v7, v10
aget-object v15, v2, v11
aget-wide v16, v15, v9
aget-object v15, v2, v10
aget-wide v18, v15, v9
sub-double v16, v16, v18
div-double v16, v16, v12
aput-wide v16, v14, v9
if-nez v10, :cond_50
.line 8
aget-object v12, v8, v10
aget-object v10, v7, v10
aget-wide v13, v10, v9
aput-wide v13, v12, v9
goto :goto_64
.line 9
:cond_50
aget-object v12, v8, v10
add-int/lit8 v13, v10, -0x1
aget-object v13, v7, v13
aget-wide v14, v13, v9
aget-object v10, v7, v10
aget-wide v16, v10, v9
add-double v14, v14, v16
const-wide/high16 v16, 0x3fe0000000000000L # 0.5
mul-double v14, v14, v16
aput-wide v14, v12, v9
:goto_64
move v10, v11
goto :goto_2c
.line 10
:cond_66
aget-object v10, v8, v6
add-int/lit8 v11, v3, -0x2
aget-object v11, v7, v11
aget-wide v12, v11, v9
aput-wide v12, v10, v9
add-int/lit8 v9, v9, 0x1
goto :goto_29
:cond_73
const/4 v3, 0x0
:goto_74
if-ge v3, v6, :cond_cf
const/4 v9, 0x0
:goto_77
if-ge v9, v5, :cond_cc
.line 11
aget-object v10, v7, v3
aget-wide v11, v10, v9
const-wide/16 v13, 0x0
cmpl-double v10, v11, v13
if-nez v10, :cond_8e
.line 12
aget-object v10, v8, v3
aput-wide v13, v10, v9
add-int/lit8 v10, v3, 0x1
.line 13
aget-object v10, v8, v10
aput-wide v13, v10, v9
goto :goto_c9
.line 14
:cond_8e
aget-object v10, v8, v3
aget-wide v11, v10, v9
aget-object v10, v7, v3
aget-wide v13, v10, v9
div-double/2addr v11, v13
add-int/lit8 v10, v3, 0x1
.line 15
aget-object v13, v8, v10
aget-wide v14, v13, v9
aget-object v13, v7, v3
aget-wide v16, v13, v9
div-double v14, v14, v16
.line 16
invoke-static {v11, v12, v14, v15}, Ljava/lang/Math;->hypot(DD)D
move-result-wide v16
const-wide/high16 v18, 0x4022000000000000L # 9.0
cmpl-double v13, v16, v18
if-lez v13, :cond_c9
const-wide/high16 v18, 0x4008000000000000L # 3.0
div-double v18, v18, v16
.line 17
aget-object v13, v8, v3
mul-double v11, v11, v18
aget-object v16, v7, v3
aget-wide v20, v16, v9
mul-double v11, v11, v20
aput-wide v11, v13, v9
.line 18
aget-object v10, v8, v10
mul-double v18, v18, v14
aget-object v11, v7, v3
aget-wide v12, v11, v9
mul-double v18, v18, v12
aput-wide v18, v10, v9
:cond_c9
:goto_c9
add-int/lit8 v9, v9, 0x1
goto :goto_77
:cond_cc
add-int/lit8 v3, v3, 0x1
goto :goto_74
.line 19
:cond_cf
iput-object v1, v0, Lb/b/a/a/e;->a:[D
.line 20
iput-object v2, v0, Lb/b/a/a/e;->b:[[D
.line 21
iput-object v8, v0, Lb/b/a/a/e;->c:[[D
return-void
.end method
.method private static a(DDDDDD)D
.registers 22
mul-double v0, p2, p2
const-wide/high16 v2, -0x3fe8000000000000L # -6.0
mul-double v2, v2, v0
mul-double v2, v2, p6
const-wide/high16 v4, 0x4018000000000000L # 6.0
mul-double v6, p2, v4
mul-double v8, v6, p6
add-double/2addr v2, v8
mul-double v4, v4, v0
mul-double v4, v4, p4
add-double/2addr v2, v4
mul-double v6, v6, p4
sub-double/2addr v2, v6
const-wide/high16 v4, 0x4008000000000000L # 3.0
mul-double v4, v4, p0
mul-double v6, v4, p10
mul-double v6, v6, v0
add-double/2addr v2, v6
mul-double v4, v4, p8
mul-double v4, v4, v0
add-double/2addr v2, v4
const-wide/high16 v0, 0x4000000000000000L # 2.0
mul-double v0, v0, p0
mul-double v0, v0, p10
mul-double v0, v0, p2
sub-double/2addr v2, v0
const-wide/high16 v0, 0x4010000000000000L # 4.0
mul-double v0, v0, p0
mul-double v0, v0, p8
mul-double v0, v0, p2
sub-double/2addr v2, v0
mul-double v0, p0, p8
add-double/2addr v2, v0
return-wide v2
.end method
.method private static b(DDDDDD)D
.registers 24
mul-double v0, p2, p2
mul-double v2, v0, p2
const-wide/high16 v4, -0x4000000000000000L # -2.0
mul-double v4, v4, v2
mul-double v4, v4, p6
const-wide/high16 v6, 0x4008000000000000L # 3.0
mul-double v6, v6, v0
mul-double v8, v6, p6
add-double/2addr v4, v8
const-wide/high16 v8, 0x4000000000000000L # 2.0
mul-double v10, v2, v8
mul-double v10, v10, p4
add-double/2addr v4, v10
mul-double v6, v6, p4
sub-double/2addr v4, v6
add-double v4, v4, p4
mul-double v6, p0, p10
mul-double v10, v6, v2
add-double/2addr v4, v10
mul-double v10, p0, p8
mul-double v2, v2, v10
add-double/2addr v4, v2
mul-double v6, v6, v0
sub-double/2addr v4, v6
mul-double v2, p0, v8
mul-double v2, v2, p8
mul-double v2, v2, v0
sub-double/2addr v4, v2
mul-double v10, v10, p2
add-double/2addr v4, v10
return-wide v4
.end method
# virtual methods
.method public a(DI)D
.registers 25
move-object/from16 v0, p0
.line 33
iget-object v1, v0, Lb/b/a/a/e;->a:[D
array-length v2, v1
const/4 v3, 0x0
.line 34
aget-wide v4, v1, v3
cmpg-double v6, p1, v4
if-gtz v6, :cond_13
.line 35
iget-object v1, v0, Lb/b/a/a/e;->b:[[D
aget-object v1, v1, v3
aget-wide v2, v1, p3
return-wide v2
:cond_13
add-int/lit8 v2, v2, -0x1
.line 36
aget-wide v4, v1, v2
cmpl-double v1, p1, v4
if-ltz v1, :cond_22
.line 37
iget-object v1, v0, Lb/b/a/a/e;->b:[[D
aget-object v1, v1, v2
aget-wide v2, v1, p3
return-wide v2
:cond_22
:goto_22
if-ge v3, v2, :cond_62
.line 38
iget-object v1, v0, Lb/b/a/a/e;->a:[D
aget-wide v4, v1, v3
cmpl-double v6, p1, v4
if-nez v6, :cond_33
.line 39
iget-object v1, v0, Lb/b/a/a/e;->b:[[D
aget-object v1, v1, v3
aget-wide v2, v1, p3
return-wide v2
:cond_33
add-int/lit8 v4, v3, 0x1
.line 40
aget-wide v5, v1, v4
cmpg-double v7, p1, v5
if-gez v7, :cond_60
.line 41
aget-wide v5, v1, v4
aget-wide v7, v1, v3
sub-double v9, v5, v7
.line 42
aget-wide v5, v1, v3
sub-double v1, p1, v5
div-double v11, v1, v9
.line 43
iget-object v1, v0, Lb/b/a/a/e;->b:[[D
aget-object v2, v1, v3
aget-wide v13, v2, p3
.line 44
aget-object v1, v1, v4
aget-wide v15, v1, p3
.line 45
iget-object v1, v0, Lb/b/a/a/e;->c:[[D
aget-object v2, v1, v3
aget-wide v17, v2, p3
.line 46
aget-object v1, v1, v4
aget-wide v19, v1, p3
.line 47
invoke-static/range {v9 .. v20}, Lb/b/a/a/e;->b(DDDDDD)D
move-result-wide v1
return-wide v1
:cond_60
move v3, v4
goto :goto_22
:cond_62
const-wide/16 v1, 0x0
return-wide v1
.end method
.method public a(D[D)V
.registers 27
move-object/from16 v0, p0
.line 1
iget-object v1, v0, Lb/b/a/a/e;->a:[D
array-length v2, v1
.line 2
iget-object v3, v0, Lb/b/a/a/e;->b:[[D
const/4 v4, 0x0
aget-object v3, v3, v4
array-length v3, v3
.line 3
aget-wide v5, v1, v4
cmpg-double v7, p1, v5
if-gtz v7, :cond_20
const/4 v1, 0x0
:goto_12
if-ge v1, v3, :cond_1f
.line 4
iget-object v2, v0, Lb/b/a/a/e;->b:[[D
aget-object v2, v2, v4
aget-wide v5, v2, v1
aput-wide v5, p3, v1
add-int/lit8 v1, v1, 0x1
goto :goto_12
:cond_1f
return-void
:cond_20
add-int/lit8 v2, v2, -0x1
.line 5
aget-wide v5, v1, v2
cmpl-double v1, p1, v5
if-ltz v1, :cond_36
:goto_28
if-ge v4, v3, :cond_35
.line 6
iget-object v1, v0, Lb/b/a/a/e;->b:[[D
aget-object v1, v1, v2
aget-wide v5, v1, v4
aput-wide v5, p3, v4
add-int/lit8 v4, v4, 0x1
goto :goto_28
:cond_35
return-void
:cond_36
const/4 v1, 0x0
:goto_37
if-ge v1, v2, :cond_87
.line 7
iget-object v5, v0, Lb/b/a/a/e;->a:[D
aget-wide v6, v5, v1
cmpl-double v5, p1, v6
if-nez v5, :cond_4f
const/4 v5, 0x0
:goto_42
if-ge v5, v3, :cond_4f
.line 8
iget-object v6, v0, Lb/b/a/a/e;->b:[[D
aget-object v6, v6, v1
aget-wide v7, v6, v5
aput-wide v7, p3, v5
add-int/lit8 v5, v5, 0x1
goto :goto_42
.line 9
:cond_4f
iget-object v5, v0, Lb/b/a/a/e;->a:[D
add-int/lit8 v6, v1, 0x1
aget-wide v7, v5, v6
cmpg-double v9, p1, v7
if-gez v9, :cond_85
.line 10
aget-wide v7, v5, v6
aget-wide v9, v5, v1
sub-double/2addr v7, v9
.line 11
aget-wide v9, v5, v1
sub-double v9, p1, v9
div-double/2addr v9, v7
:goto_63
if-ge v4, v3, :cond_84
.line 12
iget-object v2, v0, Lb/b/a/a/e;->b:[[D
aget-object v5, v2, v1
aget-wide v15, v5, v4
.line 13
aget-object v2, v2, v6
aget-wide v17, v2, v4
.line 14
iget-object v2, v0, Lb/b/a/a/e;->c:[[D
aget-object v5, v2, v1
aget-wide v19, v5, v4
.line 15
aget-object v2, v2, v6
aget-wide v21, v2, v4
move-wide v11, v7
move-wide v13, v9
.line 16
invoke-static/range {v11 .. v22}, Lb/b/a/a/e;->b(DDDDDD)D
move-result-wide v11
aput-wide v11, p3, v4
add-int/lit8 v4, v4, 0x1
goto :goto_63
:cond_84
return-void
:cond_85
move v1, v6
goto :goto_37
:cond_87
return-void
.end method
.method public a(D[F)V
.registers 27
move-object/from16 v0, p0
.line 17
iget-object v1, v0, Lb/b/a/a/e;->a:[D
array-length v2, v1
.line 18
iget-object v3, v0, Lb/b/a/a/e;->b:[[D
const/4 v4, 0x0
aget-object v3, v3, v4
array-length v3, v3
.line 19
aget-wide v5, v1, v4
cmpg-double v7, p1, v5
if-gtz v7, :cond_21
const/4 v1, 0x0
:goto_12
if-ge v1, v3, :cond_20
.line 20
iget-object v2, v0, Lb/b/a/a/e;->b:[[D
aget-object v2, v2, v4
aget-wide v5, v2, v1
double-to-float v2, v5
aput v2, p3, v1
add-int/lit8 v1, v1, 0x1
goto :goto_12
:cond_20
return-void
:cond_21
add-int/lit8 v2, v2, -0x1
.line 21
aget-wide v5, v1, v2
cmpl-double v1, p1, v5
if-ltz v1, :cond_38
:goto_29
if-ge v4, v3, :cond_37
.line 22
iget-object v1, v0, Lb/b/a/a/e;->b:[[D
aget-object v1, v1, v2
aget-wide v5, v1, v4
double-to-float v1, v5
aput v1, p3, v4
add-int/lit8 v4, v4, 0x1
goto :goto_29
:cond_37
return-void
:cond_38
const/4 v1, 0x0
:goto_39
if-ge v1, v2, :cond_8b
.line 23
iget-object v5, v0, Lb/b/a/a/e;->a:[D
aget-wide v6, v5, v1
cmpl-double v5, p1, v6
if-nez v5, :cond_52
const/4 v5, 0x0
:goto_44
if-ge v5, v3, :cond_52
.line 24
iget-object v6, v0, Lb/b/a/a/e;->b:[[D
aget-object v6, v6, v1
aget-wide v7, v6, v5
double-to-float v6, v7
aput v6, p3, v5
add-int/lit8 v5, v5, 0x1
goto :goto_44
.line 25
:cond_52
iget-object v5, v0, Lb/b/a/a/e;->a:[D
add-int/lit8 v6, v1, 0x1
aget-wide v7, v5, v6
cmpg-double v9, p1, v7
if-gez v9, :cond_89
.line 26
aget-wide v7, v5, v6
aget-wide v9, v5, v1
sub-double/2addr v7, v9
.line 27
aget-wide v9, v5, v1
sub-double v9, p1, v9
div-double/2addr v9, v7
:goto_66
if-ge v4, v3, :cond_88
.line 28
iget-object v2, v0, Lb/b/a/a/e;->b:[[D
aget-object v5, v2, v1
aget-wide v15, v5, v4
.line 29
aget-object v2, v2, v6
aget-wide v17, v2, v4
.line 30
iget-object v2, v0, Lb/b/a/a/e;->c:[[D
aget-object v5, v2, v1
aget-wide v19, v5, v4
.line 31
aget-object v2, v2, v6
aget-wide v21, v2, v4
move-wide v11, v7
move-wide v13, v9
.line 32
invoke-static/range {v11 .. v22}, Lb/b/a/a/e;->b(DDDDDD)D
move-result-wide v11
double-to-float v2, v11
aput v2, p3, v4
add-int/lit8 v4, v4, 0x1
goto :goto_66
:cond_88
return-void
:cond_89
move v1, v6
goto :goto_39
:cond_8b
return-void
.end method
.method public a()[D
.registers 2
.line 48
iget-object v0, p0, Lb/b/a/a/e;->a:[D
return-object v0
.end method
.method public b(DI)D
.registers 27
move-object/from16 v0, p0
.line 15
iget-object v1, v0, Lb/b/a/a/e;->a:[D
array-length v2, v1
const/4 v3, 0x0
.line 16
aget-wide v4, v1, v3
cmpg-double v6, p1, v4
if-gez v6, :cond_f
.line 17
aget-wide v4, v1, v3
goto :goto_1c
:cond_f
add-int/lit8 v4, v2, -0x1
.line 18
aget-wide v5, v1, v4
cmpl-double v7, p1, v5
if-ltz v7, :cond_1a
.line 19
aget-wide v4, v1, v4
goto :goto_1c
:cond_1a
move-wide/from16 v4, p1
:goto_1c
add-int/lit8 v1, v2, -0x1
if-ge v3, v1, :cond_51
.line 20
iget-object v1, v0, Lb/b/a/a/e;->a:[D
add-int/lit8 v6, v3, 0x1
aget-wide v7, v1, v6
cmpg-double v9, v4, v7
if-gtz v9, :cond_4f
.line 21
aget-wide v7, v1, v6
aget-wide v9, v1, v3
sub-double/2addr v7, v9
.line 22
aget-wide v9, v1, v3
sub-double/2addr v4, v9
div-double v13, v4, v7
.line 23
iget-object v1, v0, Lb/b/a/a/e;->b:[[D
aget-object v2, v1, v3
aget-wide v15, v2, p3
.line 24
aget-object v1, v1, v6
aget-wide v17, v1, p3
.line 25
iget-object v1, v0, Lb/b/a/a/e;->c:[[D
aget-object v2, v1, v3
aget-wide v19, v2, p3
.line 26
aget-object v1, v1, v6
aget-wide v21, v1, p3
move-wide v11, v7
.line 27
invoke-static/range {v11 .. v22}, Lb/b/a/a/e;->a(DDDDDD)D
move-result-wide v1
div-double/2addr v1, v7
return-wide v1
:cond_4f
move v3, v6
goto :goto_1c
:cond_51
const-wide/16 v1, 0x0
return-wide v1
.end method
.method public b(D[D)V
.registers 29
move-object/from16 v0, p0
.line 1
iget-object v1, v0, Lb/b/a/a/e;->a:[D
array-length v2, v1
.line 2
iget-object v3, v0, Lb/b/a/a/e;->b:[[D
const/4 v4, 0x0
aget-object v3, v3, v4
array-length v3, v3
.line 3
aget-wide v5, v1, v4
cmpg-double v7, p1, v5
if-gtz v7, :cond_14
.line 4
aget-wide v5, v1, v4
goto :goto_21
:cond_14
add-int/lit8 v5, v2, -0x1
.line 5
aget-wide v6, v1, v5
cmpl-double v8, p1, v6
if-ltz v8, :cond_1f
.line 6
aget-wide v5, v1, v5
goto :goto_21
:cond_1f
move-wide/from16 v5, p1
:goto_21
const/4 v1, 0x0
:goto_22
add-int/lit8 v7, v2, -0x1
if-ge v1, v7, :cond_5d
.line 7
iget-object v7, v0, Lb/b/a/a/e;->a:[D
add-int/lit8 v8, v1, 0x1
aget-wide v9, v7, v8
cmpg-double v11, v5, v9
if-gtz v11, :cond_5b
.line 8
aget-wide v9, v7, v8
aget-wide v11, v7, v1
sub-double/2addr v9, v11
.line 9
aget-wide v11, v7, v1
sub-double/2addr v5, v11
div-double/2addr v5, v9
:goto_39
if-ge v4, v3, :cond_5d
.line 10
iget-object v2, v0, Lb/b/a/a/e;->b:[[D
aget-object v7, v2, v1
aget-wide v17, v7, v4
.line 11
aget-object v2, v2, v8
aget-wide v19, v2, v4
.line 12
iget-object v2, v0, Lb/b/a/a/e;->c:[[D
aget-object v7, v2, v1
aget-wide v21, v7, v4
.line 13
aget-object v2, v2, v8
aget-wide v23, v2, v4
move-wide v13, v9
move-wide v15, v5
.line 14
invoke-static/range {v13 .. v24}, Lb/b/a/a/e;->a(DDDDDD)D
move-result-wide v11
div-double/2addr v11, v9
aput-wide v11, p3, v4
add-int/lit8 v4, v4, 0x1
goto :goto_39
:cond_5b
move v1, v8
goto :goto_22
:cond_5d
return-void
.end method