WikiDer > Сложенный код Рида – Соломона
В теория кодирования, свернутые коды Рида – Соломона похожи Коды Рида – Соломона, которые получаются отображением Кодовые слова Рида – Соломона над большим алфавитом путем тщательного объединения символов кодовых слов.
Свернутые коды Рида – Соломона также являются частным случаем Коды Парвареша – Варди.
Используя оптимальные параметры, можно декодировать с помощью ставка из р, и достичь радиуса декодирования 1 -р.
Термин «свернутые коды Рида – Соломона» был введен в обращение В.Я. Крачковского с алгоритмом, который представил коды Рида – Соломона с множеством случайных "фазированных пакетов" ошибок. [1]. Алгоритм декодирования списком для свернутых кодов RS исправляет за пределы для кодов Рида – Соломона, достигаемая Гурусвами–Судан алгоритм для таких фазированных пакетных ошибок.
История
Одна из текущих проблем в теории кодирования состоит в том, чтобы коды с исправлением ошибок обеспечивали оптимальный компромисс между скоростью (кодирования) и радиусом исправления ошибок. Хотя это может оказаться невозможным практически (из-за проблем теории кодирования каналов с шумом), квазиоптимальные компромиссы могут быть достигнуты теоретически.
До разработки свернутых кодов Рида-Соломона наилучший радиус коррекции ошибок был достигнут , к Коды Рида – Соломона по всем тарифам .
Улучшение этого предел был достигнут Парвареш и Варди для ставок
За алгоритм Парвареша – Варди может декодировать дробь ошибок.
Свернутые коды Рида – Соломона улучшают эти предыдущие конструкции и могут быть декодированы по списку за полиномиальное время для некоторой доли ошибок для любой постоянной .
Определение
Рассмотрим Рида – Соломона. код длины и измерение и параметр сворачивания . Предположить, что разделяет .
Отображение кодов Рида – Соломона выглядит следующим образом:
куда это примитивный элемент в
- .
В свернутый вариант кода Рида-Соломона , обозначенный это код длины блока над . просто Коды Рида-Соломона с последовательные символы из кодовых слов RS, сгруппированные вместе.
Графическое описание
Приведенное выше определение становится более ясным с помощью диаграммы с , куда - параметр сворачивания.
Сообщение обозначается , который при кодировании с использованием кодирования Рида – Соломона состоит из значений в , куда .
Затем объединение выполняется в группы по 3 элемента, чтобы получить кодовое слово длины по алфавиту .
Здесь следует отметить, что продемонстрированная операция складывания не изменяет скорость исходного кода Рида – Соломона.
Чтобы доказать это, рассмотрим линейный код длины , измерение и расстояние . В операция складывания сделает его код. Тем самым ставка будет то же самое.
Свернутые коды Рида – Соломона и одноэлементная граница
Согласно асимптотической версии одноэлементная граница, известно, что относительное расстояние , кода должен удовлетворять куда это скорость кода. Как было показано ранее, поскольку ставка сохраняется относительное расстояние также соответствует границе Синглтона.
Почему складывание может помочь?
Свернутые коды Рида – Соломона в основном такие же, как коды Рида-Соломона, только просматриваются через более крупный алфавит. Чтобы показать, как это может помочь, рассмотрим свернутый код Рида – Соломона с . Декодирование кода Рида – Соломона и свернутого кода Рида – Соломона с одинаковой долей ошибок - задачи почти одинаковой вычислительной мощности: развернуться полученное слово свернутого кода Рида-Соломона, рассматривать его как полученное слово исходного кода Рида-Соломона и запускать алгоритм декодирования списка Рида-Соломона на нем. Очевидно, этот список будет содержать все свернутые кодовые слова Рида – Соломона на расстоянии полученного слова, а также некоторые дополнения, которые мы можем удалить.
Кроме того, более простой задачей является декодирование свернутого кода Рида – Соломона. Допустим, мы хотим исправить треть ошибок. Выбранный алгоритм декодирования должен исправить шаблон ошибки, который исправляет каждый третий символ в кодировке Рида-Соломона. Но после сворачивания этот шаблон ошибки приведет к повреждению всех символов на и устранит необходимость исправления ошибок. Это распространение ошибок обозначено синим цветом в графическом описании. Это доказывает, что при фиксированной доле ошибок операция сворачивания снижает гибкость канала для распределения ошибок, что, в свою очередь, ведет к уменьшению количества шаблонов ошибок, которые необходимо исправить.
Мы можем связать свернутые коды Рида-Соломона с Парвареш Варди коды, которые кодируют многочлен степени с многочленами куда куда является неприводимый многочлен. Выбирая неприводимый многочлен и параметр мы должны проверить, каждый ли многочлен степени не более удовлетворяет поскольку это просто сдвинутый аналог куда это примитивный элемент в Свернутый таким образом код RS с объединением кодовых символов является кодом заказа PV. за набор оценочных баллов
- .
Если мы сравним свернутый код RS с кодом PV порядка 2 для набора точек оценки
мы можем видеть, что в кодировке PV , для каждого и каждый появляется на и ,
в отличие от свернутой кодировки FRS, в которой он появляется только один раз. Таким образом, коды PV и свернутые коды RS имеют одинаковую информацию, но только скорость FRS больше в раз. и, следовательно, расшифровка списка Радиус компромисса лучше для свернутого кода RS, просто используя декодируемость списка кодов PV. Плюс заключается в выборе кода FRS таким образом, чтобы они представляли собой сжатые формы подходящего PV-кода с аналогичной эффективностью исправления ошибок с лучшей скоростью, чем соответствующий PV-код. Эту идею можно использовать для построения свернутых кодов RS скорости которые могут быть декодированы списком до радиуса приблизительно за . [2]
Краткий обзор свернутых кодов Рида – Соломона со списком декодирования
А расшифровка списка алгоритм, который выполняется за квадратичное время для декодирования кода FRS до радиуса представлен Гурусвами. По сути, алгоритм состоит из трех этапов, а именно этапа интерполяции, на котором используется интерполяция в стиле Уэлча-Берлекампа для интерполяции ненулевого многочлена.
после чего все многочлены со степенью удовлетворяющие уравнению, полученному при интерполяции. На третьем шаге известен фактический список ближайших кодовых слов путем сокращения подпространства решения, которое принимает время.
Алгоритм декодирования линейно-алгебраического списка
Гурусвами представляет алгоритм декодирования временного списка на основе линейной алгебры, который может декодировать свернутый код Рида-Соломона до радиуса с размером списка . В этом алгоритме есть три шага: шаг интерполяции, шаг поиска корня и шаг сокращения. На шаге интерполяции он попытается найти полином сообщения кандидата путем решения линейной системы. На этапе поиска корня он попытается найти подпространство решения, решая другую линейную систему. Последний шаг попытается сократить подпространство решения, полученное на втором шаге. Далее мы подробно расскажем о каждом шаге.
Шаг 1: Шаг интерполяции
Это В стиле Уэлча – Берлекампа интерполяция (поскольку ее можно рассматривать как многомерное обобщение алгоритма Велча – Берлекампа). Допустим, мы получили кодовое слово из свернутый код Рида – Соломона, как показано ниже
Интерполируем ненулевой многочлен
используя тщательно подобранный параметр степени .
Таким образом, требования к интерполяции будут
Тогда количество одночленов в является
Поскольку количество одночленов в больше, чем количество условий интерполяции. У нас есть лемма ниже
- Лемма 1. удовлетворяющее вышеуказанному условию интерполяции, можно найти, решив однородную линейную систему над максимум с ограничения и переменные. Более того, эту интерполяцию можно выполнить в операции над .[1]
Эта лемма показывает нам, что шаг интерполяции может быть выполнен за почти линейное время.
А пока мы поговорили обо всем, что нам нужно для многомерного полинома . Оставшаяся задача - сосредоточиться на полиномах сообщений. .
- Лемма 2. Если кандидат полином сообщения является многочленом степени не выше чья сложенная кодировка Рида-Соломона совпадает с полученным словом по крайней мере столбцы с
- тогда [2]
Здесь «согласен» означает, что все значения в столбце должны соответствовать соответствующим значениям в кодовом слове .
Эта лемма показывает нам, что любой такой многочлен представляет собой алгебраическое условие, которое должно выполняться для этих многочленов сообщений что нас интересует расшифровка списка.
Объединяя лемму 2 и параметр , у нас есть
Далее мы можем получить границу декодирования
Заметим, что дробное согласие
Шаг 2: поиск корней
На этом этапе наша задача сосредоточена на том, как найти все многочлены со степенью не выше и удовлетворяют уравнению, полученному на шаге 1, а именно
Поскольку приведенное выше уравнение образует линейную систему уравнений над в коэффициентах полинома
решения вышеуказанного уравнения - это аффинное подпространство из . Этот факт является ключевым моментом, который дает начало эффективному алгоритму - мы можем решить линейную систему.
Естественно спросить, насколько велика размерность решения? Есть ли верхняя граница размера? Наличие верхней границы очень важно при построении эффективного алгоритма декодирования списка, поскольку можно просто вывести все кодовые слова для любой данной проблемы декодирования.
На самом деле он действительно имеет верхнюю границу, как утверждает лемма ниже.
- Лемма 3. Если порядок по крайней мере (в частности, когда примитивно), то размерность решения не превосходит .[3]
Эта лемма показывает нам верхнюю границу размерности пространства решений.
Наконец, основываясь на приведенном выше анализе, мы имеем следующую теорему
- Теорема 1. Для свернутого кода Рида – Соломона длины блока и оценить для всех целых чисел верно следующее . Учитывая полученное слово , в время можно найти базис для подпространства размерности не более который содержит все полиномы сообщений степени меньше чем чья кодировка FRS отличается от самое большее в доле
- из позиции кодового слова.
Когда , мы замечаем, что это сводится к уникальному алгоритму декодирования с точностью до дробной части ошибок. Другими словами, мы можем рассматривать уникальный алгоритм декодирования как особенность алгоритма декодирования списка. Количество около для выбора параметров, которые достигают радиуса декодирования списка .
Теорема 1 точно говорит нам, насколько большим будет радиус ошибки.
Наконец-то мы получили подпространство решений. Однако остается еще одна проблема. Размер списка в худшем случае . Но фактический список ближайших кодовых слов - это лишь небольшой набор в этом подпространстве. Итак, нам нужен какой-то процесс, чтобы обрезать подпространство, чтобы сузить его. Этот процесс обрезки занимает время в худшем случае. К сожалению, не известно, как улучшить время выполнения, потому что мы не знаем, как улучшить границу размера списка для свернутого кода Рида-Соломона.
Все станет лучше, если мы изменим код, тщательно выбрав подмножество всех возможных степеней полиномы в виде сообщений, размер списка оказывается намного меньше, но лишь немного теряет в скорости. Мы кратко поговорим об этом на следующем шаге.
Шаг 3: этап обрезки
Путем преобразования проблемы декодирования свернутого кода Рида – Соломона в две линейные системы, одну линейную систему, которая используется для этапа интерполяции, и другую линейную систему, чтобы найти подпространство кандидата решения, сложность проблемы декодирования успешно снижается до квадратичной. Однако в худшем случае граница размера списка вывода очень плохая.
На шаге 2 было упомянуто, что если тщательно выбрать только подмножество всех возможных степеней полиномы как сообщения, размер списка может быть значительно уменьшен. Здесь мы расширим наше обсуждение.
Для достижения этой цели идея состоит в том, чтобы ограничить вектор коэффициентов к особому подмножеству , который удовлетворяет следующим двум условиям:
- Условие 1. Набор должен быть достаточно большим ().
Это необходимо для обеспечения того, чтобы ставка была снижена не более чем в раз .
- Условие 2. Набор должен иметь низкое пересечение с любым подпространством измерения удовлетворение и Такое подмножество называется подмножеством, уклоняющимся от подпространства.
Граница размера списка в худшем случае , и его можно свести к относительной малой оценке с помощью подпространственных подмножеств.
На этом шаге, поскольку он должен проверить каждый элемент подпространства решения, которое мы получаем на шаге 2, он принимает время в худшем случае ( - размерность подпространства решений).
Двир и Ловетт улучшили результат на основе работы Гурусвами, который может уменьшить размер списка до постоянного.
Здесь представлена только идея, которая используется для сокращения подпространства решения. Для получения подробной информации о процессе обрезки, пожалуйста, обратитесь к статьям Гурусвами, Двира и Ловетта, которые перечислены в ссылке.
Резюме
Если мы не рассматриваем шаг 3, этот алгоритм может работать в квадратичном времени. Краткое описание этого алгоритма приведено ниже.
Шаги |
|
---|---|
Время выполнения | |
Радиус ошибки | |
Размер списка |
Смотрите также
Рекомендации
- Атри РудраКонспект лекции: Свернутые коды Рида – Соломона
- Конспекты Атри Рудры: Границы
- Бумага Атри Рудра и Венкатесан Гурусвами: Расшифровка свернутых кодов Рида – Соломона
- Глава о декодировании списком свернутых кодов Рида – Соломона: Списочное декодирование свернутых кодов Рида – Соломона
- Примечания к лекции Венкатесана Гурусвами: Элементарные границы кодов
- Примечания к лекции Венкатесана Гурусвами: Список декодирования свернутого кода Рида – Соломона
- Гурусвами, Венкатесан (2011). "Линейно-алгебраическое списочное декодирование свернутых кодов Рида – Соломона". 2011 26-я Ежегодная конференция IEEE по вычислительной сложности: 77–85. arXiv:1106.0436. Bibcode:2011arXiv1106.0436G. Дои:10.1109 / CCC.2011.22. ISBN 978-1-4577-0179-5.
- Двирл, Зеев; Ловетт, Шахар (2011). «Подпространственные уклоняющиеся множества». arXiv:1110.5696 [cs.CC].
- Докторская диссертация Кристиан Брандер: Интерполяция и расшифровка списков алгебраических кодов
- Крачковский В.Ю. (2003). «Коды Рида – Соломона для исправления фазированных пакетов ошибок». IEEE Trans. Инф. Теория. 49 (11): 2975–2984. Дои:10.1109 / TIT.2003.819333.