КАТЕГОРИИ: Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748) |
Вибір перешкодостійкого коду і розробка пристроїв захисту від помилок
У каналах з перешкодами ефективним засобом підвищення врогідності передачі повідомлень є перешкодостійке кодування. Воно засноване на застосуванні спеціальних кодів, які коректують помилки, викликані дією перешкод. Код називається коректуючим, якщо він дозволяє виявляти або виявляти і виправляти помилки при прийомі повідомлень. Для того, щоб код володів коректуючими здібностями, в кодовій послідовності повинні міститися додаткові (надмірні) символи, призначені для коректування помилок. Коректуюча здатність коду залежить від кодової відстані d, яка чисельно дорівнює мінімальному числу елементів, якими відрізняється кодова комбінація від будь-якої іншої. У загальному випадку:
де t0 та ti - число виявлених і виправлених помилок відповідно. Якщо код тільки виявляє помилки, то
а у випадку тільки виправлення
Основними характеристиками коду (крім кодової відстані) є його потужність і коефіцієнт надмірності. Потужність коду Np – число комбінацій (кодових слів) із загального числа 2n, використовуваних в даному коді для передачі повідомлень (такі комбінації називають робочими)
Комбінації, що не входять до числа робочих, використовуються для перевірки правильності приходу закодованої комбінації: якщо прийнята комбінація не належить до робочих, то це означає, що в процесі передачі відбулася помилка. Кількість перевірочних елементів k коректуючого кода залежить від виду кода. Коефіцієнтом надлишковост кода називають відношення
Чим більше надмірність коду, тим вище його коректуюча здатність. Код, за допомогою якого тільки виявляються помилки, носить назву виявляючого коду. Виправлення помилки при такому кодуванні зазвичай проводиться шляхом повторення спотворених повідомлень. Запит про повторення передається по каналу зворотного зв'язку. Код, який виправляє виявлені помилки, називається виправляючим кодом. В цьому випадку фіксується не тільки сам факт наявності помилок, але і встановлюється, які кодові символи прийняті помилково, що дозволяє їх виправити без повторної передачі. Відомі також коди, в яких виправляється тільки частина виявлених помилок, а решта помилкових комбінацій передається повторно. В курсовому проекті пропонується використовувати один з наступних видів перешкодостійких кодів: - код з контролем парності; - код з повторенням і інверсією; - ітеративний код; - код Хеммінга; - циклічний код. При побудові коду із контролем парності в кожній комбінації двійкового коду вводиться додатковий розряд, щодоповнює кількість одиниць в комбінації до парного числа. Потужність такого коду Np = 2 n-1, коефіцієнт надлишковості kн = 1/n. Приймальний пристрій в цьому випадку бракує всі комбінації, які містять непарне число одиниць, що дозволяє виявляти всі помилки непарної кратності. Підрахунок числа одиниць в кодовій комбінації доцільно виконувати підсумовуванням по модулю 2 її елементів, або за допомогою спеціальних елементів контролю парності [4, 7, 9]. Аналогічно будується код із захистом по непарності. Код з повторенням і інверсією будується таким чином: кожна комбінація двійкового коду залежно від числа одиниць в ній або просто повторюється, або повторюється з інвертуванням. Потужність такого коду Np = 2 n/2, коефіцієнт надлишковості kн = 0,5. Приймальний пристрій повинен спочатку проаналізувати першу половину кодової комбінації і у разі парного числа одиниць в ній порівняти її з другою половиною, з якою вона повинна співпасти. У разі ж непарного числа одиниць в першій половині вона інвертується і після цього перевіряється на збіг з другою половиною. У загальному випадку код з повторенням і інверсією може використовуватися не тільки для виявлення, але і для виправлення всіх одноразових помилок [7, 9]. Ітеративний код характеризується наявністю двох або більше системи перевірок всередині кожної кодової комбінації [4, 5, 7]. Будується він таким чином (див. рис. 5.1): одна або декілька кодових комбінацій групуються у вигляді матриці || qij || розмірністю i ´ j, де i – число рядків, а j – число стовпців. В кінці кожного рядка додається перевірочний розряд ri, який дорівнює сумі по модулю 2 всіх елементів рядка; крім того вводиться додатковий рядок, елементи якого sj дорівнюють сумі по модулю 2 елементів j-го стовпця (елемент sj+1 дорівнює сумі по модулю 2 перевірочних розрядів ri).
Рис. 5.1 – Формування матриці ітеративного коду При використанні ітеративного коду в курсовому проекті доцільно складати кодову матрицю для кожного опитуваного об'єкту, в цьому випадку в кожному рядку можна помістити кодове слово, що несе інформацію від одного з датчиків. Тоді кількість стовпців буде дорівнювати кількості інформаційних розрядів m, а кількість рядків – кількості датчиків на кожному опитуваному об'єкті. Потужність такого коду Np = (2i)j, кількість перевірочних розрядів – k = i + j + 1. На приймальні стороні перевірка правильності приходу кодової комбінації здійснюється підсумовуванням по модулю 2 елементів кожного рядка і кожного стовпця з урахуванням контрольних розрядів. При правильному прийомі всі суми повинні дорівнювати нулю. Цей код має кодову відстань d = 4 і дозволяє виявляти всі помилки кратності до трьох і непарної кратності. Основним недоліком ітеративного коду являється його відносно висока надмірність. Код Хеммінга – один з найбільш ефективних кодів, що дозвляють виявляти і виправляти одиночні помилки [4-7, 9]. Кодова відстань d=3. Код утворюється шляхом доповнення інформаційної частини передаваного блоку, що складається з m біт, k перевірочними елементами, причому в інформаційну частину при кодуванні можна включати і службові символи (номер, початок і кінець блоку), за винятком маркерних комбінацій, які доцільно розташовувати на початку блоку. При визначенні кількості перевірочних елементів k слід керуватися нерівністю
Оскільки m визначене, то не важко підібрати найменше число k, що задовольняє умові (5.6). Код будується так, щоб в результаті k = n – m перевірок отримати k-розрядне двійкове число, що вказує номер спотвореної позиції кодової комбінації. Для цього перевірочні символи повинні знаходитися на позиціях, номери яких виражаються степенем числа 2 (20, 21, 22, …, 2k-1), оскільки кожен з них входить тільки в одне з перевірочних рівнянь. Таким чином, якщо нумерувати позиції зліва направо, то контрольні символи повинні знаходитися на першій, другій, четвертій, восьмій і так далі позиціях. Перевірочні елементи коду Хеммінга утворюються шляхом підсумовування по модулю 2 певних розрядів безнадмірної кодової комбінації. Результат першої перевірки дає цифру молодшого розряду синдрому помилки в двійковому записі, отже, першою перевіркою повинні бути охоплені символи з номерами, що містять в двійковому записі одиниці в першому розряді (1, 3, 5, 7 і так далі). результат другої перевірки дає цифру другого розряду синдрому помилки, отже, другою перевіркою повинні бути охоплені символи з номерами, що містять в двійковому записі одиниці в другому розряді (2, 3, 6, 7, 10 і так далі). Аналогічно при i-ій перевірці повинні перевірятися символи, номери яких в двійковому записі містять одиниці в i-ому розряді. Таким чином, перевірочні групи повинні мати вигляд:
При декодуванні здійснюється підсумовування по модулю 2 правої і лівої частин кожного рівняння з (5.7). Результат підсумовування покаже синдром помилки. Якщо всі розряди синдрому дорівнюють нулю, то помилок не виявлено, інакше синдром указуватиме номер розряду, в якому відбулася помилка. Циклічні коди знаходять найбільше розповсюдження в системах передачі даних з вирішальним зворотним зв'язком, що обумовлене їх високими коректуючими властивостями, порівняно простою реалізацією, невисокою надлишковістю. Особливо вони ефективні при виявленні пакетів помилок. Циклічні коди відносяться до блоково-систематичних кодів, в яких кожна комбінація кодується самостійно у вигляді блоку таким чином, що інформаційні і перевірочні елементи завжди знаходяться на певних місцях [4-7, 9]. Для спрощення процедури кодування і декодування перевірочні біти розміщують в кінці блоку. Кодування передаваного повідомлення здійснюється множенням двійкової послідовності G(x) на одночлен xk, що має ту ж степінь, що і створюючий поліном P(x), з додаванням до цього добутку залишку R(x), отриманого після ділення добутку G(x)×xk на створюючий поліном, тобто передаване в канал зв'язку повідомлення F(x) має вигляд:
При декодуванні послідовність F(x), що приймається, знову ділиться на створюючий поліном P(x). Отриманий нульовий залишок R(x) = 0 свідчить про відсутність помилок в прийнятому блоці, а відмінність залишку від нуля – про наявність помилок. Аналізуючи залишок можна визначити номери спотворених розрядів і скоректувати їх. Для побудови циклічних кодів в якості створюючих поліномів використовуються многочлени, що не приводяться, тобто многочлени, які без залишку діляться тільки на себе і на одиницю. Поліном P(x) може бути представлений у алгебраїчній формі або у вигляді двійкового або вісімкового числа. У останньому випадку кожна вісімкова цифра відображає три двійкові розряди. Наприклад, для полінома P(x) = x5 + x2 + 1 двійковий запис має вигляд 100101, а відповідний йому вісімковий – 43. У таблиці 5.1 приведені всі многочлени, що не приводяться, до п'ятої степені, а в [2, 4] – вибіркові многочлени, що не приводяться, до дев'ятої степені, а також їх двійкові і вісімкові еквіваленти. При виборі створюючого полінома P(x) слід мати на увазі, що степінь створюючого полінома не може бути менше числа перевірочних елементів k. Для спрощення технічної реалізації кодерів і декодерів необхідно обирати степінь полінома рівну k. Якщо в таблиці є декілька многочленів, що не приводяться, даної степені, то доцільно вибрати найкоротший, причому число ненульових членів P(x) не повинне бути менше необхідної кодової відстані, визначеної по (5.1). До всякого коду обов'язково пред'являється вимога однозначності декодування. У разі блокових кодів це означає, що всякій послідовності або групі послідовностей кодових символів повинна однозначно відповідати послідовність елементів передаваного повідомлення, що завжди виконується при використанні рівномірних кодів.
Таблиця 5.1 – Многочлени, що не приводяться, і їх еквіваленти
Використовувані в даний час способи кодування не дозволяють наблизитися до теоретичної пропускної спроможності реальних каналів зв'язку при достатньо малій ймовірності помилки (високій вірності прийому). Для цього знадобилися б дуже складні, економічно не вигідні схеми кодування і декодування. Проте за допомогою розумно вибраного коду часто вдається значно підвищити швидкість передачі або вірність прийому. Питання реалізації схемотехніки кодерів і декодерів описаних вище перешкодостійких кодів досить детально представлені в [2, 4-7].
Дата добавления: 2015-08-31; Просмотров: 669; Нарушение авторских прав?; Мы поможем в написании вашей работы! Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет |