Binary Golay code

From Wikipedia, the free encyclopedia
Jump to: navigation, search
Extended binary Golay code
BinaryGolayCode.svg
Its generator matrix
Named after Marcel J. E. Golay
Classification
Type Linear block code
Parameters
Block length 24
Message length 12
Rate 12/24 = 0.5
Distance 8
Alphabet size 2
Notation [24,12,8]2-code
Perfect binary Golay code
Named after Marcel J. E. Golay
Classification
Type Linear block code
Parameters
Block length 23
Message length 12
Rate 12/23 ~ 0.522
Distance 7
Alphabet size 2
Notation [23,12,7]2-code

In mathematics and electronics engineering, a binary Golay code is a type of error-correcting code used in digital communications. The binary Golay code, along with the ternary Golay code, has a particularly deep and interesting connection to the theory of finite sporadic groups in mathematics. These codes are named in honor of Marcel J. E. Golay.

There are two closely related binary Golay codes. The extended binary Golay code encodes 12 bits of data in a 24-bit word in such a way that any 3-bit errors can be corrected and any 7-bit errors can be detected. The other, the perfect binary Golay code, has codewords of length 23 and is obtained from the extended binary Golay code by deleting one coordinate position (conversely, the extended binary Golay code is obtained from the perfect binary Golay code by adding a parity bit). In standard code notation the codes have parameters [24, 12, 8] and [23, 12, 7].

Contents

[edit] Mathematical definition

In mathematical terms, the extended binary Golay code consists of a 12-dimensional subspace W of the space V=F224 of 24-bit words such that any two distinct elements of W differ in at least eight coordinates. Equivalently, any non-zero element of W has at least eight non-zero coordinates.

  • The possible sets of non-zero coordinates as w ranges over W are called code words. In the extended binary Golay code, all code words have the Hamming weights of 0, 8, 12, 16, or 24.
  • Up to relabeling coordinates, W is unique.

The perfect binary Golay code is a perfect code. That is, the spheres of radius three around code words form a partition of the vector space.

The automorphism group of the binary Golay code is the Mathieu group M23. The automorphism group of the extended binary Golay code is the Mathieu group M24. The other Mathieu groups occur as stabilizers of one or several elements of W.

The Golay code words of weight eight are elements of the S(5,8,24) Steiner system.

[edit] Constructions

  1. Lexicographic code: Order the vectors in V lexicographically (i.e., interpret them as unsigned 24-bit binary integers and take the usual ordering). Starting with w1 = 0, define w2, w3, ..., w12 by the rule that wn is the smallest integer which differs from all linear combinations of previous elements in at least eight coordinates. Then W can be defined as the span of w1, ..., w12.
  2. Quadratic residue code: Consider the set N of quadratic non-residues (mod 23). This is an 11-element subset of the cyclic group Z/23Z. Consider the translates t+N of this subset. Augment each translate to a 12-element set St by adding an element ∞. Then labeling the basis elements of V by 0, 1, 2, ..., 22, ∞, W can be defined as the span of the words St together with the word consisting of all basis vectors. (The perfect code is obtained by leaving out ∞.)
  3. As a Cyclic code: The perfect G23 code can be constructed via factorization of x23 − 1, it is the code generated by x11 + x10 + x6 + x5 + x4 + x2 + 1 / x23 − 1
  4. The Miracle Octad Generator of R. T. Curtis: This uses a 4×6 array of square cells to picture the 759 Hamming-weight-8 code words, or "octads," of the extended binary Golay code. The remaining code words are obtained via symmetric differences of subsets of the 24 cells-- i.e., by binary addition.
  5. Winning positions in the mathematical game of Mogul: a position in Mogul is a row of 24 coins. Each turn consists of flipping from one to seven coins such that the leftmost of the flipped coins goes from head to tail. The losing positions are those with no legal move. If heads are interpreted as 1 and tails as 0 then moving to a codeword from the extended binary Golay code guarantees it will be possible to force a win.
  6. A generator matrix for the binary Golay code is I A, where I is the 12×12 identity matrix, and A is the complement of the adjacency matrix of the icosahedron.

[edit] Practical applications of Golay codes

[edit] NASA Deep Space Missions

The Voyager 1 & 2 spacecraft needed to transmit hundreds of color pictures of Jupiter and Saturn in their 1979, 1980, and 1981 fly-bys within a constrained telecommunications bandwidth.

  • Color image transmission required three times the amount of data, so the Golay (24,12,8) code was used. [1]
  • This Golay code is only triple-error correcting, but it could be transmitted at a much higher data rate than the Hadamard code that was used during the Mariner mission.

[edit] ALE HF data communications

The new American government standards for automatic link establishment (ALE) in High Frequency (HF) radio systems specifies the use of an extended (24,12) Golay block code for forward error correction (FEC).

  • The Extended (24,12) Golay Code specified is a (24,12) block code.
  • This code encodes 12 data bits to produce 24-bit code words.
  • It is furthermore a systematic code, meaning that the 12 data bits are present in unchanged form in the code word.

The minimum Hamming distance between any two code words (the number of bits by which any pair of code words differs) is eight.

[edit] See also

[edit] Notes

[edit] References

  • Golay, Marcel J. E. (1949). "Notes on Digital Coding". Proc. IRE 37: 657. 
  • Curtis, R. T. (1976). "A new combinatorial approach to M24". Math. Proc. Camb. Phil. Soc. 79: 25–42. doi:10.1017/S0305004100052075. 
  • Griess, Robert L. (1998). Twelve Sporadic Groups. Springer. pp. 167. ISBN 9783540627784. 
  • Thompson, Thomas M. (1983). From Error Correcting Codes through Sphere Packings to Simple Groups. Carus Mathematical Monographs. 21. Mathematical Association of America. ISBN 9780883850237. 
Personal tools
Namespaces
Variants
Actions
Navigation
Interaction
Toolbox
Print/export
Languages