Математика циклических проверок избыточности - Mathematics of cyclic redundancy checks

В циклическая проверка избыточности (CRC) основан на деление в кольцо многочленов над конечное поле GF (2) (целые числа по модулю 2 ), т. е. множество многочлены где каждый коэффициент либо ноль, либо единица, и арифметические операции обернуть.

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

Математика

В общем, вычисление CRC соответствует Евклидово деление многочленов над GF (2):

Вот является полиномом исходного сообщения и степень- образующий полином. Кусочки исходное сообщение с нули добавлены в конце. Контрольная сумма CRC формируется коэффициентами полинома остатка чья степень строго меньше, чем . Фактор-полином не представляет интереса. С помощью операция по модулю, можно сказать, что

При общении отправитель прикрепляет биты R после битов исходного сообщения M, которые могут быть показаны как эквивалентные отправке кодовое слово.) Получатель, зная и поэтому , отделяет M от R и повторяет вычисление, проверяя, что полученное и вычисленное R равны. Если да, то получатель предполагает, что биты принятого сообщения верны.

На практике вычисления CRC больше всего напоминают длинное деление в двоичном, за исключением того, что участвующие вычитания не заимствуют из более значащих цифр и, таким образом, становятся Эксклюзивный или операции.

CRC - это контрольная сумма в строгом математическом смысле, так как это может быть выражено как взвешенная по модулю 2 сумма на бит синдромы, но это слово обычно зарезервировано более конкретно для сумм, вычисляемых с использованием больших модулей, таких как 10, 256 или 65535.

CRC также могут использоваться как часть коды с исправлением ошибок, которые позволяют не только обнаруживать ошибки передачи, но и восстанавливать правильное сообщение. Эти коды основаны на тесно связанных математических принципах.

Полиномиальная арифметика по модулю 2

Поскольку коэффициенты ограничены одним битом, любая математическая операция над полиномами CRC должна отображать коэффициенты результата либо в ноль, либо в единицу. Например, дополнительно:

Обратите внимание, что эквивалентно нулю в приведенном выше уравнении, поскольку сложение коэффициентов выполняется по модулю 2:

Сложение полиномов по модулю 2 такое же, как побитовое XOR. Поскольку XOR является обратным самому себе, полиномиальное вычитание по модулю 2 совпадает с побитовым XOR.

Умножение аналогично (a продукт без переноски ):

Мы также можем разделить многочлены по модулю 2 и найти частное и остаток. Например, предположим, что мы делим от . Мы бы обнаружили, что

Другими словами,

Деление дает частное от Икс2 + 1 с остатком −1, который, поскольку он нечетный, имеет последний бит 1.

В приведенных выше уравнениях представляет биты исходного сообщения 111, - порождающий полином, а остаток (эквивалентно, ) - это CRC. Степень порождающего полинома равна 1, поэтому мы сначала умножили сообщение на получить .

Вариации

Существует несколько стандартных вариантов CRC, любой или все из которых могут использоваться с любым полиномом CRC. Варианты реализации такие как порядок байтов и представление CRC влияет только на отображение битовых строк на коэффициенты и , и не влияют на свойства алгоритма.

  • Чтобы проверить CRC, вместо вычисления CRC для сообщения и сравнения его с CRC, вычисление CRC может выполняться для всего кодового слова. Если результат (называемый остатком) равен нулю, проверка проходит. Это работает, потому что кодовое слово , который всегда делится на .
Это упрощает многие реализации, избегая необходимости обрабатывать последние несколько байтов сообщения специально при проверке CRC.
  • Регистр сдвига может быть инициализирован единицами вместо нулей. Это эквивалентно инвертированию первого биты сообщения перед подачей их в алгоритм. Уравнение CRC становится , где - длина сообщения в битах. Изменение, которое это налагает на является функцией производящего полинома и длины сообщения, .
Причина использования этого метода заключается в том, что немодифицированный CRC не различает два сообщения, которые отличаются только количеством начальных нулей, поскольку начальные нули не влияют на значение . Когда эта инверсия выполняется, CRC действительно различает такие сообщения.
  • CRC может быть инвертирован перед добавлением к потоку сообщений. В то время как немодифицированный CRC различает сообщения при разном количестве завершающих нулей он не обнаруживает конечных нулей, добавленных после самого остатка CRC. Это потому, что все допустимые кодовые слова кратны , так раз это кодовое слово также является кратным. (Собственно, именно поэтому работает первый вариант, описанный выше.)

На практике два последних варианта неизменно используются вместе. Они изменяют передаваемый CRC, поэтому должны быть реализованы как на передатчике, так и на приемнике. В то время как предварительная установка сдвигового регистра на единицу проста на обоих концах, инвертирование влияет на приемники, реализующие первый вариант, потому что CRC полного кодового слова, которое уже включает CRC, больше не равно нулю. Вместо этого это фиксированный ненулевой шаблон, CRC шаблона инверсии ед.

Таким образом, CRC можно проверить либо очевидным методом вычисления CRC в сообщении, его инвертирования и сравнения с CRC в потоке сообщений, либо путем вычисления CRC для всего кодового слова и сравнения его с ожидаемым фиксированным значением. , называемый контрольным полиномом, вычетом или магическое число. Это можно вычислить как или, что то же самое, вычислением немодифицированного CRC сообщения, состоящего из те, .

Эти обращения чрезвычайно распространены, но выполняются не повсеместно, даже в случае полиномов CRC-32 или CRC-16-CCITT.

Обратные представления и обратные многочлены

Полиномиальные представления

Пример 16-разрядного многочлена CCITT в описанных формах (биты внутри квадратных скобок включены в представление слова; биты снаружи подразумеваются как 1 бит; вертикальные полосы обозначают грызть границы):

16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 коэффициент 1 [0 0 0 1 | 0 0 0 0 | 0 0 1 0 | 0 0 0 1] Нормальный [1 | 0 | 2 | 1] Нормальные полубайты 0x1021 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 [1 0 0 0 | 0 1 0 0 | 0 0 0 0 | 1 0 0 0] 1 Обратное [8 | 4 | 0 | 8] Полубайты обратного направления 0x840816 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 1 [0 0 0 0 | 1 0 0 0 | 0 0 0 1 | 0 0 0 1] Взаимное [0 | 8 | 1 | 1] Полубайты взаимности 0x0811 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 Обратные взаимные 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 Купман [1 0 0 0 | 1 0 0 0 | 0 0 0 1 | 0 0 0 0] 1 [8 | 8 | 1 | 0] Полубайты 0x8810

Все известные полиномы генератора CRC степени имеют два общих шестнадцатеричных представления. В обоих случаях коэффициент опускается и понимается как 1.

  • Представление msbit-first - это шестнадцатеричное число с биты, младший бит из которых всегда равен 1. Самый старший бит представляет собой коэффициент а младший бит представляет собой коэффициент .
  • Представление lsbit-first - это шестнадцатеричное число с биты, самый старший бит из которых всегда равен 1. Самый старший бит представляет коэффициент а младший бит представляет собой коэффициент .

Форма msbit-first часто упоминается в литературе как нормальный представление, в то время как lsbit-first называется перевернутый представление. При реализации CRC важно использовать правильную форму. Если коэффициент оказывается равным нулю, формы можно определить с первого взгляда, посмотрев, на каком конце установлен бит.

Чтобы еще больше запутать ситуацию, статья П. Купмана и Т. Чакраварти [1][2] преобразует полиномы генератора CRC в шестнадцатеричные числа еще одним способом: msbit-first, но включая коэффициент и без учета коэффициент. Это представление «Купмана» имеет то преимущество, что степень может быть определена в шестнадцатеричной форме, а коэффициенты легко считываются в порядке слева направо. Однако он больше нигде не используется и не рекомендуется из-за риска возникновения путаницы.

Взаимные полиномы

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

Наиболее интересным свойством обратных многочленов, когда они используются в CRC, является то, что они имеют точно такую ​​же способность обнаруживать ошибки, что и многочлены, которым они являются обратными. Обратная величина полинома порождает то же кодовые слова, только бит обратный - то есть, если все, кроме первого биты кодового слова под исходным многочленом берутся, меняются местами и используются в качестве нового сообщения, CRC этого сообщения под обратным многочленом равняется обратному первому биты исходного кодового слова. Но обратный многочлен не совпадает с исходным многочленом, и CRC, сгенерированные с его помощью, не такие же (даже по модулю обращения битов), как те, которые сгенерированы исходным многочленом.

Сила обнаружения ошибок

Способность CRC обнаруживать ошибки зависит от степени ключевого полинома и от конкретного используемого ключевого полинома. «Полином ошибок» - симметричная разность кодового слова принятого сообщения и правильного кодового слова сообщения. Ошибка не будет обнаружена алгоритмом CRC тогда и только тогда, когда полином ошибки делится на полином CRC.

  • Поскольку CRC основан на делении, ни один полином не может обнаружить ошибки, состоящие из строки нулей, добавленных к данным, или отсутствующих начальных нулей. Однако см. Вариации.
  • Все одиночные битовые ошибки будут обнаружены любым полиномом, содержащим как минимум два члена с ненулевыми коэффициентами. Полином ошибки равен , и делится только на многочлены где .
  • Все две битовые ошибки, разделенные расстоянием меньше, чем порядок из примитивный полином, который является множителем порождающего полинома будет обнаружен. Полином ошибки в двухбитном случае равен . Как отмечалось выше, член не будет делиться на полином CRC, который оставляет срок. По определению, наименьшее значение такой, что многочлен делит порядок полинома или экспонента. Многочлены с наибольшим порядком называются примитивные полиномы, а для многочленов степени с двоичными коэффициентами имеют порядок .
  • Все ошибки в нечетном количестве битов будут обнаружены полиномом, который кратен . Это эквивалентно многочлену, имеющему четное число членов с ненулевыми коэффициентами. Эта емкость предполагает, что порождающий полином является произведением и примитивный многочлен степени поскольку все примитивные многочлены, кроме имеют нечетное количество ненулевых коэффициентов.
  • Все пакетные ошибки длины будет обнаруживаться любым полиномом степени или больше, имеющее ненулевое значение срок.

(Кстати, никогда не стоит использовать полином с нулевым срок. Напомним, что CRC - это остаток полиномиального времени сообщения. делится на полином CRC. Полином с нулем термин всегда имеет как фактор. Так что если является исходным полиномом CRC и , тогда

То есть CRC любого сообщения с многочлен такой же, как и в том же сообщении с многочлен с добавленным нулем. Это пустая трата времени.)

Комбинация этих факторов означает, что хорошие полиномы CRC часто являются примитивными полиномами (которые имеют лучшее обнаружение 2-битных ошибок) или примитивными полиномами степени , умножается на (который обнаруживает все нечетные числа битовых ошибок и имеет вдвое меньшую способность обнаружения двухбитовых ошибок примитивного полинома степени ).[1]

Битовые фильтры

Методика анализа с использованием битовых фильтров[1] позволяет очень эффективно определять свойства заданного порождающего полинома. Результаты следующие:

  1. Все пакетные ошибки (кроме одной) с длиной не больше, чем полином генератора, могут быть обнаружены любым полиномом генератора. . Это включает в себя 1-битные ошибки (пакет длиной 1). Максимальная длина составляет , когда является степенью порождающего полинома (длина которого ). Исключением из этого результата является битовая комбинация, такая же, как у генераторного полинома.
  2. Все нечетные битовые ошибки обнаруживаются генератором полиномов с четным числом членов.
  3. 2-битные ошибки на (кратном) расстоянии от самого длинного битового фильтра четной четности до полинома генератора не обнаруживаются; все остальные обнаружены. Для степеней до 32 существует оптимальный порождающий полином с этой степенью и четным числом членов; в этом случае указанный выше период . Для это означает, что блоки длиной 32 767 битов не содержат неоткрытых 2-битных ошибок. Для нечетного числа членов в образующем полиноме может быть период ; однако эти порождающие полиномы (с нечетным числом членов) не обнаруживают все нечетное количество ошибок, поэтому их следует избегать. Список соответствующих генераторов с четным числом терминов можно найти по ссылке, указанной в начале этого раздела.
  4. Все одиночные битовые ошибки в пределах периода битового фильтра, упомянутого выше (для четных членов в полиноме генератора), могут быть однозначно идентифицированы по их невязке. Таким образом, метод CRC может использоваться и для исправления однобитовых ошибок (в этих пределах, например, 32 767 бит с оптимальными полиномами генератора степени 16). Поскольку все нечетные ошибки оставляют нечетный остаток, все четные, четные остатки, 1-битные ошибки и 2-битные ошибки могут быть различены. Однако, как и другие ОТДЕЛЕННЫЙ методы CRC не всегда могут отличить 1-битные ошибки от 3-битных. Когда в блоке возникают 3 или более битовых ошибок, исправление битовых ошибок CRC само будет ошибочным и приведет к большему количеству ошибок.

Смотрите также

использованная литература

  1. ^ а б c Купман, Филипп (июль 2002 г.). 32-битные циклические коды избыточности для интернет-приложений (PDF). Международная конференция по надежным системам и сетям. С. 459–468. CiteSeerX  10.1.1.11.8323. Дои:10.1109 / DSN.2002.1028931. ISBN  978-0-7695-1597-7. Получено 14 января 2011. - проверка результатов Кастаньоли исчерпывающим перебором и некоторыми новыми хорошими полиномами
  2. ^ Купман, Филипп; Чакраварти, Тридиб (июнь 2004 г.). Выбор полинома циклического избыточного кода (CRC) для встроенных сетей (PDF). Международная конференция по надежным системам и сетям. С. 145–154. CiteSeerX  10.1.1.648.9080. Дои:10.1109 / DSN.2004.1311885. ISBN  978-0-7695-2052-0. Получено 14 января 2011. - анализ коротких полиномов CRC для встроенных приложений

внешние ссылки