12NAMESPACE_BEGIN(CryptoPP)
16#if defined(CRYPTOPP_CXX11_STATIC_INIT)
26 CRYPTOPP_ASSERT(qbits > 9);
27 CRYPTOPP_ASSERT(pbits > qbits);
41 (void)SolveModularQuadraticEquation(r1, r2, 1, -1, 1, q);
47 }
while (((p % 3U) != 2) || (((p.
Squared() - p + 1) % q).NotZero()));
59 t = XTR_Exponentiate(g, p+1, p);
62 g = XTR_Exponentiate(g, (p.
Squared()-p+1)/q, p);
67 if (XTR_Exponentiate(g, q, p) != three)
75 unsigned int bitCount = e.BitCount();
80 unsigned int lowest1bit;
81 for (lowest1bit=0; e.GetBit(lowest1bit) == 0; lowest1bit++) {}
86 GFP2Element S[5] = {gfp2.ConvertIn(3), c, gfp2.SpecialOperation1(c)};
90 for (i = e.BitCount() - 1; i>lowest1bit; i--)
94 gfp2.RaiseToPthPower(S[0]);
95 gfp2.Accumulate(S[0], gfp2.SpecialOperation2(S[2], c, S[1]));
96 S[1] = gfp2.SpecialOperation1(S[1]);
97 S[2] = gfp2.SpecialOperation1(S[2]);
102 gfp2.RaiseToPthPower(S[2]);
103 gfp2.Accumulate(S[2], gfp2.SpecialOperation2(S[0], cp, S[1]));
104 S[1] = gfp2.SpecialOperation1(S[1]);
105 S[0] = gfp2.SpecialOperation1(S[0]);
112 S[1] = gfp2.SpecialOperation1(S[1]);
114 return gfp2.ConvertOut(S[1]);
Classes for performing mathematics over different fields.
GF(p^2), optimal normal basis.
Multiple precision integer with arithmetic operations.
static const Integer &CRYPTOPP_API Zero()
Integer representing 0.
void Randomize(RandomNumberGenerator &rng, size_t bitCount)
Set this Integer to random integer.
Integer Squared() const
Multiply this integer by itself.
@ PRIME
a number which is probabilistically prime
static Integer CRYPTOPP_API Power2(size_t e)
Exponentiates to a power of 2.
Interface for random number generators.
virtual unsigned int GenerateBit()
Generate new random bit and return it.
Restricts the instantiation of a class to one static object without locks.
CRYPTOPP_NOINLINE const T & Ref(CRYPTOPP_NOINLINE_DOTDOTDOT) const
Return a reference to the inner Singleton object.
Multiple precision integer with arithmetic operations.
Class file for performing modular arithmetic.
Classes and functions for number theoretic operations.
Integer EuclideanMultiplicativeInverse(const Integer &a, const Integer &b)
Calculate multiplicative inverse.
The XTR public key system.