當前位置: 首頁>>代碼示例>>Java>>正文


Java Nat224.create方法代碼示例

本文整理匯總了Java中org.bouncycastle.math.raw.Nat224.create方法的典型用法代碼示例。如果您正苦於以下問題:Java Nat224.create方法的具體用法?Java Nat224.create怎麽用?Java Nat224.create使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.bouncycastle.math.raw.Nat224的用法示例。


在下文中一共展示了Nat224.create方法的14個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: sqrt

import org.bouncycastle.math.raw.Nat224; //導入方法依賴的package包/類
/**
 * return a sqrt root - the routine verifies that the calculation returns the right value - if
 * none exists it returns null.
 */
public ECFieldElement sqrt()
{
    int[] c = this.x;
    if (Nat224.isZero(c) || Nat224.isOne(c))
    {
        return this;
    }

    int[] nc = Nat224.create();
    SecP224R1Field.negate(c, nc);

    int[] r = Mod.random(SecP224R1Field.P);
    int[] t = Nat224.create();

    if (!isSquare(c))
    {
        return null;
    }

    while (!trySqrt(nc, r, t))
    {
        SecP224R1Field.addOne(r, r);
    }

    SecP224R1Field.square(t, r);

    return Nat224.eq(c, r) ? new SecP224R1FieldElement(t) : null;
}
 
開發者ID:thedrummeraki,項目名稱:Aki-SSL,代碼行數:33,代碼來源:SecP224R1FieldElement.java

示例2: trySqrt

import org.bouncycastle.math.raw.Nat224; //導入方法依賴的package包/類
private static boolean trySqrt(int[] nc, int[] r, int[] t)
{
    int[] d1 = Nat224.create();
    Nat224.copy(r, d1);
    int[] e1 = Nat224.create();
    e1[0] = 1;
    int[] f1 = Nat224.create();
    RP(nc, d1, e1, f1, t);

    int[] d0 = Nat224.create();
    int[] e0 = Nat224.create();

    for (int k = 1; k < 96; ++k)
    {
        Nat224.copy(d1, d0);
        Nat224.copy(e1, e0);

        RS(d1, e1, f1, t);

        if (Nat224.isZero(d1))
        {
            Mod.invert(SecP224R1Field.P, e0, t);
            SecP224R1Field.multiply(t, d0, t);
            return true;
        }
    }

    return false;
}
 
開發者ID:thedrummeraki,項目名稱:Aki-SSL,代碼行數:30,代碼來源:SecP224R1FieldElement.java

示例3: divide

import org.bouncycastle.math.raw.Nat224; //導入方法依賴的package包/類
public ECFieldElement divide(ECFieldElement b)
    {
//        return multiply(b.invert());
        int[] z = Nat224.create();
        Mod.invert(SecP224K1Field.P, ((SecP224K1FieldElement)b).x, z);
        SecP224K1Field.multiply(z, x, z);
        return new SecP224K1FieldElement(z);
    }
 
開發者ID:ttt43ttt,項目名稱:gwt-crypto,代碼行數:9,代碼來源:SecP224K1FieldElement.java

示例4: add

import org.bouncycastle.math.raw.Nat224; //導入方法依賴的package包/類
public ECFieldElement add(ECFieldElement b)
{
    int[] z = Nat224.create();
    SecP224K1Field.add(x, ((SecP224K1FieldElement)b).x, z);
    return new SecP224K1FieldElement(z);
}
 
開發者ID:thedrummeraki,項目名稱:Aki-SSL,代碼行數:7,代碼來源:SecP224K1FieldElement.java

示例5: negate

import org.bouncycastle.math.raw.Nat224; //導入方法依賴的package包/類
public ECFieldElement negate()
{
    int[] z = Nat224.create();
    SecP224K1Field.negate(x, z);
    return new SecP224K1FieldElement(z);
}
 
開發者ID:thedrummeraki,項目名稱:Aki-SSL,代碼行數:7,代碼來源:SecP224K1FieldElement.java

示例6: multiply

import org.bouncycastle.math.raw.Nat224; //導入方法依賴的package包/類
public ECFieldElement multiply(ECFieldElement b)
{
    int[] z = Nat224.create();
    SecP224K1Field.multiply(x, ((SecP224K1FieldElement)b).x, z);
    return new SecP224K1FieldElement(z);
}
 
開發者ID:ttt43ttt,項目名稱:gwt-crypto,代碼行數:7,代碼來源:SecP224K1FieldElement.java

示例7: multiply

import org.bouncycastle.math.raw.Nat224; //導入方法依賴的package包/類
public ECFieldElement multiply(ECFieldElement b)
{
    int[] z = Nat224.create();
    SecP224R1Field.multiply(x, ((SecP224R1FieldElement)b).x, z);
    return new SecP224R1FieldElement(z);
}
 
開發者ID:thedrummeraki,項目名稱:Aki-SSL,代碼行數:7,代碼來源:SecP224R1FieldElement.java

示例8: square

import org.bouncycastle.math.raw.Nat224; //導入方法依賴的package包/類
public ECFieldElement square()
{
    int[] z = Nat224.create();
    SecP224K1Field.square(x, z);
    return new SecP224K1FieldElement(z);
}
 
開發者ID:ttt43ttt,項目名稱:gwt-crypto,代碼行數:7,代碼來源:SecP224K1FieldElement.java

示例9: negate

import org.bouncycastle.math.raw.Nat224; //導入方法依賴的package包/類
public ECFieldElement negate()
{
    int[] z = Nat224.create();
    SecP224R1Field.negate(x, z);
    return new SecP224R1FieldElement(z);
}
 
開發者ID:thedrummeraki,項目名稱:Aki-SSL,代碼行數:7,代碼來源:SecP224R1FieldElement.java

示例10: twice

import org.bouncycastle.math.raw.Nat224; //導入方法依賴的package包/類
public ECPoint twice()
{
    if (this.isInfinity())
    {
        return this;
    }

    ECCurve curve = this.getCurve();

    SecP224K1FieldElement Y1 = (SecP224K1FieldElement)this.y;
    if (Y1.isZero())
    {
        return curve.getInfinity();
    }

    SecP224K1FieldElement X1 = (SecP224K1FieldElement)this.x, Z1 = (SecP224K1FieldElement)this.zs[0];

    int c;

    int[] Y1Squared = Nat224.create();
    SecP224K1Field.square(Y1.x, Y1Squared);

    int[] T = Nat224.create();
    SecP224K1Field.square(Y1Squared, T);

    int[] M = Nat224.create();
    SecP224K1Field.square(X1.x, M);
    c = Nat224.addBothTo(M, M, M);
    SecP224K1Field.reduce32(c, M);

    int[] S = Y1Squared;
    SecP224K1Field.multiply(Y1Squared, X1.x, S);
    c = Nat.shiftUpBits(7, S, 2, 0);
    SecP224K1Field.reduce32(c, S);

    int[] t1 = Nat224.create();
    c = Nat.shiftUpBits(7, T, 3, 0, t1);
    SecP224K1Field.reduce32(c, t1);

    SecP224K1FieldElement X3 = new SecP224K1FieldElement(T);
    SecP224K1Field.square(M, X3.x);
    SecP224K1Field.subtract(X3.x, S, X3.x);
    SecP224K1Field.subtract(X3.x, S, X3.x);

    SecP224K1FieldElement Y3 = new SecP224K1FieldElement(S);
    SecP224K1Field.subtract(S, X3.x, Y3.x);
    SecP224K1Field.multiply(Y3.x, M, Y3.x);
    SecP224K1Field.subtract(Y3.x, t1, Y3.x);

    SecP224K1FieldElement Z3 = new SecP224K1FieldElement(M);
    SecP224K1Field.twice(Y1.x, Z3.x);
    if (!Z1.isOne())
    {
        SecP224K1Field.multiply(Z3.x, Z1.x, Z3.x);
    }

    return new SecP224K1Point(curve, X3, Y3, new ECFieldElement[] { Z3 }, this.withCompression);
}
 
開發者ID:ttt43ttt,項目名稱:gwt-crypto,代碼行數:59,代碼來源:SecP224K1Point.java

示例11: addOne

import org.bouncycastle.math.raw.Nat224; //導入方法依賴的package包/類
public ECFieldElement addOne()
{
    int[] z = Nat224.create();
    SecP224R1Field.addOne(x, z);
    return new SecP224R1FieldElement(z);
}
 
開發者ID:thedrummeraki,項目名稱:Aki-SSL,代碼行數:7,代碼來源:SecP224R1FieldElement.java

示例12: twice

import org.bouncycastle.math.raw.Nat224; //導入方法依賴的package包/類
public ECPoint twice()
{
    if (this.isInfinity())
    {
        return this;
    }

    ECCurve curve = this.getCurve();

    SecP224R1FieldElement Y1 = (SecP224R1FieldElement)this.y;
    if (Y1.isZero())
    {
        return curve.getInfinity();
    }

    SecP224R1FieldElement X1 = (SecP224R1FieldElement)this.x, Z1 = (SecP224R1FieldElement)this.zs[0];

    int c;
    int[] t1 = Nat224.create();
    int[] t2 = Nat224.create();

    int[] Y1Squared = Nat224.create();
    SecP224R1Field.square(Y1.x, Y1Squared);

    int[] T = Nat224.create();
    SecP224R1Field.square(Y1Squared, T);

    boolean Z1IsOne = Z1.isOne();

    int[] Z1Squared = Z1.x;
    if (!Z1IsOne)
    {
        Z1Squared = t2;
        SecP224R1Field.square(Z1.x, Z1Squared);
    }

    SecP224R1Field.subtract(X1.x, Z1Squared, t1);

    int[] M = t2;
    SecP224R1Field.add(X1.x, Z1Squared, M);
    SecP224R1Field.multiply(M, t1, M);
    c = Nat224.addBothTo(M, M, M);
    SecP224R1Field.reduce32(c, M);

    int[] S = Y1Squared;
    SecP224R1Field.multiply(Y1Squared, X1.x, S);
    c = Nat.shiftUpBits(7, S, 2, 0);
    SecP224R1Field.reduce32(c, S);

    c = Nat.shiftUpBits(7, T, 3, 0, t1);
    SecP224R1Field.reduce32(c, t1);

    SecP224R1FieldElement X3 = new SecP224R1FieldElement(T);
    SecP224R1Field.square(M, X3.x);
    SecP224R1Field.subtract(X3.x, S, X3.x);
    SecP224R1Field.subtract(X3.x, S, X3.x);

    SecP224R1FieldElement Y3 = new SecP224R1FieldElement(S);
    SecP224R1Field.subtract(S, X3.x, Y3.x);
    SecP224R1Field.multiply(Y3.x, M, Y3.x);
    SecP224R1Field.subtract(Y3.x, t1, Y3.x);

    SecP224R1FieldElement Z3 = new SecP224R1FieldElement(M);
    SecP224R1Field.twice(Y1.x, Z3.x);
    if (!Z1IsOne)
    {
        SecP224R1Field.multiply(Z3.x, Z1.x, Z3.x);
    }

    return new SecP224R1Point(curve, X3, Y3, new ECFieldElement[]{ Z3 }, this.withCompression);
}
 
開發者ID:ttt43ttt,項目名稱:gwt-crypto,代碼行數:72,代碼來源:SecP224R1Point.java

示例13: subtract

import org.bouncycastle.math.raw.Nat224; //導入方法依賴的package包/類
public ECFieldElement subtract(ECFieldElement b)
{
    int[] z = Nat224.create();
    SecP224K1Field.subtract(x, ((SecP224K1FieldElement)b).x, z);
    return new SecP224K1FieldElement(z);
}
 
開發者ID:thedrummeraki,項目名稱:Aki-SSL,代碼行數:7,代碼來源:SecP224K1FieldElement.java

示例14: subtract

import org.bouncycastle.math.raw.Nat224; //導入方法依賴的package包/類
public ECFieldElement subtract(ECFieldElement b)
{
    int[] z = Nat224.create();
    SecP224R1Field.subtract(x, ((SecP224R1FieldElement)b).x, z);
    return new SecP224R1FieldElement(z);
}
 
開發者ID:thedrummeraki,項目名稱:Aki-SSL,代碼行數:7,代碼來源:SecP224R1FieldElement.java


注:本文中的org.bouncycastle.math.raw.Nat224.create方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。