Декодирование циклических кодов проводится путем деления принятого КВ на образующий многочлен. Если ошибки нет, то деление выполняется без остатка. Появление остатка сигнализирует об ошибке, исправление которой осуществляется в следующей последовательности.
Подсчитывается вес остатка . Если он равен или меньше кратности исправляемых ошибок, т.е. , то принятый КВ складывают по модулю 2 с остатком и получают исправленный КВ.
Если , то производится циклический сдвиг на один символ влево и полученный после такого сдвига КВ снова делится на образующий многочлен. Если вес полученного остатка , то циклически сдвинутую комбинацию складывают с остатком и полученный КВ циклически сдвигают в обратную сторону. В результате на исходной позиции получают исправленный КВ.
Если после первого сдвига и последующего деления на вновь оказывается , делается еще один сдвиг влево, снова проверяют остаток и так до тех пор, пока не окажется . После сложения сдвинутой комбинации с остатком осуществляется ее сдвиг в обратную сторону на столько шагов, на сколько их было сделано до получения требуемого остатка.
|
|
Пример.
Предположим, что при передаче рассмотренного выше КВ произошло искажение 2-го разряда, т.е. принятый КВ имеет вид: . Определим истинный вид поступившего КВ.
Решение.
Согласно правилу, необходимо делить поступивший КВ на образующий многочлен и оценивать вес остатка. Выполняем:
. Остаток не нулевой, следовательно, есть ошибка.
Вес – нужно осуществить циклический сдвиг принятой кодовой комбинации влево и повторить деление:
1) | ||||||||||||||||||||||
. Опять , поэтому выполняем еще один циклический сдвиг влево и повторяем деление:
|
|
2) | ||||||||||||||||||||||
. Здесь , поэтому складываем сдвинутую кодовую комбинацию с остатком по модулю 2:
Полученную после суммирования комбинацию циклически сдвигаем вправо на 2 такта:
– 1-ый сдвиг вправо | |||||||
– 2-ой сдвиг вправо | |||||||
Исправленная кодовая комбинация – 1001110.
2.6.4. Циклические коды с .
Циклические коды с d = 4. Эти коды могут обнаруживать одиночные, двойные и тройные ошибки или, в случае применения мажоритарного декодирования, обнаруживать двойные и исправлять одиночные ошибки.
Степень образующего многочлена и, соответственно, число контрольных разрядов в этом коде должно быть на единицу больше, чем для кода с :
. (2.60)
Образующий многочлен равен произведению двучлена на многочлен :
(2.61)
Это объясняется тем, что двучлен позволяет обнаружить все одиночные и тройные ошибки, а многочлен – двойные ошибки. Так, для кода (7,3), обнаруживающего все тройные ошибки, можно выбрать .
Дальнейшая процедура кодирования остается такой же, как и в кодах с .
Пример.
Требуется закодировать сообщение циклическим кодом с .
Решение.
Определяем степень образующего многочлена для по (2.25):
Выбираем из таблицы 2.4 образующий многочлен . Тогда
, .
Разделив на , находим остаток:
.
Закодированная комбинация имеет вид:
, код (18,12).
Обнаружение ошибок производится по остаткам от деления принятой комбинации на образующий многочлен . Если остаток нулевой, то контрольные разряды отбрасываются, а информационная часть используется по назначению. Если в результате деления получается ненулевой остаток, то комбинация бракуется.
Пример.
Пусть в рассмотренной выше комбинации кода (18,12) при передаче исказились 5, 7 и 11 разряды. Произведем декодирование.
Остаток ненулевой, поэтому комбинация бракуется.
|
|
Процесс исправления однократной ошибки и одновременного обнаружения двойной будет рассмотрен в п. 2.6.6 на примере кода (7,3).
Циклические коды с d 5 позволяют обнаруживать и исправлять любое число ошибок. В литературе эти коды известны как коды БЧХ (первые буквы фамилий Боуз, Чоудхури, Хоквинхем – разработчиков методики построения этих кодов). Построение кодов БЧХ отличается от построения циклических кодов с только выбором образующего многочлена. Заданными при кодировании здесь являются кратность исправляемой ошибки и длина кодового слова n (на величину n при этом накладывается ряд ограничений). Числа информационных символов k и контрольных символов m подлежат определению.
Методика построения кодов БЧХ рассмотрена, например, в работах [6] и [8]. Декодирование кодов БЧХ производится по той же методике, что и декодирование циклических кодов с .
Коды БЧХ, предназначенные для исправления взаимно независимых ошибок, могут использоваться также для обнаружения и исправления пакетов ошибок. Однако более эффективными при решении этих задач являются специализированные коды, например, коды Файра [6] и коды Рида-Соломона [1]. При исправлении пакетов ошибок эти коды имеют значительно меньшую избыточность, чем коды БЧХ.