
- •13 Исследование систем связи с использованием корректирующего блочного кода хемминга
- •13.1 Цель работы
- •13.2 Методические указания по организации самостоятельной работы студентов
- •Основные характеристики корректирующих кодов.
- •Число разрешённых и запрещённых кодовых комбинаций.
- •Избыточность корректирующего кода.
- •Минимальное кодовое расстояние
- •Число обнаруживаемых или исправляемых ошибок.
- •Корректирующие возможности кодов.
- •Корректирующие коды Хемминга.
- •13.3 Описание лабораторной установки
- •0 0 0 0;
- •13.5 Содержание отчета
- •13.6 Контрольные вопросы и задания
Корректирующие коды Хемминга.
Построение кодов Хемминга базируется на принципе проверки на чётность веса W(числа единичных символов) в информационной группе кодового блока.
Поясним идею проверки на чётность на примере простейшего корректирующего кода, который так и называется кодом с проверкой на чётность или кодом с проверкой по паритету (равенству).
В таком коде к кодовым комбинациям безизбыточного первичного двоичного m- разрядного кода добавляется один дополнительный разряд (символ проверки на чётность, называемый проверочным, или контрольным). Если число символов “1” исходной кодовой комбинации чётное, то в дополнительном разряде формируют контрольный символ 0, а если число символов “1” нечётное, то в дополнительном разряде формируют символ 1. В результате общее число символов “1” в любой передаваемой кодовой комбинации всегда будет чётным.
Таким образом, правило формирования проверочного символа сводится к следующему:
,
где i- соответствующий информационный символ (0 или 1),m- общее их число а под операцией "" здесь и далее понимается сложение поmod2. Очевидно, что добавление дополнительного разряда увеличивает общее число возможных комбинаций вдвое по сравнению с числом комбинаций исходного первичного кода, а условие чётности разделяет все комбинации на разрешённые и неразрешённые. Код с проверкой на чётность позволяет обнаруживать одиночную ошибку при приёме кодовой комбинации, так как такая ошибка нарушает условие чётности, переводя разрешённую комбинацию в запрещённую.
Критерием правильности принятой комбинации является равенство нулю результата Sсуммирования поmod2 всехnсимволов кода, включая проверочный символk1. При наличии одиночной ошибкиSпринимает значение 1:
.
Этот код является (m+1,m) - кодом, или (n,n-1) - кодом. Минимальное расстояние кода равно двум (dmin= 2), и, следовательно, никакие ошибки не могут быть исправлены. Простой код с проверкой на чётность может использоваться только для обнаружения (но не исправления) однократных ошибок.
Увеличивая число дополнительных проверочных разрядов и формируя по определённым правилам проверочные символы k, равные 0 или 1, можно усилить корректирующие свойства кода так, чтобы он позволял не только обнаруживать, но и исправлять ошибки. На этом и основано построение кодов Хемминга.
Коды Хемминга. Рассмотрим эти коды, позволяющие исправлять одиночную ошибку, с помощью непосредственного описания. Для каждого числа проверочных символовk= 3,4,5… существует классический код Хемминга с маркировкой
(n,m) = (2k– 1, 2k– 1 –k) , (13.19)
т.е. - (7,4), (15,11), (31,26) …
При других значениях числа информационных символов mполучаются так называемые усечённые (укороченные) коды Хемминга. Так, для международного телеграфного кода МТК-2 , имеющего 5 информационных символов, потребуется использование корректирующего кода (9,5), являющегося усечённым от классического кода Хемминга (15,11), так как число символов в этом коде уменьшается (укорачивается) на 6. Для примера рассмотрим код Хемминга (7,4), который можно сформировать и описать с помощью кодера, представленного на рис.13.1. В простейшем варианте при заданных четырёх (m = 4) информационных символах (i1,i2,i3,i4) будем полагать, что они сгруппированы в начале кодового слова, хотя это и не обязательно. Дополним эти информационные символы тремя проверочными символами (k= 3), задавая их следующими равенствами проверки на чётность, которые определяются соответствующими алгоритмами. Известно, что кодовое расстояние равно минимальному числу проверок, в которые входит информационный символ плюс один. В рассматриваемом кодеdmin. Следовательно каждый информационный символ должен входить минимум в две проверки. Определим правило формирования проверочных символов следующий образом:
В соответствии с этим алгоритмом определения значений проверочных символов kiна рис.13.3 приведены все возможные 16 кодовых слов (7,4) - кода Хемминга.
На рис. 13.2приведена схема декодера для (7,4) - кода Хемминга, на вход которого поступает кодовое слово
.
Апостроф означает, что любой символ слова может быть искажён помехой в канале передачи.
В декодере в режиме исправления ошибок строится последовательность:
Трёхсимвольная последовательность (s1, s2, s3) называется синдромом. Термин "синдром" используется и в медицине, где он обозначает сочетание признаков, характерных для определённого заболевания. В данном случае синдромS= (s1, s2,s3) представляет собой сочетание результатов проверки на чётность соответствующих символов кодовой группы и характеризует определённую конфигурацию ошибок (вектор ошибок).
Рис.13.1. Кодер для простого (7,4) - кода Хемминга
Рис.13.2. Декодер для простого (7,4) - кода Хемминга
m= 4 |
k= 3 | |||||
i1 |
i2 |
i3 |
i4 |
k1 |
k2 |
k3 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
0 |
1 |
0 |
1 |
1 |
0 |
0 |
1 |
0 |
1 |
1 |
0 |
0 |
0 |
1 |
1 |
1 |
0 |
1 |
0 |
1 |
0 |
0 |
1 |
1 |
1 |
0 |
1 |
0 |
1 |
1 |
0 |
0 |
0 |
1 |
1 |
0 |
0 |
0 |
1 |
0 |
1 |
1 |
1 |
0 |
1 |
0 |
1 |
0 |
0 |
0 |
1 |
0 |
1 |
1 |
0 |
0 |
1 |
1 |
1 |
0 |
1 |
0 |
1 |
0 |
0 |
1 |
1 |
1 |
0 |
1 |
1 |
0 |
0 |
0 |
1 |
1 |
0 |
0 |
0 |
1 |
0 |
1 |
1 |
0 |
1 |
0 |
0 |
1 |
1 |
1 |
1 |
0 |
1 |
0 |
0 |
1 |
1 |
1 |
1 |
1 |
1 |
1 |
Рис.13.3. Кодовые слова код (7,4) – кода Хемминга
Число возможных синдромов определяется выражением
S = 2k. (13.20)
При числе проверочных символов k= 3 имеется восемь возможных синдромов (23= 8). Нулевой синдром (000) указывает на то, что ошибки при приёме отсутствуют или не обнаружены. Всякому ненулевому синдрому соответствует определённая конфигурация ошибок, которая и исправляется. Классические коды Хемминга (13.19) имеют число синдромов, точно равное их необходимому числу, позволяют исправить все однократные ошибки в любом информативном и проверочном символах и включают один нулевой синдром. Такие коды называются плотноупакованными.
Усечённые коды являются неплотноупакованными, так как число синдромов у них превышает необходимое. Так, в коде (9,5) при четырёх проверочных символах число синдромов будет равно 24=16, в то время как необходимо всего 10. Лишние 6 синдромов свидетельствуют о неполной упаковке кода (9,5).
Для рассматриваемого кода (7,4) в табл.13.1 представлены ненулевые синдромы и соответствующие конфигурации ошибок.
Таблица 13.1
Синдром |
001 |
010 |
011 |
100 |
101 |
110 |
111 |
Конфигурация ошибок |
0000001 |
0000010 |
0001000 |
0000100 |
1000000 |
0010000 |
0100000 |
Ошибка в символе |
k3 |
k2 |
i4 |
k1 |
i1 |
i3 |
i2 |
Таким образом, код (7,4) позволяет исправить все одиночные ошибки. Простая проверка показывает, что каждая из ошибок имеет свой единственный синдром. При этом возможно создание такого цифрового корректора ошибок (дешифратора синдрома), который по соответствующему синдрому исправляет соответствующий символ в принятой кодовой группе. После внесения исправления проверочные символы kiможно на выход декодера (рис.13.2) не выводить. Две или более ошибки превышают возможности корректирующего кода Хемминга, и декодер будет ошибаться. Это означает, что он будет вносить неправильные исправления и выдавать искажённые информационные символы.
Идея построения подобного корректирующего кода, естественно, не меняется при перестановке позиций символов в кодовых словах. Все такие варианты также называются (7,4) - кодами Хемминга.
Расширенные коды Хеммингастроятся в результате дополнения кодов сdmin= 3 общей проверкой каждой из кодовых комбинаций на чётность, т.е. ещё одним проверочным символом. Это позволяет увеличить минимальное кодовое расстояние доdmin= 4.