Код Хэмминга

Код Хэмминга предназначен для исправления одиночных ошибок и имеет кодовое расстояние dmin=3. Значения n и k кодов Хэмминга связаны соотношением 2n-k-1=n. Строки проверочной матрицы Н представляют собой различные ненулевые последовательности длины (n-k). Изначально правила формирования проверочных элементов выбирались (50-е годы) так, чтобы результат контрольных сумм при приеме указывал порядковый номер искаженного элемента.

Пусть ai – информационные символы, bi – проверочные символы. Если проверочные символы разместить в кодовой комбинации на позициях, номера которых являются степенью двойки (1, 2, 4, 8 и т.д.), то получаемый синдром в двоичном виде указывает на номер искаженного элемента. Рассмотрим это на примере кода (7,4). Пусть на вход кодера поступает информационная последовательность U=u4u3u2u1. В кодовой комбинации кода Хемминга информационные биты размещаются в разрядах 3,5,6 и 7. В разрядах 1,2 и 4 размещаются проверочные биты. Перепишем информационную последовательность в следующем виде U=a7a6a5a3.

Правило формирования проверочных символов заключается в следующем: значение любого информационного символа должно быть равно сумме по модулю 2 тех проверочных символов, порядковые номера которых входят в разложение по степеням двойки порядкового номера данного информационного символа.

a7 a6 a5 b4 a3 b2 b1

 
 

Решим эту систему уравнений относительно b1, b2 и b4.

Тогда элементы синдрома S=s2 s1 s0 равны

Например, если ошибка произошла в символе a3, синдром будет иметь следующий вид S=(011), что означает десятичное число 3.


Понравилась статья? Добавь ее в закладку (CTRL+D) и не забудь поделиться с друзьями:  



double arrow
Сейчас читают про: