Operator.smali

.class final Lcom/facebook/appevents/ml/Operator;
.super Ljava/lang/Object;
.source "Operator.java"


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

    .line 1
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V

    return-void
.end method

.method static add([F[FIII)[F
    .registers 11

    const/4 v0, 0x0

    const/4 v1, 0x0

    :goto_2
    mul-int v2, p2, p3

    if-ge v1, v2, :cond_19

    const/4 v2, 0x0

    :goto_7
    if-ge v2, p4, :cond_16

    mul-int v3, v1, p4

    add-int/2addr v3, v2

    .line 1
    aget v4, p0, v3

    aget v5, p1, v2

    add-float/2addr v4, v5

    aput v4, p0, v3

    add-int/lit8 v2, v2, 0x1

    goto :goto_7

    :cond_16
    add-int/lit8 v1, v1, 0x1

    goto :goto_2

    :cond_19
    return-object p0
.end method

.method static concatenate([F[F)[F
    .registers 5

    .line 1
    array-length v0, p0

    array-length v1, p1

    add-int/2addr v0, v1

    new-array v0, v0, [F

    .line 2
    array-length v1, p0

    const/4 v2, 0x0

    invoke-static {p0, v2, v0, v2, v1}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V

    .line 3
    array-length p0, p0

    array-length v1, p1

    invoke-static {p1, v2, v0, p0, v1}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V

    return-object v0
.end method

.method static conv1D([F[FIIIII)[F
    .registers 22

    move/from16 v0, p2

    move/from16 v1, p4

    move/from16 v2, p5

    move/from16 v3, p6

    sub-int v4, p3, v2

    add-int/lit8 v4, v4, 0x1

    mul-int v5, v0, v4

    mul-int v5, v5, v3

    .line 1
    new-array v5, v5, [F

    const/4 v6, 0x0

    const/4 v7, 0x0

    :goto_14
    if-ge v7, v0, :cond_56

    const/4 v8, 0x0

    :goto_17
    if-ge v8, v3, :cond_53

    const/4 v9, 0x0

    :goto_1a
    if-ge v9, v4, :cond_50

    const/4 v10, 0x0

    const/4 v10, 0x0

    const/4 v11, 0x0

    :goto_1f
    if-ge v10, v2, :cond_43

    move v12, v11

    const/4 v11, 0x0

    :goto_23
    if-ge v11, v1, :cond_3f

    mul-int v13, p3, v1

    mul-int v13, v13, v7

    add-int v14, v10, v9

    mul-int v14, v14, v1

    add-int/2addr v13, v14

    add-int/2addr v13, v11

    .line 2
    aget v13, p0, v13

    mul-int v14, v10, v1

    add-int/2addr v14, v11

    mul-int v14, v14, v3

    add-int/2addr v14, v8

    aget v14, p1, v14

    mul-float v13, v13, v14

    add-float/2addr v12, v13

    add-int/lit8 v11, v11, 0x1

    goto :goto_23

    :cond_3f
    add-int/lit8 v10, v10, 0x1

    move v11, v12

    goto :goto_1f

    :cond_43
    mul-int v10, v3, v4

    mul-int v10, v10, v7

    mul-int v12, v9, v3

    add-int/2addr v10, v12

    add-int/2addr v10, v8

    .line 3
    aput v11, v5, v10

    add-int/lit8 v9, v9, 0x1

    goto :goto_1a

    :cond_50
    add-int/lit8 v8, v8, 0x1

    goto :goto_17

    :cond_53
    add-int/lit8 v7, v7, 0x1

    goto :goto_14

    :cond_56
    return-object v5
.end method

.method static dense([F[F[FIII)[F
    .registers 10

    .line 1
    invoke-static {p0, p1, p3, p4, p5}, Lcom/facebook/appevents/ml/Operator;->mul([F[FIII)[F

    move-result-object p0

    const/4 p1, 0x0

    const/4 p4, 0x0

    :goto_6
    if-ge p4, p3, :cond_1b

    const/4 v0, 0x0

    :goto_9
    if-ge v0, p5, :cond_18

    mul-int v1, p4, p5

    add-int/2addr v1, v0

    .line 2
    aget v2, p0, v1

    aget v3, p2, v0

    add-float/2addr v2, v3

    aput v2, p0, v1

    add-int/lit8 v0, v0, 0x1

    goto :goto_9

    :cond_18
    add-int/lit8 p4, p4, 0x1

    goto :goto_6

    :cond_1b
    return-object p0
.end method

.method static embedding([I[FIII)[F
    .registers 13

    mul-int v0, p2, p3

    mul-int v0, v0, p4

    .line 1
    new-array v0, v0, [F

    const/4 v1, 0x0

    const/4 v2, 0x0

    :goto_8
    if-ge v2, p2, :cond_2d

    const/4 v3, 0x0

    :goto_b
    if-ge v3, p3, :cond_2a

    mul-int v4, v2, p3

    add-int/2addr v4, v3

    .line 2
    aget v4, p0, v4

    const/4 v5, 0x0

    :goto_13
    if-ge v5, p4, :cond_27

    mul-int v6, p4, p3

    mul-int v6, v6, v2

    mul-int v7, p4, v3

    add-int/2addr v6, v7

    add-int/2addr v6, v5

    mul-int v7, v4, p4

    add-int/2addr v7, v5

    .line 3
    aget v7, p1, v7

    aput v7, v0, v6

    add-int/lit8 v5, v5, 0x1

    goto :goto_13

    :cond_27
    add-int/lit8 v3, v3, 0x1

    goto :goto_b

    :cond_2a
    add-int/lit8 v2, v2, 0x1

    goto :goto_8

    :cond_2d
    return-object v0
.end method

.method static maxPool1D([FIII)[F
    .registers 12

    sub-int/2addr p1, p3

    add-int/lit8 p1, p1, 0x1

    mul-int v0, p1, p2

    .line 1
    new-array v0, v0, [F

    const/4 v1, 0x0

    const/4 v2, 0x0

    :goto_9
    if-ge v2, p2, :cond_2c

    const/4 v3, 0x0

    :goto_c
    if-ge v3, p1, :cond_29

    move v4, v3

    :goto_f
    add-int v5, v3, p3

    if-ge v4, v5, :cond_26

    mul-int v5, v3, p2

    add-int/2addr v5, v2

    .line 2
    aget v6, v0, v5

    mul-int v7, v4, p2

    add-int/2addr v7, v2

    aget v7, p0, v7

    invoke-static {v6, v7}, Ljava/lang/Math;->max(FF)F

    move-result v6

    aput v6, v0, v5

    add-int/lit8 v4, v4, 0x1

    goto :goto_f

    :cond_26
    add-int/lit8 v3, v3, 0x1

    goto :goto_c

    :cond_29
    add-int/lit8 v2, v2, 0x1

    goto :goto_9

    :cond_2c
    return-object v0
.end method

.method static mul([F[FIII)[F
    .registers 14

    mul-int v0, p2, p4

    .line 1
    new-array v0, v0, [F

    const/4 v1, 0x0

    const/4 v2, 0x0

    :goto_6
    if-ge v2, p2, :cond_2e

    const/4 v3, 0x0

    :goto_9
    if-ge v3, p4, :cond_2b

    mul-int v4, v2, p4

    add-int/2addr v4, v3

    const/4 v5, 0x0

    .line 2
    aput v5, v0, v4

    const/4 v5, 0x0

    :goto_12
    if-ge v5, p3, :cond_28

    .line 3
    aget v6, v0, v4

    mul-int v7, v2, p3

    add-int/2addr v7, v5

    aget v7, p0, v7

    mul-int v8, v5, p4

    add-int/2addr v8, v3

    aget v8, p1, v8

    mul-float v7, v7, v8

    add-float/2addr v6, v7

    aput v6, v0, v4

    add-int/lit8 v5, v5, 0x1

    goto :goto_12

    :cond_28
    add-int/lit8 v3, v3, 0x1

    goto :goto_9

    :cond_2b
    add-int/lit8 v2, v2, 0x1

    goto :goto_6

    :cond_2e
    return-object v0
.end method

.method static relu([FI)V
    .registers 5

    const/4 v0, 0x0

    :goto_1
    if-ge v0, p1, :cond_f

    .line 1
    aget v1, p0, v0

    const/4 v2, 0x0

    cmpg-float v1, v1, v2

    if-gez v1, :cond_c

    .line 2
    aput v2, p0, v0

    :cond_c
    add-int/lit8 v0, v0, 0x1

    goto :goto_1

    :cond_f
    return-void
.end method

.method static softmax([FI)V
    .registers 7

    const/4 v0, 0x0

    const/4 v1, 0x1

    const/4 v1, 0x0

    const/4 v2, 0x1

    :goto_4
    if-ge v1, p1, :cond_11

    .line 1
    aget v3, p0, v1

    cmpl-float v3, v3, v2

    if-lez v3, :cond_e

    .line 2
    aget v2, p0, v1

    :cond_e
    add-int/lit8 v1, v1, 0x1

    goto :goto_4

    :cond_11
    const/4 v1, 0x0

    :goto_12
    if-ge v1, p1, :cond_22

    .line 3
    aget v3, p0, v1

    sub-float/2addr v3, v2

    float-to-double v3, v3

    invoke-static {v3, v4}, Ljava/lang/Math;->exp(D)D

    move-result-wide v3

    double-to-float v3, v3

    aput v3, p0, v1

    add-int/lit8 v1, v1, 0x1

    goto :goto_12

    :cond_22
    const/4 v1, 0x0

    const/4 v1, 0x0

    const/4 v2, 0x0

    :goto_25
    if-ge v1, p1, :cond_2d

    .line 4
    aget v3, p0, v1

    add-float/2addr v2, v3

    add-int/lit8 v1, v1, 0x1

    goto :goto_25

    :cond_2d
    :goto_2d
    if-ge v0, p1, :cond_37

    .line 5
    aget v1, p0, v0

    div-float/2addr v1, v2

    aput v1, p0, v0

    add-int/lit8 v0, v0, 0x1

    goto :goto_2d

    :cond_37
    return-void
.end method

.method static transpose2D([FII)[F
    .registers 9

    mul-int v0, p1, p2

    .line 1
    new-array v0, v0, [F

    const/4 v1, 0x0

    const/4 v2, 0x0

    :goto_6
    if-ge v2, p1, :cond_1b

    const/4 v3, 0x0

    :goto_9
    if-ge v3, p2, :cond_18

    mul-int v4, v3, p1

    add-int/2addr v4, v2

    mul-int v5, v2, p2

    add-int/2addr v5, v3

    .line 2
    aget v5, p0, v5

    aput v5, v0, v4

    add-int/lit8 v3, v3, 0x1

    goto :goto_9

    :cond_18
    add-int/lit8 v2, v2, 0x1

    goto :goto_6

    :cond_1b
    return-object v0
.end method

.method static transpose3D([FIII)[F
    .registers 12

    mul-int v0, p1, p2

    mul-int v0, v0, p3

    .line 1
    new-array v0, v0, [F

    const/4 v1, 0x0

    const/4 v2, 0x0

    :goto_8
    if-ge v2, p1, :cond_2d

    const/4 v3, 0x0

    :goto_b
    if-ge v3, p2, :cond_2a

    const/4 v4, 0x0

    :goto_e
    if-ge v4, p3, :cond_27

    mul-int v5, v4, p1

    mul-int v5, v5, p2

    mul-int v6, v3, p1

    add-int/2addr v5, v6

    add-int/2addr v5, v2

    mul-int v6, v2, p2

    mul-int v6, v6, p3

    mul-int v7, v3, p3

    add-int/2addr v6, v7

    add-int/2addr v6, v4

    .line 2
    aget v6, p0, v6

    aput v6, v0, v5

    add-int/lit8 v4, v4, 0x1

    goto :goto_e

    :cond_27
    add-int/lit8 v3, v3, 0x1

    goto :goto_b

    :cond_2a
    add-int/lit8 v2, v2, 0x1

    goto :goto_8

    :cond_2d
    return-object v0
.end method