GF2nField.smali
.class public abstract Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;
.super Ljava/lang/Object;
.source "GF2nField.java"
# instance fields
.field protected fieldPolynomial:Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;
.field protected fields:Ljava/util/Vector;
.field protected mDegree:I
.field protected matrices:Ljava/util/Vector;
.field protected final random:Ljava/security/SecureRandom;
# direct methods
.method protected constructor <init>(Ljava/security/SecureRandom;)V
.registers 2
.prologue
.line 44
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 45
iput-object p1, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->random:Ljava/security/SecureRandom;
.line 46
return-void
.end method
# virtual methods
.method protected abstract computeCOBMatrix(Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;)V
.end method
.method protected abstract computeFieldPolynomial()V
.end method
.method public final convert(Lorg/spongycastle/pqc/math/linearalgebra/GF2nElement;Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;)Lorg/spongycastle/pqc/math/linearalgebra/GF2nElement;
.registers 8
.prologue
.line 238
if-ne p2, p0, :cond_9
.line 240
invoke-virtual {p1}, Lorg/spongycastle/pqc/math/linearalgebra/GF2nElement;->clone()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nElement;
.line 289
:goto_8
return-object v0
.line 242
:cond_9
iget-object v0, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->fieldPolynomial:Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;
iget-object v1, p2, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->fieldPolynomial:Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;
invoke-virtual {v0, v1}, Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_1a
.line 244
invoke-virtual {p1}, Lorg/spongycastle/pqc/math/linearalgebra/GF2nElement;->clone()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nElement;
goto :goto_8
.line 246
:cond_1a
iget v0, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->mDegree:I
iget v1, p2, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->mDegree:I
if-eq v0, v1, :cond_28
.line 248
new-instance v0, Ljava/lang/RuntimeException;
const-string v1, "GF2nField.convert: B1 has a different degree and thus cannot be coverted to!"
invoke-direct {v0, v1}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw v0
.line 254
:cond_28
iget-object v0, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->fields:Ljava/util/Vector;
invoke-virtual {v0, p2}, Ljava/util/Vector;->indexOf(Ljava/lang/Object;)I
move-result v0
.line 255
const/4 v1, -0x1
if-ne v0, v1, :cond_3a
.line 257
invoke-virtual {p0, p2}, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->computeCOBMatrix(Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;)V
.line 258
iget-object v0, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->fields:Ljava/util/Vector;
invoke-virtual {v0, p2}, Ljava/util/Vector;->indexOf(Ljava/lang/Object;)I
move-result v0
.line 260
:cond_3a
iget-object v1, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->matrices:Ljava/util/Vector;
invoke-virtual {v1, v0}, Ljava/util/Vector;->elementAt(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, [Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;
.line 262
invoke-virtual {p1}, Lorg/spongycastle/pqc/math/linearalgebra/GF2nElement;->clone()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lorg/spongycastle/pqc/math/linearalgebra/GF2nElement;
.line 263
instance-of v2, v1, Lorg/spongycastle/pqc/math/linearalgebra/GF2nONBElement;
if-eqz v2, :cond_52
move-object v2, v1
.line 266
check-cast v2, Lorg/spongycastle/pqc/math/linearalgebra/GF2nONBElement;
invoke-virtual {v2}, Lorg/spongycastle/pqc/math/linearalgebra/GF2nONBElement;->reverseOrder()V
.line 268
:cond_52
new-instance v2, Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;
iget v3, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->mDegree:I
invoke-virtual {v1}, Lorg/spongycastle/pqc/math/linearalgebra/GF2nElement;->toFlexiBigInt()Ljava/math/BigInteger;
move-result-object v1
invoke-direct {v2, v3, v1}, Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;-><init>(ILjava/math/BigInteger;)V
.line 269
iget v1, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->mDegree:I
invoke-virtual {v2, v1}, Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;->expandN(I)V
.line 270
new-instance v3, Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;
iget v1, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->mDegree:I
invoke-direct {v3, v1}, Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;-><init>(I)V
.line 271
const/4 v1, 0x0
:goto_6a
iget v4, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->mDegree:I
if-ge v1, v4, :cond_81
.line 273
aget-object v4, v0, v1
invoke-virtual {v2, v4}, Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;->vectorMult(Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;)Z
move-result v4
if-eqz v4, :cond_7e
.line 275
iget v4, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->mDegree:I
add-int/lit8 v4, v4, -0x1
sub-int/2addr v4, v1
invoke-virtual {v3, v4}, Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;->setBit(I)V
.line 271
:cond_7e
add-int/lit8 v1, v1, 0x1
goto :goto_6a
.line 278
:cond_81
instance-of v0, p2, Lorg/spongycastle/pqc/math/linearalgebra/GF2nPolynomialField;
if-eqz v0, :cond_8e
.line 280
new-instance v0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nPolynomialElement;
check-cast p2, Lorg/spongycastle/pqc/math/linearalgebra/GF2nPolynomialField;
invoke-direct {v0, p2, v3}, Lorg/spongycastle/pqc/math/linearalgebra/GF2nPolynomialElement;-><init>(Lorg/spongycastle/pqc/math/linearalgebra/GF2nPolynomialField;Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;)V
goto/16 :goto_8
.line 283
:cond_8e
instance-of v0, p2, Lorg/spongycastle/pqc/math/linearalgebra/GF2nONBField;
if-eqz v0, :cond_a2
.line 285
new-instance v0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nONBElement;
check-cast p2, Lorg/spongycastle/pqc/math/linearalgebra/GF2nONBField;
.line 286
invoke-virtual {v3}, Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;->toFlexiBigInt()Ljava/math/BigInteger;
move-result-object v1
invoke-direct {v0, p2, v1}, Lorg/spongycastle/pqc/math/linearalgebra/GF2nONBElement;-><init>(Lorg/spongycastle/pqc/math/linearalgebra/GF2nONBField;Ljava/math/BigInteger;)V
.line 288
invoke-virtual {v0}, Lorg/spongycastle/pqc/math/linearalgebra/GF2nONBElement;->reverseOrder()V
goto/16 :goto_8
.line 293
:cond_a2
new-instance v0, Ljava/lang/RuntimeException;
const-string v1, "GF2nField.convert: B1 must be an instance of GF2nPolynomialField or GF2nONBField!"
invoke-direct {v0, v1}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public final equals(Ljava/lang/Object;)Z
.registers 5
.prologue
const/4 v0, 0x0
.line 81
if-eqz p1, :cond_7
instance-of v1, p1, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;
if-nez v1, :cond_8
.line 106
:cond_7
:goto_7
return v0
.line 86
:cond_8
check-cast p1, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;
.line 88
iget v1, p1, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->mDegree:I
iget v2, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->mDegree:I
if-ne v1, v2, :cond_7
.line 92
iget-object v1, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->fieldPolynomial:Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;
iget-object v2, p1, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->fieldPolynomial:Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;
invoke-virtual {v1, v2}, Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;->equals(Ljava/lang/Object;)Z
move-result v1
if-eqz v1, :cond_7
.line 96
instance-of v1, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nPolynomialField;
if-eqz v1, :cond_22
instance-of v1, p1, Lorg/spongycastle/pqc/math/linearalgebra/GF2nPolynomialField;
if-eqz v1, :cond_7
.line 101
:cond_22
instance-of v1, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nONBField;
if-eqz v1, :cond_2a
instance-of v1, p1, Lorg/spongycastle/pqc/math/linearalgebra/GF2nONBField;
if-eqz v1, :cond_7
.line 106
:cond_2a
const/4 v0, 0x1
goto :goto_7
.end method
.method public final getDegree()I
.registers 2
.prologue
.line 55
iget v0, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->mDegree:I
return v0
.end method
.method public final getFieldPolynomial()Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;
.registers 3
.prologue
.line 65
iget-object v0, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->fieldPolynomial:Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;
if-nez v0, :cond_7
.line 67
invoke-virtual {p0}, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->computeFieldPolynomial()V
.line 69
:cond_7
new-instance v0, Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;
iget-object v1, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->fieldPolynomial:Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;
invoke-direct {v0, v1}, Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;-><init>(Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;)V
return-object v0
.end method
.method protected abstract getRandomRoot(Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;)Lorg/spongycastle/pqc/math/linearalgebra/GF2nElement;
.end method
.method public hashCode()I
.registers 3
.prologue
.line 114
iget v0, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->mDegree:I
iget-object v1, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->fieldPolynomial:Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;
invoke-virtual {v1}, Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;->hashCode()I
move-result v1
add-int/2addr v0, v1
return v0
.end method
.method protected final invertMatrix([Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;)[Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;
.registers 8
.prologue
const/4 v1, 0x0
.line 151
array-length v0, p1
new-array v3, v0, [Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;
.line 152
array-length v0, p1
new-array v4, v0, [Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;
move v0, v1
.line 156
:goto_8
iget v2, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->mDegree:I
if-ge v0, v2, :cond_32
.line 160
:try_start_c
new-instance v2, Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;
aget-object v5, p1, v0
invoke-direct {v2, v5}, Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;-><init>(Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;)V
aput-object v2, v3, v0
.line 161
new-instance v2, Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;
iget v5, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->mDegree:I
invoke-direct {v2, v5}, Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;-><init>(I)V
aput-object v2, v4, v0
.line 162
aget-object v2, v4, v0
iget v5, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->mDegree:I
add-int/lit8 v5, v5, -0x1
sub-int/2addr v5, v0
invoke-virtual {v2, v5}, Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;->setBit(I)V
:try_end_28
.catch Ljava/lang/RuntimeException; {:try_start_c .. :try_end_28} :catch_2b
.line 156
:goto_28
add-int/lit8 v0, v0, 0x1
goto :goto_8
.line 166
:catch_2b
move-exception v2
invoke-virtual {v2}, Ljava/lang/RuntimeException;->printStackTrace()V
goto :goto_28
.line 171
:cond_30
add-int/lit8 v1, v1, 0x1
:cond_32
iget v0, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->mDegree:I
add-int/lit8 v0, v0, -0x1
if-ge v1, v0, :cond_8f
move v0, v1
.line 175
:goto_39
iget v2, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->mDegree:I
if-ge v0, v2, :cond_4d
aget-object v2, v3, v0
iget v5, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->mDegree:I
add-int/lit8 v5, v5, -0x1
sub-int/2addr v5, v1
invoke-virtual {v2, v5}, Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;->testBit(I)Z
move-result v2
if-nez v2, :cond_4d
.line 177
add-int/lit8 v0, v0, 0x1
goto :goto_39
.line 179
:cond_4d
iget v2, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->mDegree:I
if-lt v0, v2, :cond_59
.line 181
new-instance v0, Ljava/lang/RuntimeException;
const-string v1, "GF2nField.invertMatrix: Matrix cannot be inverted!"
invoke-direct {v0, v1}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw v0
.line 184
:cond_59
if-eq v1, v0, :cond_6b
.line 186
aget-object v2, v3, v1
.line 187
aget-object v5, v3, v0
aput-object v5, v3, v1
.line 188
aput-object v2, v3, v0
.line 189
aget-object v2, v4, v1
.line 190
aget-object v5, v4, v0
aput-object v5, v4, v1
.line 191
aput-object v2, v4, v0
.line 193
:cond_6b
add-int/lit8 v0, v1, 0x1
:goto_6d
iget v2, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->mDegree:I
if-ge v0, v2, :cond_30
.line 196
aget-object v2, v3, v0
iget v5, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->mDegree:I
add-int/lit8 v5, v5, -0x1
sub-int/2addr v5, v1
invoke-virtual {v2, v5}, Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;->testBit(I)Z
move-result v2
if-eqz v2, :cond_8c
.line 198
aget-object v2, v3, v0
aget-object v5, v3, v1
invoke-virtual {v2, v5}, Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;->addToThis(Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;)V
.line 199
aget-object v2, v4, v0
aget-object v5, v4, v1
invoke-virtual {v2, v5}, Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;->addToThis(Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;)V
.line 193
:cond_8c
add-int/lit8 v0, v0, 0x1
goto :goto_6d
.line 204
:cond_8f
iget v0, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->mDegree:I
add-int/lit8 v0, v0, -0x1
move v1, v0
:goto_94
if-lez v1, :cond_bc
.line 206
add-int/lit8 v0, v1, -0x1
:goto_98
if-ltz v0, :cond_b8
.line 209
aget-object v2, v3, v0
iget v5, p0, Lorg/spongycastle/pqc/math/linearalgebra/GF2nField;->mDegree:I
add-int/lit8 v5, v5, -0x1
sub-int/2addr v5, v1
invoke-virtual {v2, v5}, Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;->testBit(I)Z
move-result v2
if-eqz v2, :cond_b5
.line 211
aget-object v2, v3, v0
aget-object v5, v3, v1
invoke-virtual {v2, v5}, Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;->addToThis(Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;)V
.line 212
aget-object v2, v4, v0
aget-object v5, v4, v1
invoke-virtual {v2, v5}, Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;->addToThis(Lorg/spongycastle/pqc/math/linearalgebra/GF2Polynomial;)V
.line 206
:cond_b5
add-int/lit8 v0, v0, -0x1
goto :goto_98
.line 204
:cond_b8
add-int/lit8 v0, v1, -0x1
move v1, v0
goto :goto_94
.line 216
:cond_bc
return-object v4
.end method