Polynomial code

From Wikipedia, the free encyclopedia

In coding theory, a polynomial code is a type of linear code whose set of valid code words consists of those polynomials (usually of some fixed length) that are divisible by a given fixed polynomial (of shorter length, called the generator polynomial).

Contents

[edit] Definition

Fix a finite field GF(q), whose elements we call symbols. For the purposes of constructing polynomial codes, we identify a string of n symbols a_{n-1}\ldots a_0 with the polynomial

a_{n-1}x^{n-1} + \cdots + a_1x + a_0.\,

Fix integers m \leq n and let g(x) be some fixed polynomial of degree m, called the generator polynomial. The polynomial code generated by g(x) is the code whose code words are precisely the polynomials of degree less than n that are divisible (without remainder) by g(x).

[edit] Example

Consider the polynomial code over GF(2) = {0,1} with n = 5, m = 2, and generator polynomial g(x) = x2 + x + 1. This code consists of the following code words:

0,\quad x^2+x+1,\quad x^3+x^2+x,\quad x^3+1,
x^4+x^3+x^2,\quad x^4+x^3+x+1,\quad x^4+x,\quad x^4+x^2+1.

Equivalently, expressed as strings of binary digits, the codewords are:

00000,\quad 00111,\quad 01110,\quad 01001,
11100,\quad 11011,\quad 10010,\quad 10101.

Note that this, as every polynomial code, is indeed a linear code, i.e., linear combinations of code words are again code words.

[edit] Encoding

In a polynomial code over GF(q) with code length n and generator polynomial g(x) of degree m, there will be exactly qnm code words. Indeed, by definition, p(x) is a code word if and only if it is of the form p(x) = g(x)\cdot q(x), where q(x) (the quotient) is of degree less than nm. Since there are qnm such quotients available, there is the same number of possible code words. Plain (unencoded) data words should therefore be of length nm

Some authors, such as (Lidl & Pilz, 1999), use the mapping q(x) \mapsto g(x)\cdot q(x) as the assignment from data words to code words. However, this has the disadvantage that the data word does not appear as part of the code word.

Instead, the following method is often used: given a data word d(x) of length nm, first multiply d(x) by xm, which has the effect of shifting d(x) by m places to the left. In general, xmd(x) will not be divisible by g(x), i.e., it will not be a valid code word. However, there is a unique code word that can be obtained by adjusting the rightmost m symbols of xmd(x). To calculate it, compute the remainder of dividing xmd(x) by g(x):

x^md(x) = g(x)\cdot q(x) + r(x),\,

where r(x) is of degree less than m. The code word corresponding to the data word d(x) is then defined to be

p(x) := x^md(x) - r(x),\,

Note the following properties:

  1. p(x) = g(x)\cdot q(x), which is divisible by g(x). In particular, p(x) is a valid code word.
  2. Since r(x) is of degree less than m, the leftmost nm symbols of p(x) agree with the corresponding symbols of xmd(x). In other words, the first nm symbols of the code word are the same as the original data word. The remaining m symbols are sometimes called the checksum digits.

[edit] Example

For the above code with n = 5, m = 2, and generator polynomial g(x) = x2 + x + 1, we obtain the following assignment from data words to codewords:

  • 000 \mapsto 00000
  • 001 \mapsto 00111
  • 010 \mapsto 01001
  • 011 \mapsto 01110
  • 100 \mapsto 10010
  • 101 \mapsto 10101
  • 110 \mapsto 11011
  • 111 \mapsto 11100

[edit] Decoding

Assuming that the code word is free of errors, it can be decoded simply by stripping away the m checksum digits.

If there are errors, then error correction should be performed before decoding.

[edit] Properties of polynomial codes

As for all digital codes, the error detection and correction abilities of polynomial codes are determined by the minimum Hamming distance of the code. Since polynomial codes are linear codes, the minimum Hamming distance is equal to the minimum weight of any non-zero codeword.

More specific properties of a polynomial code often depend on particular algebraic properties of its generator polynomial. Here are some examples of such properties:

  • A polynomial code is cyclic if and only if the general polynomial divides xn − 1.
  • If the generator polynomial is primitive, then the resulting code has Hamming distance at least 3, provided that n\leq 2^m-1.
  • In BCH codes, the generator polynomial is chosen to have specific roots in an extension field, in a way that achieves high Hamming distance.

The algebraic nature of polynomial codes, with cleverly chosen generator polynomials, can also often be exploited to find efficient error correction algorithms. This is the case for BCH codes.

[edit] Specific families of polynomial codes

  • BCH codes are a family of polynomial codes with high Hamming distance and efficient algebraic error correction algorithms.

[edit] References

  • W.J. Gilbert and W.K. Nicholson: Modern Algebra with Applications, 2nd edition, Wiley, 2004.
  • R. Lidl and G. Pilz. Applied Abstract Algebra, 2nd edition. Wiley, 1999.