SecT131FieldElement.smali

.class public Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;
.super Lorg/spongycastle/math/ec/ECFieldElement;
.source "SecT131FieldElement.java"


# instance fields
.field protected x:[J


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

    .prologue
    .line 25
    invoke-direct {p0}, Lorg/spongycastle/math/ec/ECFieldElement;-><init>()V

    .line 26
    invoke-static {}, Lorg/spongycastle/math/raw/Nat192;->create64()[J

    move-result-object v0

    iput-object v0, p0, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    .line 27
    return-void
.end method

.method public constructor <init>(Ljava/math/BigInteger;)V
    .registers 4

    .prologue
    .line 15
    invoke-direct {p0}, Lorg/spongycastle/math/ec/ECFieldElement;-><init>()V

    .line 16
    if-eqz p1, :cond_13

    invoke-virtual {p1}, Ljava/math/BigInteger;->signum()I

    move-result v0

    if-ltz v0, :cond_13

    invoke-virtual {p1}, Ljava/math/BigInteger;->bitLength()I

    move-result v0

    const/16 v1, 0x83

    if-le v0, v1, :cond_1b

    .line 18
    :cond_13
    new-instance v0, Ljava/lang/IllegalArgumentException;

    const-string v1, "x value invalid for SecT131FieldElement"

    invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V

    throw v0

    .line 21
    :cond_1b
    invoke-static {p1}, Lorg/spongycastle/math/ec/custom/sec/SecT131Field;->fromBigInteger(Ljava/math/BigInteger;)[J

    move-result-object v0

    iput-object v0, p0, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    .line 22
    return-void
.end method

.method protected constructor <init>([J)V
    .registers 2

    .prologue
    .line 30
    invoke-direct {p0}, Lorg/spongycastle/math/ec/ECFieldElement;-><init>()V

    .line 31
    iput-object p1, p0, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    .line 32
    return-void
.end method


# virtual methods
.method public add(Lorg/spongycastle/math/ec/ECFieldElement;)Lorg/spongycastle/math/ec/ECFieldElement;
    .registers 5

    .prologue
    .line 71
    invoke-static {}, Lorg/spongycastle/math/raw/Nat192;->create64()[J

    move-result-object v0

    .line 72
    iget-object v1, p0, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    check-cast p1, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;

    iget-object v2, p1, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    invoke-static {v1, v2, v0}, Lorg/spongycastle/math/ec/custom/sec/SecT131Field;->add([J[J[J)V

    .line 73
    new-instance v1, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;

    invoke-direct {v1, v0}, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;-><init>([J)V

    return-object v1
.end method

.method public addOne()Lorg/spongycastle/math/ec/ECFieldElement;
    .registers 3

    .prologue
    .line 78
    invoke-static {}, Lorg/spongycastle/math/raw/Nat192;->create64()[J

    move-result-object v0

    .line 79
    iget-object v1, p0, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    invoke-static {v1, v0}, Lorg/spongycastle/math/ec/custom/sec/SecT131Field;->addOne([J[J)V

    .line 80
    new-instance v1, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;

    invoke-direct {v1, v0}, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;-><init>([J)V

    return-object v1
.end method

.method public divide(Lorg/spongycastle/math/ec/ECFieldElement;)Lorg/spongycastle/math/ec/ECFieldElement;
    .registers 3

    .prologue
    .line 117
    invoke-virtual {p1}, Lorg/spongycastle/math/ec/ECFieldElement;->invert()Lorg/spongycastle/math/ec/ECFieldElement;

    move-result-object v0

    invoke-virtual {p0, v0}, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->multiply(Lorg/spongycastle/math/ec/ECFieldElement;)Lorg/spongycastle/math/ec/ECFieldElement;

    move-result-object v0

    return-object v0
.end method

.method public equals(Ljava/lang/Object;)Z
    .registers 4

    .prologue
    .line 204
    if-ne p1, p0, :cond_4

    .line 206
    const/4 v0, 0x1

    .line 215
    :goto_3
    return v0

    .line 209
    :cond_4
    instance-of v0, p1, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;

    if-nez v0, :cond_a

    .line 211
    const/4 v0, 0x0

    goto :goto_3

    .line 214
    :cond_a
    check-cast p1, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;

    .line 215
    iget-object v0, p0, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    iget-object v1, p1, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    invoke-static {v0, v1}, Lorg/spongycastle/math/raw/Nat192;->eq64([J[J)Z

    move-result v0

    goto :goto_3
.end method

.method public getFieldName()Ljava/lang/String;
    .registers 2

    .prologue
    .line 61
    const-string v0, "SecT131Field"

    return-object v0
.end method

.method public getFieldSize()I
    .registers 2

    .prologue
    .line 66
    const/16 v0, 0x83

    return v0
.end method

.method public getK1()I
    .registers 2

    .prologue
    .line 189
    const/4 v0, 0x2

    return v0
.end method

.method public getK2()I
    .registers 2

    .prologue
    .line 194
    const/4 v0, 0x3

    return v0
.end method

.method public getK3()I
    .registers 2

    .prologue
    .line 199
    const/16 v0, 0x8

    return v0
.end method

.method public getM()I
    .registers 2

    .prologue
    .line 184
    const/16 v0, 0x83

    return v0
.end method

.method public getRepresentation()I
    .registers 2

    .prologue
    .line 179
    const/4 v0, 0x3

    return v0
.end method

.method public hashCode()I
    .registers 5

    .prologue
    .line 220
    const v0, 0x202f8

    iget-object v1, p0, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    const/4 v2, 0x0

    const/4 v3, 0x3

    invoke-static {v1, v2, v3}, Lorg/spongycastle/util/Arrays;->hashCode([JII)I

    move-result v1

    xor-int/2addr v0, v1

    return v0
.end method

.method public invert()Lorg/spongycastle/math/ec/ECFieldElement;
    .registers 3

    .prologue
    .line 165
    invoke-static {}, Lorg/spongycastle/math/raw/Nat192;->create64()[J

    move-result-object v0

    .line 166
    iget-object v1, p0, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    invoke-static {v1, v0}, Lorg/spongycastle/math/ec/custom/sec/SecT131Field;->invert([J[J)V

    .line 167
    new-instance v1, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;

    invoke-direct {v1, v0}, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;-><init>([J)V

    return-object v1
.end method

.method public isOne()Z
    .registers 2

    .prologue
    .line 41
    iget-object v0, p0, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    invoke-static {v0}, Lorg/spongycastle/math/raw/Nat192;->isOne64([J)Z

    move-result v0

    return v0
.end method

.method public isZero()Z
    .registers 2

    .prologue
    .line 46
    iget-object v0, p0, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    invoke-static {v0}, Lorg/spongycastle/math/raw/Nat192;->isZero64([J)Z

    move-result v0

    return v0
.end method

.method public multiply(Lorg/spongycastle/math/ec/ECFieldElement;)Lorg/spongycastle/math/ec/ECFieldElement;
    .registers 5

    .prologue
    .line 91
    invoke-static {}, Lorg/spongycastle/math/raw/Nat192;->create64()[J

    move-result-object v0

    .line 92
    iget-object v1, p0, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    check-cast p1, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;

    iget-object v2, p1, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    invoke-static {v1, v2, v0}, Lorg/spongycastle/math/ec/custom/sec/SecT131Field;->multiply([J[J[J)V

    .line 93
    new-instance v1, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;

    invoke-direct {v1, v0}, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;-><init>([J)V

    return-object v1
.end method

.method public multiplyMinusProduct(Lorg/spongycastle/math/ec/ECFieldElement;Lorg/spongycastle/math/ec/ECFieldElement;Lorg/spongycastle/math/ec/ECFieldElement;)Lorg/spongycastle/math/ec/ECFieldElement;
    .registers 5

    .prologue
    .line 98
    invoke-virtual {p0, p1, p2, p3}, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->multiplyPlusProduct(Lorg/spongycastle/math/ec/ECFieldElement;Lorg/spongycastle/math/ec/ECFieldElement;Lorg/spongycastle/math/ec/ECFieldElement;)Lorg/spongycastle/math/ec/ECFieldElement;

    move-result-object v0

    return-object v0
.end method

.method public multiplyPlusProduct(Lorg/spongycastle/math/ec/ECFieldElement;Lorg/spongycastle/math/ec/ECFieldElement;Lorg/spongycastle/math/ec/ECFieldElement;)Lorg/spongycastle/math/ec/ECFieldElement;
    .registers 9

    .prologue
    .line 103
    iget-object v0, p0, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    check-cast p1, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;

    iget-object v1, p1, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    .line 104
    check-cast p2, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;

    iget-object v2, p2, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    check-cast p3, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;

    iget-object v3, p3, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    .line 106
    const/4 v4, 0x5

    invoke-static {v4}, Lorg/spongycastle/math/raw/Nat;->create64(I)[J

    move-result-object v4

    .line 107
    invoke-static {v0, v1, v4}, Lorg/spongycastle/math/ec/custom/sec/SecT131Field;->multiplyAddToExt([J[J[J)V

    .line 108
    invoke-static {v2, v3, v4}, Lorg/spongycastle/math/ec/custom/sec/SecT131Field;->multiplyAddToExt([J[J[J)V

    .line 110
    invoke-static {}, Lorg/spongycastle/math/raw/Nat192;->create64()[J

    move-result-object v0

    .line 111
    invoke-static {v4, v0}, Lorg/spongycastle/math/ec/custom/sec/SecT131Field;->reduce([J[J)V

    .line 112
    new-instance v1, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;

    invoke-direct {v1, v0}, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;-><init>([J)V

    return-object v1
.end method

.method public negate()Lorg/spongycastle/math/ec/ECFieldElement;
    .registers 1

    .prologue
    .line 122
    return-object p0
.end method

.method public sqrt()Lorg/spongycastle/math/ec/ECFieldElement;
    .registers 3

    .prologue
    .line 172
    invoke-static {}, Lorg/spongycastle/math/raw/Nat192;->create64()[J

    move-result-object v0

    .line 173
    iget-object v1, p0, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    invoke-static {v1, v0}, Lorg/spongycastle/math/ec/custom/sec/SecT131Field;->sqrt([J[J)V

    .line 174
    new-instance v1, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;

    invoke-direct {v1, v0}, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;-><init>([J)V

    return-object v1
.end method

.method public square()Lorg/spongycastle/math/ec/ECFieldElement;
    .registers 3

    .prologue
    .line 127
    invoke-static {}, Lorg/spongycastle/math/raw/Nat192;->create64()[J

    move-result-object v0

    .line 128
    iget-object v1, p0, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    invoke-static {v1, v0}, Lorg/spongycastle/math/ec/custom/sec/SecT131Field;->square([J[J)V

    .line 129
    new-instance v1, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;

    invoke-direct {v1, v0}, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;-><init>([J)V

    return-object v1
.end method

.method public squareMinusProduct(Lorg/spongycastle/math/ec/ECFieldElement;Lorg/spongycastle/math/ec/ECFieldElement;)Lorg/spongycastle/math/ec/ECFieldElement;
    .registers 4

    .prologue
    .line 134
    invoke-virtual {p0, p1, p2}, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->squarePlusProduct(Lorg/spongycastle/math/ec/ECFieldElement;Lorg/spongycastle/math/ec/ECFieldElement;)Lorg/spongycastle/math/ec/ECFieldElement;

    move-result-object v0

    return-object v0
.end method

.method public squarePlusProduct(Lorg/spongycastle/math/ec/ECFieldElement;Lorg/spongycastle/math/ec/ECFieldElement;)Lorg/spongycastle/math/ec/ECFieldElement;
    .registers 7

    .prologue
    .line 139
    iget-object v0, p0, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    .line 140
    check-cast p1, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;

    iget-object v1, p1, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    check-cast p2, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;

    iget-object v2, p2, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    .line 142
    const/4 v3, 0x5

    invoke-static {v3}, Lorg/spongycastle/math/raw/Nat;->create64(I)[J

    move-result-object v3

    .line 143
    invoke-static {v0, v3}, Lorg/spongycastle/math/ec/custom/sec/SecT131Field;->squareAddToExt([J[J)V

    .line 144
    invoke-static {v1, v2, v3}, Lorg/spongycastle/math/ec/custom/sec/SecT131Field;->multiplyAddToExt([J[J[J)V

    .line 146
    invoke-static {}, Lorg/spongycastle/math/raw/Nat192;->create64()[J

    move-result-object v0

    .line 147
    invoke-static {v3, v0}, Lorg/spongycastle/math/ec/custom/sec/SecT131Field;->reduce([J[J)V

    .line 148
    new-instance v1, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;

    invoke-direct {v1, v0}, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;-><init>([J)V

    return-object v1
.end method

.method public squarePow(I)Lorg/spongycastle/math/ec/ECFieldElement;
    .registers 4

    .prologue
    .line 153
    if-gtz p1, :cond_3

    .line 160
    :goto_2
    return-object p0

    .line 158
    :cond_3
    invoke-static {}, Lorg/spongycastle/math/raw/Nat192;->create64()[J

    move-result-object v0

    .line 159
    iget-object v1, p0, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    invoke-static {v1, p1, v0}, Lorg/spongycastle/math/ec/custom/sec/SecT131Field;->squareN([JI[J)V

    .line 160
    new-instance p0, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;

    invoke-direct {p0, v0}, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;-><init>([J)V

    goto :goto_2
.end method

.method public subtract(Lorg/spongycastle/math/ec/ECFieldElement;)Lorg/spongycastle/math/ec/ECFieldElement;
    .registers 3

    .prologue
    .line 86
    invoke-virtual {p0, p1}, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->add(Lorg/spongycastle/math/ec/ECFieldElement;)Lorg/spongycastle/math/ec/ECFieldElement;

    move-result-object v0

    return-object v0
.end method

.method public testBitZero()Z
    .registers 7

    .prologue
    const/4 v0, 0x0

    .line 51
    iget-object v1, p0, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    aget-wide v2, v1, v0

    const-wide/16 v4, 0x1

    and-long/2addr v2, v4

    const-wide/16 v4, 0x0

    cmp-long v1, v2, v4

    if-eqz v1, :cond_f

    const/4 v0, 0x1

    :cond_f
    return v0
.end method

.method public toBigInteger()Ljava/math/BigInteger;
    .registers 2

    .prologue
    .line 56
    iget-object v0, p0, Lorg/spongycastle/math/ec/custom/sec/SecT131FieldElement;->x:[J

    invoke-static {v0}, Lorg/spongycastle/math/raw/Nat192;->toBigInteger64([J)Ljava/math/BigInteger;

    move-result-object v0

    return-object v0
.end method