Студопедия
Случайная страница | ТОМ-1 | ТОМ-2 | ТОМ-3
АвтомобилиАстрономияБиологияГеографияДом и садДругие языкиДругоеИнформатика
ИсторияКультураЛитератураЛогикаМатематикаМедицинаМеталлургияМеханика
ОбразованиеОхрана трудаПедагогикаПолитикаПравоПсихологияРелигияРиторика
СоциологияСпортСтроительствоТехнологияТуризмФизикаФилософияФинансы
ХимияЧерчениеЭкологияЭкономикаЭлектроника

Методы обнаружения и исправления ошибок

Читайте также:
  1. I. МЕТОДЫ РАСКОПОК
  2. А какие методы сбора данных об ожиданиях потребителей лучше использовать малому предприятию?
  3. Активные методы обучения студентов.
  4. Альтернативные методы печати
  5. Аудиолингвальный и аудиовизуальный методы обучения иностранным языкам
  6. Базовые методы обработки экономической информации
  7. Биологические методы остановки кровотечения.

 

Пусть под влиянием помехи e(x) в канале связи передаваемая кодовая комбинация b(х) переходит в принимаемую кодовую комбинацию b*(х), т.е. b*(х)=b(х)Åe(x)..

Помимо порождающего полинома существует проверочный полином h(x), причем

h(x)=hmxm+hm-1xm-1+…+h1x+h0.

Проверочная матрица циклического кода имеет следующий вид

.

Пример. Для циклического кода (7,4) g(х)=х32+1, k=3. Тогда проверочный полином h(x)=(x7+1)/(х32+1)=x4+x3+x2+1. Проверочная матрица имеет следующий вид

.

Если умножить b*(х) на полином h(x), то получим

b*(х)h(x)=b(х)h(x)Åe(x)h(x)=e(x)h(x) по mod(xn+1),

т.к. b(х)h(x)=b(х)(xn+1)/g(х)=0.

При коррекции ошибок с использованием свойств проверочного полинома последовательность

d(x)=e(x)h(x) по mod(xn+1)

есть опознователь (синдром) ошибки.

Если e(x)h(x)¹0 по mod(xn+1), то принятая кодовая комбинация b*(х) не совпадает ни с одним из элементов идеала (не принадлежит циклическому коду), что свидетельствует о наличии ошибки в принятой кодовой комбинации.

Многочлены ошибок различимы, если ei(x)h(x)¹ej(x)h(x).

Допустим, полиномы ei(x) и ej(x) различимы, причем ej(x)=xrei(x), r=1,2,…,n-1. Тогда dj(x)=ej(x)h(x)=xrei(x)h(x)=xrdi(x) по mod(xn+1), т.е. dj(x) есть результат циклического сдвига на r шагов влево полинома di(x). Это упрощает процедуру коррекции ошибок.

Пример. Циклический код (7,4) имеет проверочный полином h(x)=x4+x3+x2+1, d=3, s=1.

Для исправления одиночных ошибок решающая схема декодирующего устройства настроена на корректор d6(x), соответствующий ошибке старшего разряда, что соответствует ошибке e6(x)=x6. Определим корректор ошибки старшего разряда

d6(x)=e6(x)h(x)=x6(x4+x3+x2+1)=x6+x3+x2 по mod (x7+1), d6=1001110.

d(x)=b*(х)h(x)=(x5+x2) (x4+x3+x2+1)=x6+x4+x+1 (1010011) по mod (x7+1), d(x)¹d6(x).

Следовательно, принятая кодовая комбинация не содержит ошибки в старшем (шестом разряде). Найденный корректор d(x) сдвигаем на один разряд влево, получим d=0100111, d(x)¹d6(x), следовательно, и в пятом разряде принятой кодовой комбинации нет ошибки. Затем уже корректор d(x) сдвигаем на один разряд влево, получим d’’=1001110, d’’(x)=d6(x), следовательно, в четвертом разряде принятой кодовой комбинации есть ошибка.

С другой стороны, т.к. h(x)=(xn+1)/g(x), то синдром ошибки принятой кодовой комбинации определится

.

Аналогично, если ej(x)=xrei(x), то

,

т.е. dj(x) образуется в результате сдвига di(x) на r шагов влево.

Пример. Циклический код (7,4) имеет порождающий полином g(x)=x3+x2+1, d=3, s=1. Корректор настроен на ошибку старшего разряда e6(x)=x6. Корректор ошибки старшего разряда

x2+x по mod g(x).

Пусть b=0110100, e(x)=x4, т.е. b*=0100100. Корректор ошибки в принятой кодовой комбинации b* равен

x2+x+1 по mod g(x).

Найденный корректор d(x) не равен d6(x), следовательно, принятая кодовая комбинация не содержит ошибки в старшем разряде. Сдвигаем d(x) на один разряд влево, получим d(x)=d(x)х=x3+x2+х=х+1 по mod (х3+x2+1),. Так как d(x)¹d6(x),, то в пятом разряде b* также нет ошибки. Выполняем еще один сдвиг d(x) влево, получим d’’(x)=d(x)x=x2+х. d’’(x)=d6(x), следовательно, в четвертом разряде принятой кодовой комбинации есть ошибка.

Условия выбора порождающего полинома следующие.

Задано m информационных символов, известны значения r и s. Определяем значения d и k.

Число k соответствует степени порождающего полинома g(x), степень полинома должна быть не менее числа k.

Полином g(x) является делителем двучлена (xn+1).

Корректирующая способность кода будет тем выше, чем больше остатков от деления можно получить от деления xn на полином g(x) (представляется как единица со многими нулями). Остатки от деления отличаются друг от друга в d-2 и более разрядах, вес остатков более либо равен d-1.

Полином g(x) может быть произведением двух и более простых полиномов, входящих в разложение (xn+1).

Число ненулевых коэффициентов в полиноме g(x) должно быть больше либо равно d.

В табл.4.1 приведены разложения полинома (xn+1) на неприводимые сомножители.

В табл. 5.2 сомножитель (x+1), входящий в разложение полинома (xn+1) любой степени, не приведен, но его следует учитывать при выборе порождающего полинома.

С целью сокращения записи многочлены разложения (xn+1) кодированы восьмеричным кодом: 0«000, 1«001, 2«010, 3«011, 4«100, 5«101, 6«110, 7«111.

Коэффициенты многочленов в двоичной записи расположены в порядке убывания, так что коэффициент при слагаемом высшего порядка расположен слева.

Например, если степень полинома n =15, то из соответствующей строки выписываем кодированные значения 23, 37, 7, 31. Перепишем в восьмеричном коде (010011)(011111)(111)(011001). Разложение полинома 15-й степени с учетом (x+1) примет вид (x15+1)=(x+1)(x4+x+1)(x4+x3+x2+x+1)(x2+x+1)(x4+x3+1).


 

Таблица 5.2

Степень полинома Неприводимые сомножители Старшая степень сомножителя
     
     
     
  13, 17 3, 3
  111, 7 6, 2
  3, 37 1, 4
  3, 13, 13, 15, 15 1, 3, 3, 3, 3
  23, 37, 7, 31 4, 4, 2, 4
  727, 471 8, 8
  127, 15, 165, 7, 13 6, 3, 6, 2, 3
  5343, 6165 11, 11
  4102041, 37 20, 4
  1001001, 111, 7 18, 6, 2
  45, 75, 67, 57, 73, 51 5, 5, 5, 5, 5, 5
  3043, 3777, 2251, 7 10, 10, 10, 2
  16475, 13627, 13, 37, 15 12, 12, 3, 4, 3
  13617, 17777, 17075, 7 12, 12, 12, 2
  6647133, 5747175 20, 20
  52225, 47771, 64213 14, 14, 14
  10011, 23, 111, 11001, 37, 7, 31 12, 4, 6, 12, 4, 2, 4
  43073357, 75667061 23, 23
  10040001, 10000201, 13, 15 21, 21, 3, 3
  763, 727, 433, 471 8, 8, 8, 8

 


Дата добавления: 2015-10-21; просмотров: 53 | Нарушение авторских прав


Читайте в этой же книге: Принцип действия канала с амплитудной манипуляцией | Принцип действия канала с частотной манипуляцией | Принцип действия канала с относительной фазовой модуляцией | Простой, безызбыточный код | Коды по законам комбинаторики | ПОМЕХОУСТОЙЧИВЫЕ КОДЫ | Коды для обнаружения одиночных ошибок | Определение групповых кодов | Проверочная матрица | Условия обнаружения и исправления ошибок |
<== предыдущая страница | следующая страница ==>
Построение циклических кодов| Линейные переключательные схемы

mybiblioteka.su - 2015-2024 год. (0.011 сек.)