F2mSqrtOptimizer.smali
.class public Lorg/spongycastle/math/ec/tools/F2mSqrtOptimizer;
.super Ljava/lang/Object;
.source "F2mSqrtOptimizer.java"
# direct methods
.method public constructor <init>()V
.registers 1
.prologue
.line 16
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method private static enumToList(Ljava/util/Enumeration;)Ljava/util/ArrayList;
.registers 3
.prologue
.line 65
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
.line 66
:goto_5
invoke-interface {p0}, Ljava/util/Enumeration;->hasMoreElements()Z
move-result v1
if-eqz v1, :cond_13
.line 68
invoke-interface {p0}, Ljava/util/Enumeration;->nextElement()Ljava/lang/Object;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
goto :goto_5
.line 70
:cond_13
return-object v0
.end method
.method private static implPrintRootZ(Lorg/spongycastle/asn1/x9/X9ECParameters;)V
.registers 6
.prologue
.line 52
invoke-virtual {p0}, Lorg/spongycastle/asn1/x9/X9ECParameters;->getCurve()Lorg/spongycastle/math/ec/ECCurve;
move-result-object v0
const-wide/16 v2, 0x2
invoke-static {v2, v3}, Ljava/math/BigInteger;->valueOf(J)Ljava/math/BigInteger;
move-result-object v1
invoke-virtual {v0, v1}, Lorg/spongycastle/math/ec/ECCurve;->fromBigInteger(Ljava/math/BigInteger;)Lorg/spongycastle/math/ec/ECFieldElement;
move-result-object v0
.line 53
invoke-virtual {v0}, Lorg/spongycastle/math/ec/ECFieldElement;->sqrt()Lorg/spongycastle/math/ec/ECFieldElement;
move-result-object v1
.line 55
sget-object v2, Ljava/lang/System;->out:Ljava/io/PrintStream;
invoke-virtual {v1}, Lorg/spongycastle/math/ec/ECFieldElement;->toBigInteger()Ljava/math/BigInteger;
move-result-object v3
const/16 v4, 0x10
invoke-virtual {v3, v4}, Ljava/math/BigInteger;->toString(I)Ljava/lang/String;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/String;->toUpperCase()Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 57
invoke-virtual {v1}, Lorg/spongycastle/math/ec/ECFieldElement;->square()Lorg/spongycastle/math/ec/ECFieldElement;
move-result-object v1
invoke-virtual {v1, v0}, Ljava/lang/Object;->equals(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_37
.line 59
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "Optimized-sqrt sanity check failed"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.line 61
:cond_37
return-void
.end method
.method public static main([Ljava/lang/String;)V
.registers 6
.prologue
.line 20
new-instance v0, Ljava/util/TreeSet;
invoke-static {}, Lorg/spongycastle/asn1/x9/ECNamedCurveTable;->getNames()Ljava/util/Enumeration;
move-result-object v1
invoke-static {v1}, Lorg/spongycastle/math/ec/tools/F2mSqrtOptimizer;->enumToList(Ljava/util/Enumeration;)Ljava/util/ArrayList;
move-result-object v1
invoke-direct {v0, v1}, Ljava/util/TreeSet;-><init>(Ljava/util/Collection;)V
.line 21
invoke-static {}, Lorg/spongycastle/crypto/ec/CustomNamedCurves;->getNames()Ljava/util/Enumeration;
move-result-object v1
invoke-static {v1}, Lorg/spongycastle/math/ec/tools/F2mSqrtOptimizer;->enumToList(Ljava/util/Enumeration;)Ljava/util/ArrayList;
move-result-object v1
invoke-interface {v0, v1}, Ljava/util/SortedSet;->addAll(Ljava/util/Collection;)Z
.line 23
invoke-interface {v0}, Ljava/util/SortedSet;->iterator()Ljava/util/Iterator;
move-result-object v2
.line 24
:cond_1c
:goto_1c
invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_5a
.line 26
invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/String;
.line 27
invoke-static {v0}, Lorg/spongycastle/crypto/ec/CustomNamedCurves;->getByName(Ljava/lang/String;)Lorg/spongycastle/asn1/x9/X9ECParameters;
move-result-object v1
.line 28
if-nez v1, :cond_32
.line 30
invoke-static {v0}, Lorg/spongycastle/asn1/x9/ECNamedCurveTable;->getByName(Ljava/lang/String;)Lorg/spongycastle/asn1/x9/X9ECParameters;
move-result-object v1
.line 32
:cond_32
if-eqz v1, :cond_1c
invoke-virtual {v1}, Lorg/spongycastle/asn1/x9/X9ECParameters;->getCurve()Lorg/spongycastle/math/ec/ECCurve;
move-result-object v3
invoke-static {v3}, Lorg/spongycastle/math/ec/ECAlgorithms;->isF2mCurve(Lorg/spongycastle/math/ec/ECCurve;)Z
move-result v3
if-eqz v3, :cond_1c
.line 34
sget-object v3, Ljava/lang/System;->out:Ljava/io/PrintStream;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v4, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string v4, ":"
invoke-virtual {v0, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {v3, v0}, Ljava/io/PrintStream;->print(Ljava/lang/String;)V
.line 35
invoke-static {v1}, Lorg/spongycastle/math/ec/tools/F2mSqrtOptimizer;->implPrintRootZ(Lorg/spongycastle/asn1/x9/X9ECParameters;)V
goto :goto_1c
.line 38
:cond_5a
return-void
.end method
.method public static printRootZ(Lorg/spongycastle/asn1/x9/X9ECParameters;)V
.registers 3
.prologue
.line 42
invoke-virtual {p0}, Lorg/spongycastle/asn1/x9/X9ECParameters;->getCurve()Lorg/spongycastle/math/ec/ECCurve;
move-result-object v0
invoke-static {v0}, Lorg/spongycastle/math/ec/ECAlgorithms;->isF2mCurve(Lorg/spongycastle/math/ec/ECCurve;)Z
move-result v0
if-nez v0, :cond_12
.line 44
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "Sqrt optimization only defined over characteristic-2 fields"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 47
:cond_12
invoke-static {p0}, Lorg/spongycastle/math/ec/tools/F2mSqrtOptimizer;->implPrintRootZ(Lorg/spongycastle/asn1/x9/X9ECParameters;)V
.line 48
return-void
.end method