Cantor–Zassenhaus algorithm explained

In computational algebra, the Cantor–Zassenhaus algorithm is a method for factoring polynomials over finite fields (also called Galois fields).

The algorithm consists mainly of exponentiation and polynomial GCD computations. It was invented by David G. Cantor and Hans Zassenhaus in 1981.

It is arguably the dominant algorithm for solving the problem, having replaced the earlier Berlekamp's algorithm of 1967. It is currently implemented in many computer algebra systems.

Overview

Background

f(x)

(i.e. one with no repeated factors) of degree n with coefficients in a finite field

Fq

whose irreducible polynomial factors are all of equal degree (algorithms exist for efficiently factoring arbitrary polynomials into a product of polynomials satisfying these conditions, for instance,

f(x)/\gcd(f(x),f'(x))

is a squarefree polynomial with the same factors as

f(x)

, so that the Cantor–Zassenhaus algorithm can be used to factor arbitrary polynomials). It gives as output a polynomial

g(x)

with coefficients in the same field such that

g(x)

divides

f(x)

. The algorithm may then be applied recursively to these and subsequent divisors, until we find the decomposition of

f(x)

into powers of irreducible polynomials (recalling that the ring of polynomials over any field is a unique factorisation domain).

All possible factors of

f(x)

are contained within the factor ring

R=

Fq[x]
\langlef(x)\rangle
. If we suppose that

f(x)

has irreducible factors

p1(x),p2(x),\ldots,ps(x)

, all of degree d, then this factor ring is isomorphic to the direct product of factor rings

S=

s
\prod
i=1
Fq[x]
\langlepi(x)\rangle
. The isomorphism from R to S, say

\phi

, maps a polynomial

g(x)\inR

to the s-tuple of its reductions modulo each of the

pi(x)

, i.e. if:

\begin{align} g(x)&{}\equivg1(x)\pmod{p1(x)},\\ g(x)&{}\equivg2(x)\pmod{p2(x)},\\ &{}\vdots\\ g(x)&{}\equivgs(x)\pmod{ps(x)}, \end{align}

then

\phi(g(x)+\langlef(x)\rangle)=(g1(x)+\langlep1(x)\rangle,\ldots,gs(x)+\langleps(x)\rangle)

. It is important to note the following at this point, as it shall be of critical importance later in the algorithm: Since the

pi(x)

are each irreducible, each of the factor rings in this direct sum is in fact a field. These fields each have degree

qd

.

Core result

The core result underlying the Cantor–Zassenhaus algorithm is the following: If

a(x)\inR

is a polynomial satisfying:

a(x)0,\pm1

ai(x)\in\{0,-1,1\}fori=1,2,\ldots,s,

where

ai(x)

is the reduction of

a(x)

modulo

pi(x)

as before, and if any two of the following three sets is non-empty:

A=\{i\midai(x)=0\},

B=\{i\midai(x)=-1\},

C=\{i\midai(x)=1\},

then there exist the following non-trivial factors of

f(x)

:

\gcd(f(x),a(x))=\prodipi(x),

\gcd(f(x),a(x)+1)=\prodipi(x),

\gcd(f(x),a(x)-1)=\prodipi(x).

Algorithm

The Cantor–Zassenhaus algorithm computes polynomials of the same type as

a(x)

above using the isomorphism discussed in the Background section. It proceeds as follows, in the case where the field

Fq

is of odd-characteristic (the process can be generalised to characteristic 2 fields in a fairly straightforward way. Select a random polynomial

b(x)\inR

such that

b(x)0,\pm1

. Set

m=(qd-1)/2

and compute

b(x)m

. Since

\phi

is an isomorphism, we have (using our now-established notation):

\phi(b(x)m)=

m(x)
(b
1

+\langlep1(x)\rangle,\ldots,

m
b
s(x)

+\langleps(x)\rangle).

Now, each

bi(x)+\langlepi(x)\rangle

is an element of a field of order

qd

, as noted earlier. The multiplicative subgroup of this field has order

qd-1

and so, unless

bi(x)=0

, we have
qd-1
b
i(x)

=1

for each i and hence
m
b
i(x)

=\pm1

for each i. If

bi(x)=0

, then of course
m=0
b
i(x)
. Hence

b(x)m

is a polynomial of the same type as

a(x)

above. Further, since

b(x)0,\pm1

, at least two of the sets

A,B

and C are non-empty and by computing the above GCDs we may obtain non-trivial factors. Since the ring of polynomials over a field is a Euclidean domain, we may compute these GCDs using the Euclidean algorithm.

Applications

One important application of the Cantor–Zassenhaus algorithm is in computing discrete logarithms over finite fields of prime-power order. Computing discrete logarithms is an important problem in public key cryptography. For a field of prime-power order, the fastest known method is the index calculus method, which involves the factorisation of field elements. If we represent the prime-power order field in the usual way – that is, as polynomials over the prime order base field, reduced modulo an irreducible polynomial of appropriate degree – then this is simply polynomial factorisation, as provided by the Cantor–Zassenhaus algorithm.

Implementation in computer algebra systems

The Cantor–Zassenhaus algorithm is implemented in the PARI/GP computer algebra system as the factorcantor function.

See also

External links