f.smali
.class public Lb/b/a/a/f;
.super Ljava/lang/Object;
.source "Oscillator.java"
# instance fields
.field a:[F
.field b:[D
.field c:[D
.field d:I
.field e:D
.field private f:Z
# direct methods
.method public constructor <init>()V
.registers 4
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const/4 v0, 0x0
.line 2
new-array v1, v0, [F
iput-object v1, p0, Lb/b/a/a/f;->a:[F
.line 3
new-array v1, v0, [D
iput-object v1, p0, Lb/b/a/a/f;->b:[D
const-wide v1, 0x401921fb54442d18L # 6.283185307179586
.line 4
iput-wide v1, p0, Lb/b/a/a/f;->e:D
.line 5
iput-boolean v0, p0, Lb/b/a/a/f;->f:Z
return-void
.end method
# virtual methods
.method a(D)D
.registers 13
const-wide/16 v0, 0x0
cmpg-double v2, p1, v0
if-gtz v2, :cond_c
const-wide p1, 0x3ee4f8b588e368f1L # 1.0E-5
goto :goto_17
:cond_c
const-wide/high16 v2, 0x3ff0000000000000L # 1.0
cmpl-double v4, p1, v2
if-ltz v4, :cond_17
const-wide p1, 0x3feffffde7210be9L # 0.999999
.line 25
:cond_17
:goto_17
iget-object v2, p0, Lb/b/a/a/f;->b:[D
invoke-static {v2, p1, p2}, Ljava/util/Arrays;->binarySearch([DD)I
move-result v2
if-lez v2, :cond_20
return-wide v0
:cond_20
if-eqz v2, :cond_48
neg-int v0, v2
add-int/lit8 v0, v0, -0x1
.line 26
iget-object v1, p0, Lb/b/a/a/f;->a:[F
aget v2, v1, v0
add-int/lit8 v3, v0, -0x1
aget v4, v1, v3
sub-float/2addr v2, v4
float-to-double v4, v2
iget-object v2, p0, Lb/b/a/a/f;->b:[D
aget-wide v6, v2, v0
aget-wide v8, v2, v3
sub-double/2addr v6, v8
invoke-static {v4, v5}, Ljava/lang/Double;->isNaN(D)Z
div-double/2addr v4, v6
mul-double p1, p1, v4
.line 27
aget v0, v1, v3
float-to-double v0, v0
aget-wide v6, v2, v3
mul-double v4, v4, v6
invoke-static {v0, v1}, Ljava/lang/Double;->isNaN(D)Z
sub-double/2addr v0, v4
add-double/2addr v0, p1
:cond_48
return-wide v0
.end method
.method public a()V
.registers 18
move-object/from16 v0, p0
const/4 v1, 0x0
const-wide/16 v2, 0x0
move-wide v5, v2
const/4 v4, 0x0
.line 11
:goto_7
iget-object v7, v0, Lb/b/a/a/f;->a:[F
array-length v8, v7
if-ge v4, v8, :cond_16
.line 12
aget v7, v7, v4
float-to-double v7, v7
invoke-static {v7, v8}, Ljava/lang/Double;->isNaN(D)Z
add-double/2addr v5, v7
add-int/lit8 v4, v4, 0x1
goto :goto_7
:cond_16
const/4 v4, 0x1
move-wide v8, v2
const/4 v7, 0x1
.line 13
:goto_19
iget-object v10, v0, Lb/b/a/a/f;->a:[F
array-length v11, v10
const/high16 v12, 0x40000000 # 2.0f
if-ge v7, v11, :cond_39
add-int/lit8 v11, v7, -0x1
.line 14
aget v13, v10, v11
aget v10, v10, v7
add-float/2addr v13, v10
div-float/2addr v13, v12
.line 15
iget-object v10, v0, Lb/b/a/a/f;->b:[D
aget-wide v14, v10, v7
aget-wide v11, v10, v11
sub-double/2addr v14, v11
float-to-double v10, v13
.line 16
invoke-static {v10, v11}, Ljava/lang/Double;->isNaN(D)Z
mul-double v14, v14, v10
add-double/2addr v8, v14
add-int/lit8 v7, v7, 0x1
goto :goto_19
:cond_39
const/4 v7, 0x0
.line 17
:goto_3a
iget-object v10, v0, Lb/b/a/a/f;->a:[F
array-length v11, v10
if-ge v7, v11, :cond_4f
.line 18
aget v11, v10, v7
float-to-double v13, v11
div-double v15, v5, v8
invoke-static {v13, v14}, Ljava/lang/Double;->isNaN(D)Z
mul-double v13, v13, v15
double-to-float v11, v13
aput v11, v10, v7
add-int/lit8 v7, v7, 0x1
goto :goto_3a
.line 19
:cond_4f
iget-object v5, v0, Lb/b/a/a/f;->c:[D
aput-wide v2, v5, v1
const/4 v1, 0x1
.line 20
:goto_54
iget-object v2, v0, Lb/b/a/a/f;->a:[F
array-length v3, v2
if-ge v1, v3, :cond_78
add-int/lit8 v3, v1, -0x1
.line 21
aget v5, v2, v3
aget v2, v2, v1
add-float/2addr v5, v2
div-float/2addr v5, v12
.line 22
iget-object v2, v0, Lb/b/a/a/f;->b:[D
aget-wide v6, v2, v1
aget-wide v8, v2, v3
sub-double/2addr v6, v8
.line 23
iget-object v2, v0, Lb/b/a/a/f;->c:[D
aget-wide v8, v2, v3
float-to-double v10, v5
invoke-static {v10, v11}, Ljava/lang/Double;->isNaN(D)Z
mul-double v6, v6, v10
add-double/2addr v8, v6
aput-wide v8, v2, v1
add-int/lit8 v1, v1, 0x1
goto :goto_54
.line 24
:cond_78
iput-boolean v4, v0, Lb/b/a/a/f;->f:Z
return-void
.end method
.method public a(DF)V
.registers 8
.line 2
iget-object v0, p0, Lb/b/a/a/f;->a:[F
array-length v0, v0
add-int/lit8 v0, v0, 0x1
.line 3
iget-object v1, p0, Lb/b/a/a/f;->b:[D
invoke-static {v1, p1, p2}, Ljava/util/Arrays;->binarySearch([DD)I
move-result v1
if-gez v1, :cond_10
neg-int v1, v1
add-int/lit8 v1, v1, -0x1
.line 4
:cond_10
iget-object v2, p0, Lb/b/a/a/f;->b:[D
invoke-static {v2, v0}, Ljava/util/Arrays;->copyOf([DI)[D
move-result-object v2
iput-object v2, p0, Lb/b/a/a/f;->b:[D
.line 5
iget-object v2, p0, Lb/b/a/a/f;->a:[F
invoke-static {v2, v0}, Ljava/util/Arrays;->copyOf([FI)[F
move-result-object v2
iput-object v2, p0, Lb/b/a/a/f;->a:[F
.line 6
new-array v2, v0, [D
iput-object v2, p0, Lb/b/a/a/f;->c:[D
.line 7
iget-object v2, p0, Lb/b/a/a/f;->b:[D
add-int/lit8 v3, v1, 0x1
sub-int/2addr v0, v1
add-int/lit8 v0, v0, -0x1
invoke-static {v2, v1, v2, v3, v0}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 8
iget-object v0, p0, Lb/b/a/a/f;->b:[D
aput-wide p1, v0, v1
.line 9
iget-object p1, p0, Lb/b/a/a/f;->a:[F
aput p3, p1, v1
const/4 p1, 0x0
.line 10
iput-boolean p1, p0, Lb/b/a/a/f;->f:Z
return-void
.end method
.method public a(I)V
.registers 2
.line 1
iput p1, p0, Lb/b/a/a/f;->d:I
return-void
.end method
.method b(D)D
.registers 13
const-wide/high16 v0, 0x3ff0000000000000L # 1.0
const-wide/16 v2, 0x0
cmpg-double v4, p1, v2
if-gez v4, :cond_a
move-wide p1, v2
goto :goto_f
:cond_a
cmpl-double v4, p1, v0
if-lez v4, :cond_f
move-wide p1, v0
.line 1
:cond_f
:goto_f
iget-object v4, p0, Lb/b/a/a/f;->b:[D
invoke-static {v4, p1, p2}, Ljava/util/Arrays;->binarySearch([DD)I
move-result v4
if-lez v4, :cond_18
goto :goto_5a
:cond_18
if-eqz v4, :cond_59
neg-int v0, v4
add-int/lit8 v0, v0, -0x1
.line 2
iget-object v1, p0, Lb/b/a/a/f;->a:[F
aget v2, v1, v0
add-int/lit8 v3, v0, -0x1
aget v4, v1, v3
sub-float/2addr v2, v4
float-to-double v4, v2
iget-object v2, p0, Lb/b/a/a/f;->b:[D
aget-wide v6, v2, v0
aget-wide v8, v2, v3
sub-double/2addr v6, v8
invoke-static {v4, v5}, Ljava/lang/Double;->isNaN(D)Z
div-double/2addr v4, v6
.line 3
iget-object v0, p0, Lb/b/a/a/f;->c:[D
aget-wide v6, v0, v3
aget v0, v1, v3
float-to-double v0, v0
aget-wide v8, v2, v3
mul-double v8, v8, v4
invoke-static {v0, v1}, Ljava/lang/Double;->isNaN(D)Z
sub-double/2addr v0, v8
aget-wide v8, v2, v3
sub-double v8, p1, v8
mul-double v0, v0, v8
add-double/2addr v6, v0
mul-double p1, p1, p1
aget-wide v0, v2, v3
aget-wide v8, v2, v3
mul-double v0, v0, v8
sub-double/2addr p1, v0
mul-double v4, v4, p1
const-wide/high16 p1, 0x4000000000000000L # 2.0
div-double/2addr v4, p1
add-double v0, v6, v4
goto :goto_5a
:cond_59
move-wide v0, v2
:goto_5a
return-wide v0
.end method
.method public c(D)D
.registers 12
.line 1
iget v0, p0, Lb/b/a/a/f;->d:I
const-wide/high16 v1, 0x4000000000000000L # 2.0
const-wide/high16 v3, 0x4010000000000000L # 4.0
packed-switch v0, :pswitch_data_6e
.line 2
iget-wide v0, p0, Lb/b/a/a/f;->e:D
invoke-virtual {p0, p1, p2}, Lb/b/a/a/f;->a(D)D
move-result-wide v2
mul-double v0, v0, v2
iget-wide v2, p0, Lb/b/a/a/f;->e:D
invoke-virtual {p0, p1, p2}, Lb/b/a/a/f;->b(D)D
move-result-wide p1
mul-double v2, v2, p1
invoke-static {v2, v3}, Ljava/lang/Math;->cos(D)D
move-result-wide p1
:goto_1d
mul-double v0, v0, p1
return-wide v0
.line 3
:pswitch_20
invoke-virtual {p0, p1, p2}, Lb/b/a/a/f;->a(D)D
move-result-wide v5
mul-double v5, v5, v3
invoke-virtual {p0, p1, p2}, Lb/b/a/a/f;->b(D)D
move-result-wide p1
mul-double p1, p1, v3
add-double/2addr p1, v1
rem-double/2addr p1, v3
sub-double/2addr p1, v1
:goto_2f
mul-double v5, v5, p1
return-wide v5
.line 4
:pswitch_32
iget-wide v0, p0, Lb/b/a/a/f;->e:D
neg-double v0, v0
invoke-virtual {p0, p1, p2}, Lb/b/a/a/f;->a(D)D
move-result-wide v2
mul-double v0, v0, v2
iget-wide v2, p0, Lb/b/a/a/f;->e:D
invoke-virtual {p0, p1, p2}, Lb/b/a/a/f;->b(D)D
move-result-wide p1
mul-double v2, v2, p1
invoke-static {v2, v3}, Ljava/lang/Math;->sin(D)D
move-result-wide p1
goto :goto_1d
.line 5
:pswitch_48
invoke-virtual {p0, p1, p2}, Lb/b/a/a/f;->a(D)D
move-result-wide p1
neg-double p1, p1
:goto_4d
mul-double p1, p1, v1
return-wide p1
.line 6
:pswitch_50
invoke-virtual {p0, p1, p2}, Lb/b/a/a/f;->a(D)D
move-result-wide p1
goto :goto_4d
.line 7
:pswitch_55
invoke-virtual {p0, p1, p2}, Lb/b/a/a/f;->a(D)D
move-result-wide v5
mul-double v5, v5, v3
invoke-virtual {p0, p1, p2}, Lb/b/a/a/f;->b(D)D
move-result-wide p1
mul-double p1, p1, v3
const-wide/high16 v7, 0x4008000000000000L # 3.0
add-double/2addr p1, v7
rem-double/2addr p1, v3
sub-double/2addr p1, v1
invoke-static {p1, p2}, Ljava/lang/Math;->signum(D)D
move-result-wide p1
goto :goto_2f
:pswitch_6b
const-wide/16 p1, 0x0
return-wide p1
:pswitch_data_6e
.packed-switch 0x1
:pswitch_6b
:pswitch_55
:pswitch_50
:pswitch_48
:pswitch_32
:pswitch_20
.end packed-switch
.end method
.method public d(D)D
.registers 10
.line 1
iget v0, p0, Lb/b/a/a/f;->d:I
const-wide/high16 v1, 0x4010000000000000L # 4.0
const-wide/high16 v3, 0x4000000000000000L # 2.0
const-wide/high16 v5, 0x3ff0000000000000L # 1.0
packed-switch v0, :pswitch_data_66
.line 2
iget-wide v0, p0, Lb/b/a/a/f;->e:D
invoke-virtual {p0, p1, p2}, Lb/b/a/a/f;->b(D)D
move-result-wide p1
mul-double v0, v0, p1
invoke-static {v0, v1}, Ljava/lang/Math;->sin(D)D
move-result-wide p1
return-wide p1
.line 3
:pswitch_18
invoke-virtual {p0, p1, p2}, Lb/b/a/a/f;->b(D)D
move-result-wide p1
mul-double p1, p1, v1
rem-double/2addr p1, v1
sub-double/2addr p1, v3
invoke-static {p1, p2}, Ljava/lang/Math;->abs(D)D
move-result-wide p1
sub-double p1, v5, p1
mul-double p1, p1, p1
:goto_28
sub-double/2addr v5, p1
return-wide v5
.line 4
:pswitch_2a
iget-wide v0, p0, Lb/b/a/a/f;->e:D
invoke-virtual {p0, p1, p2}, Lb/b/a/a/f;->b(D)D
move-result-wide p1
mul-double v0, v0, p1
invoke-static {v0, v1}, Ljava/lang/Math;->cos(D)D
move-result-wide p1
return-wide p1
.line 5
:pswitch_37
invoke-virtual {p0, p1, p2}, Lb/b/a/a/f;->b(D)D
move-result-wide p1
mul-double p1, p1, v3
add-double/2addr p1, v5
rem-double/2addr p1, v3
goto :goto_28
.line 6
:pswitch_40
invoke-virtual {p0, p1, p2}, Lb/b/a/a/f;->b(D)D
move-result-wide p1
mul-double p1, p1, v3
add-double/2addr p1, v5
rem-double/2addr p1, v3
sub-double/2addr p1, v5
return-wide p1
.line 7
:pswitch_4a
invoke-virtual {p0, p1, p2}, Lb/b/a/a/f;->b(D)D
move-result-wide p1
mul-double p1, p1, v1
add-double/2addr p1, v5
rem-double/2addr p1, v1
sub-double/2addr p1, v3
invoke-static {p1, p2}, Ljava/lang/Math;->abs(D)D
move-result-wide p1
goto :goto_28
:pswitch_58
const-wide/high16 v0, 0x3fe0000000000000L # 0.5
.line 8
invoke-virtual {p0, p1, p2}, Lb/b/a/a/f;->b(D)D
move-result-wide p1
rem-double/2addr p1, v5
sub-double/2addr v0, p1
invoke-static {v0, v1}, Ljava/lang/Math;->signum(D)D
move-result-wide p1
return-wide p1
nop
:pswitch_data_66
.packed-switch 0x1
:pswitch_58
:pswitch_4a
:pswitch_40
:pswitch_37
:pswitch_2a
:pswitch_18
.end packed-switch
.end method
.method public toString()Ljava/lang/String;
.registers 3
.line 1
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "pos ="
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p0, Lb/b/a/a/f;->b:[D
invoke-static {v1}, Ljava/util/Arrays;->toString([D)Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, " period="
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p0, Lb/b/a/a/f;->a:[F
invoke-static {v1}, Ljava/util/Arrays;->toString([F)Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
return-object v0
.end method