Trace Zero Cryptography

From HandWiki
Revision as of 12:42, 8 February 2021 by imported>Jslovo (over-write)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)

In 1998 Gerhard Frey firstly proposed using trace zero varieties for cryptographic purpose. These varieties are subgroups of the divisor class group on a low genus hyperelliptic curve defined over a finite field. These groups can be used to establish asymmetric cryptography using the discrete logarithm problem as cryptographic primitive.

Trace zero varieties feature a better scalar multiplication performance than elliptic curves. This allows a fast arithmetic in this groups, which can speed up the calculations with a factor 3 compared with elliptic curves and hence speed up the cryptosystem.

Another advantage is that for a groups of cryptographically relevant size, the order of the group can simply be calculated using the characteristic polynomial of the Frobenius endomorphism. This is not the case, for example, in elliptic curve cryptography when the group of points of an elliptic curve over a prime field is used for cryptographic purpose.

However to represent an element of the trace zero variety more bits are needed compared with elements of elliptic or hyperelliptic curves. Another disadvantage, is the fact, that it is possible to reduce the security of the TZV of 1/6th of the bit length using cover attack.

Mathematical background

A hyperelliptic curve C of genus g over a prime field [math]\displaystyle{ \mathbb{F}_q }[/math] where q = pn (p prime) of odd characteristic is defined as

[math]\displaystyle{ C:~y^2 + h(x)y = f(x), }[/math]

where f monic, deg(f) = 2g + 1 and deg(h) ≤ g. The curve has at least one [math]\displaystyle{ \mathbb{F}_q }[/math]-rational Weierstraßpoint.

The Jacobian variety [math]\displaystyle{ J_C(\mathbb{F}_{q^n}) }[/math] of C is for all finite extension [math]\displaystyle{ \mathbb{F}_{q^n} }[/math] isomorphic to the ideal class group [math]\displaystyle{ \operatorname{Cl}(C/\mathbb{F}_{q^n}) }[/math]. With the Mumford's representation it is possible to represent the elements of [math]\displaystyle{ J_C(\mathbb{F}_{q^n}) }[/math] with a pair of polynomials [u, v], where u, v[math]\displaystyle{ \mathbb{F}_{q^n}[x] }[/math].

The Frobenius endomorphism σ is used on an element [u, v] of [math]\displaystyle{ J_C(\mathbb{F}_{q^n}) }[/math] to raise the power of each coefficient of that element to q: σ([u, v]) = [uq(x), vq(x)]. The characteristic polynomial of this endomorphism has the following form:

[math]\displaystyle{ \chi(T) = T^{2g} + a_1T^{2g-1} + \cdots + a_gT^g + \cdots + a_1q^{g-1}T + q^g, }[/math]

where ai in ℤ

With the Hasse–Weil theorem it is possible to receive the group order of any extension field [math]\displaystyle{ \mathbb{F}_{q^n} }[/math] by using the complex roots τi of χ(T):

[math]\displaystyle{ |J_C(\mathbb{F}_{q^n})| = \prod_{i=1}^{2g} (1 - \tau_i^n) }[/math]

Let D be an element of the [math]\displaystyle{ J_C(\mathbb{F}_{q^n}) }[/math] of C, then it is possible to define an endomorphism of [math]\displaystyle{ J_C(\mathbb{F}_{q^n}) }[/math], the so-called trace of D:

[math]\displaystyle{ \operatorname{Tr}(D) = \sum_{i=0}^{n-1} \sigma^i(D) = D + \sigma(D) + \cdots + \sigma^{n-1}(D) }[/math]

Based on this endomorphism one can reduce the Jacobian variety to a subgroup G with the property, that every element is of trace zero:

[math]\displaystyle{ G = \{ D \in J_C(\mathbb{F}_{q^n})~|~\text{Tr}(D) = \textbf{0} \}, ~~~(\textbf{0} \text{ neutral element in } J_C(\mathbb{F}_{q^n}) }[/math]

G is the kernel of the trace endomorphism and thus G is a group, the so-called trace zero (sub)variety (TZV) of [math]\displaystyle{ J_C(\mathbb{F}_{q^n}) }[/math].

The intersection of G and [math]\displaystyle{ J_C(\mathbb{F}_{q}) }[/math] is produced by the n-torsion elements of [math]\displaystyle{ J_C(\mathbb{F}_{q}) }[/math]. If the greatest common divisor [math]\displaystyle{ \gcd(n, |J_C(\mathbb{F}_q)|) = 1 }[/math] the intersection is empty and one can compute the group order of G:

[math]\displaystyle{ |G| = \dfrac{|J_C(\mathbb{F}_{q^n})|}{|J_C(\mathbb{F}_q)|} = \dfrac{\prod_{i=1}^{2g} (1 - \tau_i^n)}{ \prod_{i=1}^{2g} (1 - \tau_i)} }[/math]

The actual group used in cryptographic applications is a subgroup G0 of G of a large prime order l. This group may be G itself.[1][2]

There exist three different cases of cryptograpghical relevance for TZV:[3]

  • g = 1, n = 3
  • g = 1, n = 5
  • g = 2, n = 3

Arithmetic

The arithmetic used in the TZV group G0 based on the arithmetic for the whole group [math]\displaystyle{ J_C(\mathbb{F}_{q^n}) }[/math], But it is possible to use the Frobenius endomorphism σ to speed up the scalar multiplication. This can be archived if G0 is generated by D of order l then σ(D) = sD, for some integers s. For the given cases of TZV s can be computed as follows, where ai come from the characteristic polynomial of the Frobenius endomorphism :

  • For g = 1, n = 3: [math]\displaystyle{ s = \dfrac {q-1} {1 - a_1} \bmod{\ell} }[/math]
  • For g = 1, n = 5: [math]\displaystyle{ s = \dfrac {q^2-q-a_1^2q+a_1q+1} {q-2a_1q+a_1^3-a_1^2+a_1-1} \bmod{\ell} }[/math]
  • For g = 2, n = 3: [math]\displaystyle{ s = - \dfrac {q^2-a_2+a_1} {a_1q-a_2+1} \bmod{\ell} }[/math]

Knowing this, it is possible to replace any scalar multiplication mD (|m| ≤ l/2) with:

[math]\displaystyle{ m_0D + m_1\sigma(D) + \cdots + m_{n-1}\sigma^{n-1}(D), ~~~~\text{where }m_i = O(\ell^{1/(n-1)}) = O(q^g) }[/math]

With this trick the multiple scalar product can be reduced to about 1/(n − 1)th of doublings necessary for calculating mD, if the implied constants are small enough.[4][5]

Security

The security of cryptographic systems based on trace zero subvarieties according to the results of the papers[6][7] comparable to the security of hyper-elliptic curves of low genus g' over [math]\displaystyle{ \mathbb{F}_{p'} }[/math], where p' ~ (n − 1)(g/g' ) for |G| ~128 bits.

For the cases where n = 3, g = 2 and n = 5, g = 1 it is possible to reduce the security for at most 6 bits, where |G| ~ 2256, because one can not be sure that G is contained in a Jacobian of a curve of genus 6. The security of curves of genus 4 for similar fields are far less secure.

Cover attack on a trace zero crypto-system

The attack published in[8] shows, that the DLP in trace zero groups of genus 2 over finite fields of characteristic diverse than 2 or 3 and a field extension of degree 3 can be transformed into a DLP in a class group of degree 0 with genus of at most 6 over the base field. In this new class group the DLP can be attacked with the index calculus methods. This leads to a reduction of the bit length 1/6th.

Notes

  1. G. Frey and T. Lange: "Mathematical background of public key cryptography"
  2. T. Lange: "Trace zero subvariety for cryptosystems"
  3. R. M. Avanzi and E. Cesena: "Trace zero varieties over fields of characteristic 2 for cryptographic applications"
  4. R. M. Avanzi and E. Cesena: "Trace zero varieties over fields of characteristic 2 for cryptographic applications"
  5. T. Lange: "Trace zero subvariety for cryptosystems"
  6. T. Lange: "Trace zero subvariety for cryptosystems"
  7. R. M. Avanzi and E. Cesena: "Trace zero varieties over fields of characteristic 2 for cryptographic applications"
  8. C. Diem and J. Scholten: "An attack on a trace-zero cryptosystem"

References