Код Хэмминга: различия между версиями
[непроверенная версия] | [непроверенная версия] |
оформление |
Sldst-bot (обсуждение | вклад) м В шаблоне 'переработать' (до 2016 ш:cleanup) добавлена дата установки: 2010-08-23 |
||
(не показаны 332 промежуточные версии, сделанные более чем 100 участниками) | |||
Строка 1: | Строка 1: | ||
{{переработать|дата=2010-08-23}} |
|||
'''Коды Хемминга — простейшие линейные коды с минимальным расстоянием 3, то есть способные исправить одну ошибку.''' В коде Хемминга вводится понятие кодового расстояния <math>d(\cdot,\cdot)</math> (расстояния между двумя кодами), равного числу разрядов с неодинаковыми значениями. Возможности исправления ошибок связаны с минимальным кодовым расстоянием <math>d_{min}</math>. Исправляются ошибки кратности <math>r = \frac{ent (d_{min}-1)}{2}</math> и обнаруживаются ошибки кратности <math>d_{min}-1</math> (здесь ent означает «целая часть»). Так, при контроле на нечетность <math>d_{min} = 2</math> и обнаруживаются одиночные ошибки. В коде Хемминга <math>d_{min} = 3</math>. Дополнительно к информационным разрядам вводится <math>L = \log{2K}</math> избыточных контролирующих разрядов, где <math>K</math> — число информационных разрядов, <math>L</math> округляется до ближайшего большего целого значения. <math>L</math> - разрядный контролирующий код есть инвертированный результат поразрядного сложения (то есть сложения по модулю 2) номеров тех информационных разрядов, значения которых равны 1. |
|||
{{нет источников|дата=2011-07-09}} |
|||
{{Карточка кода |
|||
'''П р и м е р 1'''. Пусть имеем основной код 100110, то есть К = 6. Следовательно, L = 3 и дополнительный код равен |
|||
| название = Двоичный код Хэмминга |
|||
| изображение = Hamming(7,4).svg |
|||
| подпись = Код Хэмминга <math>(7, 4)</math> с <math>r=3</math> |
|||
| размер = 160px |
|||
| назван в честь = [[Хэмминг, Ричард Уэсли|Ричард Хэмминг]] |
|||
| тип = [[линейный блочный код]] |
|||
| длина блока = <math>2^r-1</math> |
|||
| длина сообщения = <math>2^r-r-1</math> |
|||
| доля = <math>1-\frac{2}{2^r-1}</math> |
|||
| расстояние = 3 |
|||
| размер алфавита = 2 |
|||
| обозначение = <math>[2^r-1, 2^r-r-1, 3]_2</math> |
|||
}} |
|||
'''Код Хэ́мминга''' — самоконтролирующийся и самокорректирующийся [[код]]. Построен применительно к [[Двоичная система счисления|двоичной системе счисления]]. |
|||
Позволяет исправлять одиночную ошибку (ошибка в одном бите слова) и находить двойную<ref>{{Cite web|accessdate = 2016-01-20|title = Коды Хемминга — "Все о Hi-Tech"|url = http://all-ht.ru/inf/systems/p_0_14.html|publisher = all-ht.ru|archive-date = 2016-01-15|archive-url = https://web.archive.org/web/20160115162714/http://all-ht.ru/inf/systems/p_0_14.html|deadlink = no}}</ref>. |
|||
Назван в честь американского математика [[Хэмминг, Ричард Уэсли|Хэмминга Ричарда Уэсли]], предложившего код. |
|||
010 # 011 # 110 = 111, |
|||
== История == |
|||
где # — символ операции поразрядного сложения, и после инвертирования имеем 000. Теперь вместе с основным кодом будет передан и дополнительный. На приемном конце вновь рассчитывается дополнительный код и сравнивается с переданным. Фиксируется код сравнения (поразрядная операция отрицания равнозначности), и если он отличен от нуля, то его значение есть номер ошибочно принятого разряда основного кода. Так, если принят код 100010, то рассчитанный в приемнике дополнительный код равен инверсии от 010 # 110 = 100, то есть 011, что означает ошибку в 3-м разряде. |
|||
В середине 1940-х годов в [[лаборатории Белла]] была создана счётная машина ''Bell Model V''. Это была электромеханическая машина, использующая релейные блоки, скорость которых была очень низка: одна операция за несколько секунд. Данные вводились в машину с помощью [[Перфокарта|перфокарт]] с ненадёжными устройствами чтения, поэтому в процессе чтения часто происходили ошибки. В рабочие дни использовались специальные коды, чтобы обнаруживать и исправлять найденные ошибки, при этом оператор узнавал об ошибке по свечению лампочек, исправлял и снова запускал машину. В выходные дни, когда не было операторов, при возникновении ошибки машина автоматически выходила из программы и запускала другую. |
|||
Хэмминг часто работал в выходные дни и всё больше раздражался, так как должен был перезагружать свою программу из-за ненадёжности считывателя перфокарт. На протяжении нескольких лет он искал эффективный алгоритм исправления ошибок. В [[1950 год]]у он опубликовал способ кодирования, который известен как код Хэмминга. |
|||
'''П р и м е р 2'''. Основной код 1100000, дополнительный код 110 (результат инверсии кода 110 # 111 = 001). Пусть принятый код 1101000, его дополнительный код 010, код сравнения 100, то есть ошибка в четвертом разряде. |
|||
== Систематические коды == |
|||
{{wikify}} |
|||
Систематические коды образуют большую группу из блочных, разделимых кодов (в которых все символы слова можно разделить на проверочные и информационные). Особенностью систематических кодов является то, что проверочные символы образуются в результате [[Линейный код|линейных логических операций]] над информационными символами. Кроме того, любая разрешенная кодовая комбинация может быть получена в результате линейных операций над набором линейно независимых кодовых комбинаций. |
|||
== Самоконтролирующиеся коды == |
|||
[[cs:Hammingův kód]] |
|||
Коды Хэмминга являются самоконтролирующимися кодами, то есть кодами, позволяющими автоматически обнаруживать ошибки при передаче данных. Для их построения достаточно приписать к каждому слову один добавочный (контрольный) двоичный разряд и выбрать цифру этого разряда так, чтобы общее количество единиц в изображении любого числа было, например, нечётным. Одиночная ошибка в каком-либо разряде передаваемого слова (в том числе, может быть, и в контрольном разряде) изменит чётность общего количества единиц. Счётчики по модулю 2, подсчитывающие количество единиц, которые содержатся среди двоичных цифр числа, дают сигнал о наличии ошибок. При этом невозможно узнать, в какой именно позиции слова произошла ошибка, и, следовательно, нет возможности исправить её. Остаются незамеченными также ошибки, возникающие одновременно в двух, четырёх, и т. д. — в чётном количестве разрядов. Предполагается, что двойные, а тем более многократные ошибки маловероятны. |
|||
[[de:Hamming-Code]] |
|||
[[en:Hamming code]] |
|||
== Самокорректирующиеся коды == |
|||
[[es:Código Hamming]] |
|||
Коды, в которых возможно автоматическое исправление ошибок, называются самокорректирующимися. Для построения самокорректирующегося кода, рассчитанного на исправление одиночных ошибок, одного контрольного разряда недостаточно. Как видно из дальнейшего, количество контрольных разрядов <math>k</math> должно быть выбрано так, чтобы удовлетворялось неравенство <math>2^k \geq k+m+1</math> или <math> k \geq \log_2(k+m+1)</math>, где <math>m</math> — количество информационных двоичных разрядов кодового слова. Минимальные значения k при заданных значениях m, найденные в соответствии с этим неравенством, приведены в таблице. |
|||
[[fr:Code de Hamming]] |
|||
[[he:קוד המינג]] |
|||
{| class="wikitable" |
|||
[[it:Codice di Hamming]] |
|||
|+ |
|||
[[ja:ハミング符号]] |
|||
! Диапазон m |
|||
[[ko:해밍 부호]] |
|||
! k<sub>min</sub> |
|||
[[nl:Hamming-code]] |
|||
|- |
|||
[[vi:Mã Hamming]] |
|||
| 1 |
|||
| 2 |
|||
|- |
|||
| 2-4 |
|||
| 3 |
|||
|- |
|||
| 5-11 |
|||
| 4 |
|||
|- |
|||
| 12-26 |
|||
| 5 |
|||
|- |
|||
| 27-57 |
|||
| 6 |
|||
|} |
|||
Наибольший интерес представляют [[Обнаружение и исправление ошибок#Коды обнаружения и исправления ошибок|двоичные блочные корректирующие коды]]. При использовании таких кодов информация передаётся в виде блоков одинаковой длины, и каждый блок кодируется и декодируется независимо от другого. Почти во всех блочных кодах символы можно разделить на информационные и проверочные или контрольные. Таким образом, все слова разделяются на разрешённые (для которых соотношение информационных и проверочных символов возможно) и запрещённые. |
|||
Основные характеристики самокорректирующихся кодов: |
|||
# Число разрешённых и запрещённых комбинаций. Если <math>n</math> — число символов в блоке, <math>r</math> — число проверочных символов в блоке, <math>k</math> — число информационных символов, то '''<math>2^n</math>''' — число возможных кодовых комбинаций, '''<math>2^k</math>''' — число разрешённых кодовых комбинаций, '''<math>2^n - 2^k</math>''' — число запрещённых комбинаций. |
|||
# Избыточность кода. Величину '''<math>\tfrac{r}{n}</math>''' называют избыточностью корректирующего кода. |
|||
# Минимальное кодовое расстояние. Минимальным кодовым расстоянием <math>d</math> называется минимальное число искажённых символов, необходимое для перехода одной разрешённой комбинации в другую. |
|||
# Число обнаруживаемых и исправляемых ошибок. Если <math>g</math> — количество ошибок, которое код способен исправить, то необходимо и достаточно, чтобы '''<math>d \geq 2g+1</math>''' |
|||
# Корректирующие возможности кодов. |
|||
[[Граница Плоткина]] даёт верхнюю границу кодового расстояния: |
|||
: <math>d\leqslant \tfrac{n \cdot 2^{k-1}}{2^k-1},</math> |
|||
или: |
|||
: <math>r \geq 2\cdot(d-1)-\log_2 d</math> при <math>n \geq 2 \cdot d-1.</math> |
|||
[[Граница Хэмминга]] устанавливает максимально возможное число разрешённых кодовых комбинаций: |
|||
: <math>2^k \leq {2^n} / \sum_{i=0}^{\tfrac{d-1}{2}} C_n^i,</math> |
|||
: где <math>C_n^i</math> — число сочетаний из <math>n</math> элементов по <math>i</math> элементам. Отсюда можно получить выражение для оценки числа проверочных символов: |
|||
: <math>r \geq \log_2\left( \sum_{i=0}^{(d-1)/2} C_n^i \right).</math> |
|||
Для значений <math>(d/n) \leq 0{,}3 </math> разница между границей Хэмминга и границей Плоткина невелика. |
|||
[[Неравенство Гильберта — Варшамова|Граница Варшамова — Гилберта]] для больших n определяет нижнюю границу числа проверочных символов: |
|||
: <math>r \geq \log_2\left(\sum_{i=0}^{d-2} C_{n-1}^i\right) .</math> |
|||
Все вышеперечисленные оценки дают представление о '''верхней границе''' <math>d</math> при фиксированных <math>n</math> и <math>k</math> или '''оценку снизу''' числа проверочных символов. |
|||
== Код Хэмминга == |
|||
Построение кодов Хэмминга основано на принципе проверки на чётность числа единичных символов: к последовательности добавляется такой элемент, чтобы число единичных символов в получившейся последовательности было чётным: |
|||
: <math>r_1 = i_1 \oplus i_2 \oplus ... \oplus i_k.</math> |
|||
Знак <math>\oplus</math> здесь означает [[сложение по модулю 2]]: |
|||
: <math>S = i_1 \oplus i_2 \oplus ... \oplus i_n \oplus r_1.</math> |
|||
Если <math>S = 0</math> — то ошибки нет, если <math>S = 1</math> — то однократная ошибка. |
|||
Такой код называется <math>(k+1,\ k) </math> или <math>(n,\ n-1) </math>. Первое число — количество элементов последовательности, второе — количество информационных символов. |
|||
Для каждого числа проверочных символов <math>r = 3,\ 4,\ 5\ ...</math> существует классический код Хэмминга с маркировкой: |
|||
: <math>(n,k)=(2^r-1,2^r-1-r),</math> то есть — <math>(7,4),(15,11),(31,26) </math>. |
|||
При иных значениях <math>k</math> получается так называемый усечённый код — например, телеграфный [[код Бодо]], у которого <math>k = 5</math>. Для него необходим код Хэмминга <math>(9,\ 5),</math> который является усечённым от классического <math>(15,\ 11).</math> |
|||
Для примера рассмотрим классический код Хэмминга <math>(7,\ 4)</math>. Сгруппируем проверочные символы следующим образом: |
|||
: <math>r_1 = i_1 \oplus i_2 \oplus i_3,</math> |
|||
: <math>r_2 = i_2 \oplus i_3 \oplus i_4,</math> |
|||
: <math>r_3 = i_1 \oplus i_2 \oplus i_4.</math> |
|||
Получение кодового слова выглядит следующим образом: |
|||
: <math>\begin{pmatrix} |
|||
i_1 & i_2 & i_3 & i_4 & \\ |
|||
\end{pmatrix} </math><math>\begin{pmatrix} |
|||
1 & 0 & 0 & 0 & 1 & 0 & 1 \\ |
|||
0 & 1 & 0 & 0 & 1 & 1 & 1 \\ |
|||
0 & 0 & 1 & 0 & 1 & 1 & 0 \\ |
|||
0 & 0 & 0 & 1 & 0 & 1 & 1 \\ |
|||
\end{pmatrix} </math> = <math>\begin{pmatrix} |
|||
i_1 & i_2 & i_3 & i_4 & r_1 & r_2 & r_3 \\ |
|||
\end{pmatrix} </math>. |
|||
На вход декодера поступает кодовое слово |
|||
<math>V = (i_1',\ i_2',\ i_3',\ i_4',\ r_1',\ r_2',\ r_3')</math>, где штрихом помечены символы, которые могут исказиться в результате действия помехи. В декодере в режиме исправления ошибок строится последовательность синдромов: |
|||
: <math>S_1 = r_1 \oplus i_1 \oplus i_2 \oplus i_3,</math> |
|||
: <math>S_2 = r_2 \oplus i_2 \oplus i_3 \oplus i_4,</math> |
|||
: <math>S_3 = r_3 \oplus i_1 \oplus i_2 \oplus i_4.</math> |
|||
<math>S = (S_1,\ S_2,\ S_3)</math> называется синдромом последовательности. |
|||
Получение синдрома выглядит следующим образом: |
|||
: <math>\begin{pmatrix} |
|||
i_1 & i_2 & i_3 & i_4 & r_1 & r_2 & r_3 \\ |
|||
\end{pmatrix} </math><math>\begin{pmatrix} |
|||
1 & 0 & 1 \\ |
|||
1 & 1 & 1 \\ |
|||
1 & 1 & 0 \\ |
|||
0 & 1 & 1 \\ |
|||
1 & 0 & 0 \\ |
|||
0 & 1 & 0 \\ |
|||
0 & 0 & 1 \\ |
|||
\end{pmatrix} </math> = <math>\begin{pmatrix} |
|||
S_1 & S_2 & S_3 \\ |
|||
\end{pmatrix}</math>. |
|||
{| class="wikitable" style="float:left; margin-right:1em; clear:left" |
|||
|<math>i_1</math> || <math>i_2</math> || <math>i_3</math> || <math>i_4</math> || <math>r_1</math> || <math>r_2</math> || <math>r_3</math> |
|||
|<math>i_1</math> |
|||
|<math>i_2</math> |
|||
|<math>i_3</math> |
|||
|<math>i_4</math> |
|||
|<math>r_1</math> |
|||
|<math>r_2</math> |
|||
|<math>r_3</math> |
|||
|- |
|||
| 0 || 0 || 0 || 0 || 0 || 0 || 0 |
|||
|1 |
|||
|0 |
|||
|0 |
|||
|0 |
|||
|1 |
|||
|0 |
|||
|1 |
|||
|- |
|||
|0 |
|||
|0 |
|||
|0 |
|||
|1 |
|||
|0 |
|||
|1 |
|||
|1 |
|||
|1 |
|||
|0 |
|||
|0 |
|||
|1 |
|||
|1 |
|||
|1 |
|||
|0 |
|||
|- |
|||
|0 |
|||
|0 |
|||
|1 |
|||
|0 |
|||
|1 |
|||
|1 |
|||
|0 |
|||
|1 |
|||
|0 |
|||
|1 |
|||
|0 |
|||
|0 |
|||
|1 |
|||
|1 |
|||
|- |
|||
|0 |
|||
|0 |
|||
|1 |
|||
|1 |
|||
|1 |
|||
|0 |
|||
|1 |
|||
|1 |
|||
|0 |
|||
|1 |
|||
|1 |
|||
|0 |
|||
|0 |
|||
|0 |
|||
|- |
|||
|0 |
|||
|1 |
|||
|0 |
|||
|0 |
|||
|1 |
|||
|1 |
|||
|1 |
|||
|1 |
|||
|1 |
|||
|0 |
|||
|0 |
|||
|0 |
|||
|1 |
|||
|0 |
|||
|- |
|||
|0 |
|||
|1 |
|||
|0 |
|||
|1 |
|||
|1 |
|||
|0 |
|||
|0 |
|||
|1 |
|||
|1 |
|||
|0 |
|||
|1 |
|||
|0 |
|||
|0 |
|||
|1 |
|||
|- |
|||
|0 |
|||
|1 |
|||
|1 |
|||
|0 |
|||
|0 |
|||
|0 |
|||
|1 |
|||
|1 |
|||
|1 |
|||
|1 |
|||
|0 |
|||
|1 |
|||
|0 |
|||
|0 |
|||
|- |
|||
|0 |
|||
|1 |
|||
|1 |
|||
|1 |
|||
|0 |
|||
|1 |
|||
|0 |
|||
|1 |
|||
|1 |
|||
|1 |
|||
|1 |
|||
|1 |
|||
|1 |
|||
|1 |
|||
|} |
|||
Кодовые слова <math>(7,\ 4)</math> кода Хэмминга приведены в таблице. |
|||
Синдром <math>(0,0,0) </math> указывает на то, что в последовательности нет искажений. Каждому ненулевому синдрому соответствует определённая конфигурация ошибок, которая исправляется на этапе декодирования. |
|||
{{-}} |
|||
{| class="wikitable" style="float:right; margin-left:1em; clear:right" |
|||
|Синдром |
|||
|001 |
|||
|010 |
|||
|011 |
|||
|100 |
|||
|101 |
|||
|110 |
|||
|111 |
|||
|- |
|||
|Конфигурация<br>ошибок |
|||
|0000001 |
|||
|0000010 |
|||
|0001000 |
|||
|0000100 |
|||
|1000000 |
|||
|0010000 |
|||
|0100000 |
|||
|- |
|||
|Ошибка в<br>символе |
|||
|<math>r_3</math> |
|||
|<math>r_2</math> |
|||
|<math>i_4</math> |
|||
|<math>r_1</math> |
|||
|<math>i_1</math> |
|||
|<math>i_3</math> |
|||
|<math>i_2</math> |
|||
|} |
|||
Для кода <math>(7,4) </math> в таблице справа указаны ненулевые синдромы и соответствующие им конфигурации ошибок (для вида: <math>i_1</math> <math>i_2</math> <math>i_3</math> <math>i_4</math> <math>r_1</math> <math>r_2</math> <math>r_3</math>). |
|||
[[Файл:My hemcode.png|600px]] |
|||
[[Файл:HemDecode.PNG|600px]] |
|||
== Алгоритм кодирования == |
|||
Предположим, что нужно сгенерировать код Хэмминга для некоторого информационного кодового слова. В качестве примера возьмём 15-битовое кодовое слово <math>x_1 \dots \ x_{15},</math> хотя алгоритм пригоден для кодовых слов любой длины. В приведённой ниже таблице в первой строке даны номера позиций в кодовом слове, во второй — условное обозначение битов, в третьей — значения битов. |
|||
{| class="wikitable" |
|||
|- |
|||
! 1 !! 2 !! 3 !! 4 !! 5 !! 6 !! 7 !! 8 !! 9 !! 10 !! 11 !! 12 !! 13 !! 14 !! 15 |
|||
|- |
|||
! '''x'''<sub>1</sub> !! '''x'''<sub>2</sub> !! '''x'''<sub>3</sub> !! '''x'''<sub>4</sub> !! '''x'''<sub>5</sub> !! '''x'''<sub>6</sub> !! '''x'''<sub>7</sub> !! '''x'''<sub>8</sub> !! '''x'''<sub>9</sub> !! '''x'''<sub>10</sub> !! '''x'''<sub>11</sub> !! '''x'''<sub>12</sub> !! '''x'''<sub>13</sub> !! '''x'''<sub>14</sub> !! '''x'''<sub>15</sub> |
|||
|- align="center" bgcolor=lightgrey |
|||
| 1 || 0 || 0 || 1 || 0 |
|||
| 0 || 1 || 0 || 1 || 1 |
|||
| 1 || 0 || 0 || 0 || 1 |
|||
|} |
|||
Вставим в информационное слово контрольные биты <math>r_0 \dots \ r_4</math> таким образом, чтобы номера их позиций представляли собой целые степени двойки: 1, 2, 4, 8, 16… Получим 20-разрядное слово с 15 информационными и 5 контрольными битами. Первоначально контрольные биты устанавливаем равными нулю. На рисунке контрольные биты выделены розовым цветом. |
|||
{| class="wikitable" |
|||
|- |
|||
! 1 !! 2 !! 3 !! 4 !! 5 !! 6 !! 7 !! 8 !! 9 !! 10 !! 11 !! 12 !! 13 !! 14 !! 15 !! 16 !! 17 !! 18 !! 19 !! 20 |
|||
|- |
|||
! '''r'''<sub>0</sub> !! '''r'''<sub>1</sub> !! '''x'''<sub>1</sub> !! '''r'''<sub>2</sub> !! '''x'''<sub>2</sub> !! '''x'''<sub>3</sub> !! '''x'''<sub>4</sub> !! '''r'''<sub>3</sub> !! '''x'''<sub>5</sub> !! '''x'''<sub>6</sub> !! '''x'''<sub>7</sub> !! '''x'''<sub>8</sub> !! '''x'''<sub>9</sub> !! '''x'''<sub>10</sub> !! '''x'''<sub>11</sub> !! '''r'''<sub>4</sub> !! '''x'''<sub>12</sub> !! '''x'''<sub>13</sub> !! '''x'''<sub>14</sub> !! '''x'''<sub>15</sub> |
|||
|- align=center bgcolor=lightgrey |
|||
|bgcolor=pink|0||bgcolor=pink|0|| 1 ||bgcolor=pink|0|| 0 || 0 || 1 ||bgcolor=pink|0|| 0 |
|||
| 0 || 1 || 0 || 1 || 1 |
|||
| 1 ||bgcolor=pink|0|| 0 || 0 || 0 || 1 |
|||
|} |
|||
В общем случае количество контрольных бит в кодовом слове равно двоичному логарифму числа, на единицу большего, чем количество бит кодового слова (включая контрольные биты); логарифм округляется в большую сторону. Например, информационное слово длиной 1 бит требует двух контрольных разрядов, 2-, 3- или 4-битовое информационное слово — трёх, 5…11-битовое — четырёх, 12…26-битовое — пяти и т. д. |
|||
Добавим к таблице 5 строк (по количеству контрольных битов), в которые поместим матрицу преобразования. Каждая строка будет соответствовать одному контрольному биту (нулевой контрольный бит — верхняя строка, четвёртый — нижняя), каждый столбец — одному биту кодируемого слова. В каждом столбце матрицы преобразования поместим двоичный номер этого столбца, причём порядок следования битов будет обратный — младший бит расположим в верхней строке, старший — в нижней. Например, в третьем столбце матрицы будут стоять числа 11000, что соответствует двоичной записи числа три: 00011. |
|||
{| class="wikitable" |
|||
|- |
|||
! 1 !! 2 !! 3 !! 4 !! 5 !! 6 !! 7 !! 8 !! 9 !! 10 !! 11 !! 12 !! 13 !! 14 !! 15 !! 16 !! 17 !! 18 !! 19 !! 20 |
|||
|- |
|||
! '''r'''<sub>0</sub> !! '''r'''<sub>1</sub> !! '''x'''<sub>1</sub> !! '''r'''<sub>2</sub> !! '''x'''<sub>2</sub> !! '''x'''<sub>3</sub> !! '''x'''<sub>4</sub> !! '''r'''<sub>3</sub> !! '''x'''<sub>5</sub> !! '''x'''<sub>6</sub> !! '''x'''<sub>7</sub> !! '''x'''<sub>8</sub> !! '''x'''<sub>9</sub> !! '''x'''<sub>10</sub> !! '''x'''<sub>11</sub> !! '''r'''<sub>4</sub> !! '''x'''<sub>12</sub> !! '''x'''<sub>13</sub> !! '''x'''<sub>14</sub> !! '''x'''<sub>15</sub> |
|||
|- align="center" bgcolor=lightgrey |
|||
|bgcolor=pink|0||bgcolor=pink|0|| 1 ||bgcolor=pink|0|| 0 || 0 || 1 ||bgcolor=pink|0|| 0 |
|||
| 0 || 1 || 0 || 1 || 1 |
|||
| 1 ||bgcolor=pink|0|| 0 || 0 || 0 || 1 |
|||
|- align="center" |
|||
| 1 || 0 || 1 || 0 || 1 || 0 || 1 || 0 || 1 || 0 || 1 || 0 || 1 || 0 || 1 || 0 || 1 || 0 || 1 || 0 |
|||
| '''r'''<sub>0</sub> || |
|||
|- align="center" |
|||
| 0 || 1 || 1 || 0 || 0 || 1 || 1 || 0 || 0 || 1 || 1 || 0 || 0 || 1 || 1 || 0 || 0 || 1 || 1 || 0 |
|||
| '''r'''<sub>1</sub> || |
|||
|- align="center" |
|||
| 0 || 0 || 0 || 1 || 1 || 1 || 1 || 0 || 0 || 0 || 0 || 1 || 1 || 1 || 1 || 0 || 0 || 0 || 0 || 1 |
|||
| '''r'''<sub>2</sub> || |
|||
|- align="center" |
|||
| 0 || 0 || 0 || 0 || 0 || 0 || 0 || 1 || 1 || 1 || 1 || 1 || 1 || 1 || 1 || 0 || 0 || 0 || 0 || 0 |
|||
| '''r'''<sub>3</sub> || |
|||
|- align="center" |
|||
| 0 || 0 || 0 || 0 || 0 || 0 || 0 || 0 || 0 || 0 || 0 || 0 || 0 || 0 || 0 || 1 || 1 || 1 || 1 || 1 |
|||
| '''r'''<sub>4</sub> || |
|||
|} |
|||
В правой части таблицы оставили пустым один столбец, в который поместим результаты вычислений контрольных битов. Вычисление контрольных битов производим следующим образом: берём одну из строк матрицы преобразования (например, <math>r_0</math>) и находим её скалярное произведение с кодовым словом, то есть перемножаем соответствующие биты обеих строк и находим сумму произведений. Если сумма получилась больше единицы, находим остаток от его деления на 2. Иными словами, мы подсчитываем, сколько раз в кодовом слове и соответствующей строке матрицы в одинаковых позициях стоят единицы, и берём это число по модулю 2. |
|||
Если описывать этот процесс в терминах матричной алгебры, то операция представляет собой перемножение матрицы преобразования на матрицу-столбец кодового слова, в результате чего получается матрица-столбец контрольных разрядов, которые нужно взять по модулю 2. |
|||
Например, для строки <math>r_0</math>: |
|||
: <math>r_0</math> = (1·0+0·0+1·1+0·0+1·0+0·0+1·1+0·0+1·0+0·0+1·1+0·0+1·1+0·1+1·1+0·0+1·0+0·0+1·0+0·1) mod 2 = 5 mod 2 = 1. |
|||
Полученные контрольные биты вставляем в кодовое слово вместо стоявших там ранее нулей. По аналогии находим проверочные биты в остальных строках. Кодирование по Хэммингу завершено. Полученное кодовое слово — 11110010001011110001. |
|||
{| class="wikitable" |
|||
|- |
|||
! 1 !! 2 !! 3 !! 4 !! 5 !! 6 !! 7 !! 8 !! 9 !! 10 !! 11 !! 12 !! 13 !! 14 !! 15 !! 16 !! 17 !! 18 !! 19 !! 20 |
|||
|- |
|||
! '''r'''<sub>0</sub> !! '''r'''<sub>1</sub> !! '''x'''<sub>1</sub> !! '''r'''<sub>2</sub> !! '''x'''<sub>2</sub> !! '''x'''<sub>3</sub> !! '''x'''<sub>4</sub> !! '''r'''<sub>3</sub> !! '''x'''<sub>5</sub> !! '''x'''<sub>6</sub> !! '''x'''<sub>7</sub> !! '''x'''<sub>8</sub> !! '''x'''<sub>9</sub> !! '''x'''<sub>10</sub> !! '''x'''<sub>11</sub> !! '''r'''<sub>4</sub> !! '''x'''<sub>12</sub> !! '''x'''<sub>13</sub> !! '''x'''<sub>14</sub> !! '''x'''<sub>15</sub> |
|||
|- align="center" bgcolor=lightgrey |
|||
|bgcolor=pink|1|| bgcolor="pink" |1|| 1 ||bgcolor=pink|1|| 0 || 0 || 1 ||bgcolor=pink|0|| 0 |
|||
| 0 || 1 || 0 || 1 || 1 |
|||
| 1 ||bgcolor=pink|1|| 0 || 0 || 0 || 1 |
|||
|- align="center" |
|||
| 1 || 0 || 1 || 0 || 1 || 0 || 1 || 0 || 1 || 0 || 1 || 0 || 1 || 0 || 1 || 0 || 1 || 0 || 1 || 0 |
|||
| '''r'''<sub>0</sub> || 1 |
|||
|- align="center" |
|||
| 0 || 1 || 1 || 0 || 0 || 1 || 1 || 0 || 0 || 1 || 1 || 0 || 0 || 1 || 1 || 0 || 0 || 1 || 1 || 0 |
|||
| '''r'''<sub>1</sub> ||1 |
|||
|- align="center" |
|||
| 0 || 0 || 0 || 1 || 1 || 1 || 1 || 0 || 0 || 0 || 0 || 1 || 1 || 1 || 1 || 0 || 0 || 0 || 0 || 1 |
|||
| '''r'''<sub>2</sub> ||1 |
|||
|- align="center" |
|||
| 0 || 0 || 0 || 0 || 0 || 0 || 0 || 1 || 1 || 1 || 1 || 1 || 1 || 1 || 1 || 0 || 0 || 0 || 0 || 0 |
|||
| '''r'''<sub>3</sub> || 0 |
|||
|- align="center" |
|||
| 0 || 0 || 0 || 0 || 0 || 0 || 0 || 0 || 0 || 0 || 0 || 0 || 0 || 0 || 0 || 1 || 1 || 1 || 1 || 1 |
|||
| '''r'''<sub>4</sub> ||1 |
|||
|} |
|||
== Алгоритм декодирования == |
|||
Алгоритм декодирования по Хэммингу абсолютно идентичен алгоритму кодирования. Матрица преобразования соответствующей размерности умножается на матрицу-столбец кодового слова, и каждый элемент полученной матрицы-столбца берётся по модулю 2. Полученная матрица-столбец получила название «матрица синдромов». Легко проверить, что кодовое слово, сформированное в соответствии с алгоритмом, описанным в предыдущем разделе, всегда даёт нулевую матрицу синдромов. |
|||
Матрица синдромов становится ненулевой, если в результате ошибки (например, при передаче слова по линии связи с шумами) один из битов исходного слова изменил своё значение. Предположим для примера, что в кодовом слове, полученном в предыдущем разделе, шестой бит изменил своё значение с нуля на единицу (на рисунке обозначено красным цветом). Тогда получим следующую матрицу синдромов. |
|||
{| class="wikitable" |
|||
|- |
|||
! 1 !! 2 !! 3 !! 4 !! 5 !! 6 !! 7 !! 8 !! 9 !! 10 !! 11 !! 12 !! 13 !! 14 !! 15 !! 16 !! 17 !! 18 !! 19 !! 20 |
|||
|- |
|||
! '''r'''<sub>0</sub> !! '''r'''<sub>1</sub> !! '''x'''<sub>1</sub> !! '''r'''<sub>2</sub> !! '''x'''<sub>2</sub> !! '''x'''<sub>3</sub> !! '''x'''<sub>4</sub> !! '''r'''<sub>3</sub> !! '''x'''<sub>5</sub> !! '''x'''<sub>6</sub> !! '''x'''<sub>7</sub> !! '''x'''<sub>8</sub> !! '''x'''<sub>9</sub> !! '''x'''<sub>10</sub> !! '''x'''<sub>11</sub> !! '''r'''<sub>4</sub> !! '''x'''<sub>12</sub> !! '''x'''<sub>13</sub> !! '''x'''<sub>14</sub> !! '''x'''<sub>15</sub> |
|||
|- align="center" bgcolor=lightgrey |
|||
|bgcolor=pink|1|| bgcolor="pink" |1|| 1 ||bgcolor=pink|1|| 0 ||bgcolor=red| 1 || 1 ||bgcolor=pink|0|| 0 |
|||
| 0 || 1 || 0 || 1 || 1 |
|||
| 1 ||bgcolor=pink|1|| 0 || 0 || 0 || 1 |
|||
|- align="center" |
|||
| 1 || 0 || 1 || 0 || 1 || 0 || 1 || 0 || 1 || 0 || 1 || 0 || 1 || 0 || 1 || 0 || 1 || 0 || 1 || 0 |
|||
| '''s'''<sub>0</sub> || 0 |
|||
|- align="center" |
|||
| 0 || 1 || 1 || 0 || 0 || 1 || 1 || 0 || 0 || 1 || 1 || 0 || 0 || 1 || 1 || 0 || 0 || 1 || 1 || 0 |
|||
| '''s'''<sub>1</sub> || 1 |
|||
|- align="center" |
|||
| 0 || 0 || 0 || 1 || 1 || 1 || 1 || 0 || 0 || 0 || 0 || 1 || 1 || 1 || 1 || 0 || 0 || 0 || 0 || 1 |
|||
| '''s'''<sub>2</sub> || 1 |
|||
|- align="center" |
|||
| 0 || 0 || 0 || 0 || 0 || 0 || 0 || 1 || 1 || 1 || 1 || 1 || 1 || 1 || 1 || 0 || 0 || 0 || 0 || 0 |
|||
| '''s'''<sub>3</sub> || 0 |
|||
|- align="center" |
|||
| 0 || 0 || 0 || 0 || 0 || 0 || 0 || 0 || 0 || 0 || 0 || 0 || 0 || 0 || 0 || 1 || 1 || 1 || 1 || 1 |
|||
| '''s'''<sub>4</sub> || 0 |
|||
|} |
|||
Заметим, что при однократной ошибке матрица синдромов всегда представляет собой двоичную запись (младший разряд в верхней строке) номера позиции, в которой произошла ошибка. В приведённом примере матрица синдромов (01100) соответствует двоичному числу 00110 или десятичному 6, откуда следует, что ошибка произошла в шестом бите. |
|||
== Применение == |
|||
Код Хэмминга используется: |
|||
* в некоторых прикладных программах в области хранения данных; |
|||
* при построении дисковых массивов [[RAID|RAID 2]]; |
|||
* в памяти типа [[ECC]] и позволяет «на лету» исправлять однократные и обнаруживать двукратные ошибки. |
|||
== См. также == |
|||
* [[Бит чётности]] |
|||
* [[Циклический код]] |
|||
* [[Циклический избыточный код]] |
|||
* [[Код Рида — Соломона]] |
|||
== Примечания == |
|||
{{примечания}} |
|||
== Литература == |
|||
* ''Питерсон У., Уэлдон Э.'' Коды, исправляющие ошибки: Пер. с англ. М.: Мир, 1976, 594 c. |
|||
* ''Пенин П. Е., Филиппов М.Р.'' Радиотехнические системы передачи информации. М.: Радио и Связь, 1984, 256 с. |
|||
* ''Блейхут Р.'' Теория и практика кодов, контролирующих ошибки. Пер. с англ. М.: Мир, 1986, 576 с. |
|||
[[Категория:Обнаружение и устранение ошибок]] |
|||
[[Категория:Теория кодирования]] |
Текущая версия от 18:18, 7 января 2025
Эта статья нуждается в переработке. |
В статье не хватает ссылок на источники (см. рекомендации по поиску). |
Двоичный код Хэмминга | |
---|---|
| |
Назван в честь | Ричард Хэмминг |
Тип | линейный блочный код |
Длина блока | |
Длина сообщения | |
Доля | |
Расстояние | 3 |
Размер алфавита | 2 |
Обозначение | |
Медиафайлы на Викискладе |
Код Хэ́мминга — самоконтролирующийся и самокорректирующийся код. Построен применительно к двоичной системе счисления.
Позволяет исправлять одиночную ошибку (ошибка в одном бите слова) и находить двойную[1].
Назван в честь американского математика Хэмминга Ричарда Уэсли, предложившего код.
История
[править | править код]В середине 1940-х годов в лаборатории Белла была создана счётная машина Bell Model V. Это была электромеханическая машина, использующая релейные блоки, скорость которых была очень низка: одна операция за несколько секунд. Данные вводились в машину с помощью перфокарт с ненадёжными устройствами чтения, поэтому в процессе чтения часто происходили ошибки. В рабочие дни использовались специальные коды, чтобы обнаруживать и исправлять найденные ошибки, при этом оператор узнавал об ошибке по свечению лампочек, исправлял и снова запускал машину. В выходные дни, когда не было операторов, при возникновении ошибки машина автоматически выходила из программы и запускала другую.
Хэмминг часто работал в выходные дни и всё больше раздражался, так как должен был перезагружать свою программу из-за ненадёжности считывателя перфокарт. На протяжении нескольких лет он искал эффективный алгоритм исправления ошибок. В 1950 году он опубликовал способ кодирования, который известен как код Хэмминга.
Систематические коды
[править | править код]Систематические коды образуют большую группу из блочных, разделимых кодов (в которых все символы слова можно разделить на проверочные и информационные). Особенностью систематических кодов является то, что проверочные символы образуются в результате линейных логических операций над информационными символами. Кроме того, любая разрешенная кодовая комбинация может быть получена в результате линейных операций над набором линейно независимых кодовых комбинаций.
Самоконтролирующиеся коды
[править | править код]Коды Хэмминга являются самоконтролирующимися кодами, то есть кодами, позволяющими автоматически обнаруживать ошибки при передаче данных. Для их построения достаточно приписать к каждому слову один добавочный (контрольный) двоичный разряд и выбрать цифру этого разряда так, чтобы общее количество единиц в изображении любого числа было, например, нечётным. Одиночная ошибка в каком-либо разряде передаваемого слова (в том числе, может быть, и в контрольном разряде) изменит чётность общего количества единиц. Счётчики по модулю 2, подсчитывающие количество единиц, которые содержатся среди двоичных цифр числа, дают сигнал о наличии ошибок. При этом невозможно узнать, в какой именно позиции слова произошла ошибка, и, следовательно, нет возможности исправить её. Остаются незамеченными также ошибки, возникающие одновременно в двух, четырёх, и т. д. — в чётном количестве разрядов. Предполагается, что двойные, а тем более многократные ошибки маловероятны.
Самокорректирующиеся коды
[править | править код]Коды, в которых возможно автоматическое исправление ошибок, называются самокорректирующимися. Для построения самокорректирующегося кода, рассчитанного на исправление одиночных ошибок, одного контрольного разряда недостаточно. Как видно из дальнейшего, количество контрольных разрядов должно быть выбрано так, чтобы удовлетворялось неравенство или , где — количество информационных двоичных разрядов кодового слова. Минимальные значения k при заданных значениях m, найденные в соответствии с этим неравенством, приведены в таблице.
Диапазон m | kmin |
---|---|
1 | 2 |
2-4 | 3 |
5-11 | 4 |
12-26 | 5 |
27-57 | 6 |
Наибольший интерес представляют двоичные блочные корректирующие коды. При использовании таких кодов информация передаётся в виде блоков одинаковой длины, и каждый блок кодируется и декодируется независимо от другого. Почти во всех блочных кодах символы можно разделить на информационные и проверочные или контрольные. Таким образом, все слова разделяются на разрешённые (для которых соотношение информационных и проверочных символов возможно) и запрещённые.
Основные характеристики самокорректирующихся кодов:
- Число разрешённых и запрещённых комбинаций. Если — число символов в блоке, — число проверочных символов в блоке, — число информационных символов, то — число возможных кодовых комбинаций, — число разрешённых кодовых комбинаций, — число запрещённых комбинаций.
- Избыточность кода. Величину называют избыточностью корректирующего кода.
- Минимальное кодовое расстояние. Минимальным кодовым расстоянием называется минимальное число искажённых символов, необходимое для перехода одной разрешённой комбинации в другую.
- Число обнаруживаемых и исправляемых ошибок. Если — количество ошибок, которое код способен исправить, то необходимо и достаточно, чтобы
- Корректирующие возможности кодов.
Граница Плоткина даёт верхнюю границу кодового расстояния:
или:
- при
Граница Хэмминга устанавливает максимально возможное число разрешённых кодовых комбинаций:
- где — число сочетаний из элементов по элементам. Отсюда можно получить выражение для оценки числа проверочных символов:
Для значений разница между границей Хэмминга и границей Плоткина невелика.
Граница Варшамова — Гилберта для больших n определяет нижнюю границу числа проверочных символов:
Все вышеперечисленные оценки дают представление о верхней границе при фиксированных и или оценку снизу числа проверочных символов.
Код Хэмминга
[править | править код]Построение кодов Хэмминга основано на принципе проверки на чётность числа единичных символов: к последовательности добавляется такой элемент, чтобы число единичных символов в получившейся последовательности было чётным:
Знак здесь означает сложение по модулю 2:
Если — то ошибки нет, если — то однократная ошибка.
Такой код называется или . Первое число — количество элементов последовательности, второе — количество информационных символов.
Для каждого числа проверочных символов существует классический код Хэмминга с маркировкой:
- то есть — .
При иных значениях получается так называемый усечённый код — например, телеграфный код Бодо, у которого . Для него необходим код Хэмминга который является усечённым от классического
Для примера рассмотрим классический код Хэмминга . Сгруппируем проверочные символы следующим образом:
Получение кодового слова выглядит следующим образом:
- = .
На вход декодера поступает кодовое слово , где штрихом помечены символы, которые могут исказиться в результате действия помехи. В декодере в режиме исправления ошибок строится последовательность синдромов:
называется синдромом последовательности.
Получение синдрома выглядит следующим образом:
- = .
0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 |
0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 |
0 | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 1 |
0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 |
0 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 |
0 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 1 |
0 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 0 |
0 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
Кодовые слова кода Хэмминга приведены в таблице.
Синдром указывает на то, что в последовательности нет искажений. Каждому ненулевому синдрому соответствует определённая конфигурация ошибок, которая исправляется на этапе декодирования.
Синдром | 001 | 010 | 011 | 100 | 101 | 110 | 111 |
Конфигурация ошибок |
0000001 | 0000010 | 0001000 | 0000100 | 1000000 | 0010000 | 0100000 |
Ошибка в символе |
Для кода в таблице справа указаны ненулевые синдромы и соответствующие им конфигурации ошибок (для вида: ).
Алгоритм кодирования
[править | править код]Предположим, что нужно сгенерировать код Хэмминга для некоторого информационного кодового слова. В качестве примера возьмём 15-битовое кодовое слово хотя алгоритм пригоден для кодовых слов любой длины. В приведённой ниже таблице в первой строке даны номера позиций в кодовом слове, во второй — условное обозначение битов, в третьей — значения битов.
1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
x1 | x2 | x3 | x4 | x5 | x6 | x7 | x8 | x9 | x10 | x11 | x12 | x13 | x14 | x15 |
1 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 |
Вставим в информационное слово контрольные биты таким образом, чтобы номера их позиций представляли собой целые степени двойки: 1, 2, 4, 8, 16… Получим 20-разрядное слово с 15 информационными и 5 контрольными битами. Первоначально контрольные биты устанавливаем равными нулю. На рисунке контрольные биты выделены розовым цветом.
1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
r0 | r1 | x1 | r2 | x2 | x3 | x4 | r3 | x5 | x6 | x7 | x8 | x9 | x10 | x11 | r4 | x12 | x13 | x14 | x15 |
0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 |
В общем случае количество контрольных бит в кодовом слове равно двоичному логарифму числа, на единицу большего, чем количество бит кодового слова (включая контрольные биты); логарифм округляется в большую сторону. Например, информационное слово длиной 1 бит требует двух контрольных разрядов, 2-, 3- или 4-битовое информационное слово — трёх, 5…11-битовое — четырёх, 12…26-битовое — пяти и т. д.
Добавим к таблице 5 строк (по количеству контрольных битов), в которые поместим матрицу преобразования. Каждая строка будет соответствовать одному контрольному биту (нулевой контрольный бит — верхняя строка, четвёртый — нижняя), каждый столбец — одному биту кодируемого слова. В каждом столбце матрицы преобразования поместим двоичный номер этого столбца, причём порядок следования битов будет обратный — младший бит расположим в верхней строке, старший — в нижней. Например, в третьем столбце матрицы будут стоять числа 11000, что соответствует двоичной записи числа три: 00011.
1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | ||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
r0 | r1 | x1 | r2 | x2 | x3 | x4 | r3 | x5 | x6 | x7 | x8 | x9 | x10 | x11 | r4 | x12 | x13 | x14 | x15 | ||
0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | ||
1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | r0 | |
0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | r1 | |
0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | r2 | |
0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | r3 | |
0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | r4 |
В правой части таблицы оставили пустым один столбец, в который поместим результаты вычислений контрольных битов. Вычисление контрольных битов производим следующим образом: берём одну из строк матрицы преобразования (например, ) и находим её скалярное произведение с кодовым словом, то есть перемножаем соответствующие биты обеих строк и находим сумму произведений. Если сумма получилась больше единицы, находим остаток от его деления на 2. Иными словами, мы подсчитываем, сколько раз в кодовом слове и соответствующей строке матрицы в одинаковых позициях стоят единицы, и берём это число по модулю 2.
Если описывать этот процесс в терминах матричной алгебры, то операция представляет собой перемножение матрицы преобразования на матрицу-столбец кодового слова, в результате чего получается матрица-столбец контрольных разрядов, которые нужно взять по модулю 2.
Например, для строки :
- = (1·0+0·0+1·1+0·0+1·0+0·0+1·1+0·0+1·0+0·0+1·1+0·0+1·1+0·1+1·1+0·0+1·0+0·0+1·0+0·1) mod 2 = 5 mod 2 = 1.
Полученные контрольные биты вставляем в кодовое слово вместо стоявших там ранее нулей. По аналогии находим проверочные биты в остальных строках. Кодирование по Хэммингу завершено. Полученное кодовое слово — 11110010001011110001.
1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | ||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
r0 | r1 | x1 | r2 | x2 | x3 | x4 | r3 | x5 | x6 | x7 | x8 | x9 | x10 | x11 | r4 | x12 | x13 | x14 | x15 | ||
1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | ||
1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | r0 | 1 |
0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | r1 | 1 |
0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | r2 | 1 |
0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | r3 | 0 |
0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | r4 | 1 |
Алгоритм декодирования
[править | править код]Алгоритм декодирования по Хэммингу абсолютно идентичен алгоритму кодирования. Матрица преобразования соответствующей размерности умножается на матрицу-столбец кодового слова, и каждый элемент полученной матрицы-столбца берётся по модулю 2. Полученная матрица-столбец получила название «матрица синдромов». Легко проверить, что кодовое слово, сформированное в соответствии с алгоритмом, описанным в предыдущем разделе, всегда даёт нулевую матрицу синдромов.
Матрица синдромов становится ненулевой, если в результате ошибки (например, при передаче слова по линии связи с шумами) один из битов исходного слова изменил своё значение. Предположим для примера, что в кодовом слове, полученном в предыдущем разделе, шестой бит изменил своё значение с нуля на единицу (на рисунке обозначено красным цветом). Тогда получим следующую матрицу синдромов.
1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | ||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
r0 | r1 | x1 | r2 | x2 | x3 | x4 | r3 | x5 | x6 | x7 | x8 | x9 | x10 | x11 | r4 | x12 | x13 | x14 | x15 | ||
1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | ||
1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | s0 | 0 |
0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | s1 | 1 |
0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | s2 | 1 |
0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | s3 | 0 |
0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | s4 | 0 |
Заметим, что при однократной ошибке матрица синдромов всегда представляет собой двоичную запись (младший разряд в верхней строке) номера позиции, в которой произошла ошибка. В приведённом примере матрица синдромов (01100) соответствует двоичному числу 00110 или десятичному 6, откуда следует, что ошибка произошла в шестом бите.
Применение
[править | править код]Код Хэмминга используется:
- в некоторых прикладных программах в области хранения данных;
- при построении дисковых массивов RAID 2;
- в памяти типа ECC и позволяет «на лету» исправлять однократные и обнаруживать двукратные ошибки.
См. также
[править | править код]Примечания
[править | править код]- ↑ Коды Хемминга — "Все о Hi-Tech" . all-ht.ru. Дата обращения: 20 января 2016. Архивировано 15 января 2016 года.
Литература
[править | править код]- Питерсон У., Уэлдон Э. Коды, исправляющие ошибки: Пер. с англ. М.: Мир, 1976, 594 c.
- Пенин П. Е., Филиппов М.Р. Радиотехнические системы передачи информации. М.: Радио и Связь, 1984, 256 с.
- Блейхут Р. Теория и практика кодов, контролирующих ошибки. Пер. с англ. М.: Мир, 1986, 576 с.