如何获取NTRU参数

时间:2015-04-04 11:06:53

标签: java encryption bouncycastle ntruencrypt

我使用了bouncycastle对NTRU的启示,这是我的代码:

NTRUEncryptionKeyGenerationParameters ntruEncryptionKeyGenerationParameters = NTRUEncryptionKeyGenerationParameters.EES1087EP2;
NTRUEncryptionKeyPairGenerator ntruEncryptionKeyPairGenerator = new NTRUEncryptionKeyPairGenerator();
ntruEncryptionKeyPairGenerator.init(ntruEncryptionKeyGenerationParameters);
AsymmetricCipherKeyPair asymmetricCipherKeyPair = ntruEncryptionKeyPairGenerator.generateKeyPair();
NTRUEncryptionPrivateKeyParameters ntruEncryptionPrivateKeyParameters = (NTRUEncryptionPrivateKeyParameters) asymmetricCipherKeyPair.getPrivate();

NTRUEncryptionPublicKeyParameters ntruEncryptionPublicKeyParameters = (NTRUEncryptionPublicKeyParameters) asymmetricCipherKeyPair.getPublic();
NTRUEngine ntruEngine = new NTRUEngine();
ntruEngine.init(true, ntruEncryptionPublicKeyParameters);

问题是我怎样才能得到f多项式和基数,因为我只发现了fp(f的倒数,他们没有倒数法)和Basis?我查了javadocs但没有结果。

1 个答案:

答案 0 :(得分:0)

您可以从课程NTRUEncryptionKeyPairGenerator

中找到它
public AsymmetricCipherKeyPair generateKeyPair()
{
    int N = params.N;
    int q = params.q;
    int df = params.df;
    int df1 = params.df1;
    int df2 = params.df2;
    int df3 = params.df3;
    int dg = params.dg;
    boolean fastFp = params.fastFp;
    boolean sparse = params.sparse;

    Polynomial t;
    IntegerPolynomial fq;
    IntegerPolynomial fp = null;

    // choose a random f that is invertible mod 3 and q
    while (true)
    {
        IntegerPolynomial f;

        // choose random t, calculate f and fp
        if (fastFp)
        {
            // if fastFp=true, f is always invertible mod 3
            t = params.polyType == NTRUParameters.TERNARY_POLYNOMIAL_TYPE_SIMPLE ? Util.generateRandomTernary(N, df, df, sparse, params.getRandom()) : ProductFormPolynomial.generateRandom(N, df1, df2, df3, df3, params.getRandom());
            f = t.toIntegerPolynomial();
            f.mult(3);
            f.coeffs[0] += 1;
        }
        else
        {
            t = params.polyType == NTRUParameters.TERNARY_POLYNOMIAL_TYPE_SIMPLE ? Util.generateRandomTernary(N, df, df - 1, sparse, params.getRandom()) : ProductFormPolynomial.generateRandom(N, df1, df2, df3, df3 - 1, params.getRandom());
            f = t.toIntegerPolynomial();
            fp = f.invertF3();
            if (fp == null)
            {
                continue;
            }
        }

        fq = f.invertFq(q);
        if (fq == null)
        {
            continue;
        }
        break;
    }

    // if fastFp=true, fp=1
    if (fastFp)
    {
        fp = new IntegerPolynomial(N);
        fp.coeffs[0] = 1;
    }

    // choose a random g that is invertible mod q
    DenseTernaryPolynomial g;
    while (true)
    {
        g = DenseTernaryPolynomial.generateRandom(N, dg, dg - 1, params.getRandom());
        if (g.invertFq(q) != null)
        {
            break;
        }
    }

    IntegerPolynomial h = g.mult(fq, q);
    h.mult3(q);
    h.ensurePositive(q);
    g.clear();
    fq.clear();

    NTRUEncryptionPrivateKeyParameters priv = new NTRUEncryptionPrivateKeyParameters(h, t, fp, params.getEncryptionParameters());
    NTRUEncryptionPublicKeyParameters pub = new NTRUEncryptionPublicKeyParameters(h, params.getEncryptionParameters());
    return new AsymmetricCipherKeyPair(pub, priv);
}

f是你追求的多项式。 你的基础是什么意思?

NTRU报告014中描述了逆方法: 几乎逆转和快速NTRU密钥创建

https://www.securityinnovation.com/uploads/Crypto/NTRUTech014.pdf

通过几个优化步骤完成

  1. 在Z / 2Z /(x ^ N-1)上找到f的倒数

  2. 将其提升至Z / 2 ^ rZ /(x ^ N-1)

  3. 重复直到2 ^ r = q