Jump to content

Система нумерации остатков

(Перенаправлено из системы счисления остатка )

Система счисления с вычетом ( RNS ) — это система счисления, представляющая целые числа по их значениям по модулю нескольких попарно взаимно простых целых чисел, называемых модулями. Это представление допускается китайской теоремой об остатках , которая утверждает, что, если M является произведением модулей, в интервале длины M существует ровно одно целое число, имеющее любой заданный набор модульных значений. Использование системы счисления вычета для арифметических операций также называется мультимодульной арифметикой .

Мультимодульная арифметика широко используется для вычислений с большими целыми числами, обычно в линейной алгебре , поскольку она обеспечивает более быстрые вычисления, чем с обычными системами счисления, даже если принять во внимание время преобразования между системами счисления. Другие применения мультимодульной арифметики включают определение наибольшего общего делителя полинома , вычисление базиса Грёбнера и криптографию .

Определение

[ редактировать ]

Система счисления остатка определяется набором из k целых чисел

называемые модулями , которые обычно считаются попарно взаимно простыми (т. е. любые два из них имеют наибольший общий делитель, равный единице). Системы счисления остатков были определены для невзаимопростых модулей, но обычно не используются из-за худших свойств. Поэтому в оставшейся части статьи они рассматриваться не будут. [1]

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

при евклидовом делении по модулям. То есть

и

для каждого я

Пусть М — произведение всех . Два целых числа, разность которых кратна M, имеют одинаковое представление в системе счисления остатка, определяемой m i s . Точнее, китайская теорема об остатках что каждый из M различных наборов возможных остатков представляет ровно один класс вычетов по модулю M. утверждает , То есть каждый набор остатков представляет ровно одно целое число. в интервале . Для чисел со знаком динамический диапазон равен (когда четно, обычно отображается дополнительное отрицательное значение). [2]

Арифметические операции

[ редактировать ]

Для сложения, вычитания и умножения чисел, представленных в остаточной системе счисления, достаточно выполнить одну и ту же модульную операцию над каждой парой остатков. Точнее, если

список модулей, сумма целых чисел x и y , соответственно представленных остатками и целое число z, представленное такой, что

для i = 1, ..., k (как обычно, mod обозначает операцию по модулю , состоящую в взятии остатка евклидова деления правым операндом). Аналогично определяются вычитание и умножение.

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

Однако такие операции, как сравнение величин, вычисление знака, обнаружение переполнения, масштабирование и деление, трудно выполнить в системе остаточных чисел. [3]

Сравнение

[ редактировать ]

Если два целых числа равны, то все их остатки равны. И наоборот, если все остатки равны, то два целых числа равны или их разность кратна M . Отсюда следует, что проверить равенство легко.

Напротив, проверка неравенств ( x < y ) сложна и обычно требует преобразования целых чисел к стандартному представлению. Как следствие, такое представление чисел не подходит для алгоритмов, использующих тесты на неравенства, таких как деление Евклида и алгоритм Евклида .

Разделение

[ редактировать ]

Деление в остаточных системах счисления проблематично. С другой стороны, если является взаимно простым с (то есть ) затем

можно легко вычислить по

где является мультипликативным обратным модуль , и является мультипликативным обратным модуль .

Приложения

[ редактировать ]

RNS имеют применение в области цифровой компьютерной арифметики . Разложив при этом большое целое число на набор меньших целых чисел, можно выполнить большое вычисление как серию меньших вычислений, которые можно выполнять независимо и параллельно.

См. также

[ редактировать ]
  1. ^ Пархами, Бехруз (2010). Компьютерная арифметика: алгоритмы и конструкции аппаратного обеспечения (2-е изд.). Нью-Йорк, США: Издательство Оксфордского университета . ISBN  978-0-19-532848-6 . Архивировано из оригинала 04 августа 2020 г. Проверено 23 января 2021 г. (xxv+641 страница)
  2. ^ Хунг, CY; Пархами, Б. (1 февраля 1994 г.). «Приблизительный метод определения знаков остатков и его применение для разделения RNS» (PDF) . Компьютеры и математика с приложениями . 27 (4): 23–35. дои : 10.1016/0898-1221(94)90052-3 .
  3. ^ Исупов, Константин (07.04.2020) [20.03.2020, 08.03.2020, 17.02.2020]. «Использование интервалов с плавающей запятой для немодульных вычислений в системе счисления остатков» . Доступ IEEE . 8 : 58603–58619. Бибкод : 2020IEEA...858603I . дои : 10.1109/ACCESS.2020.2982365 . ISSN   2169-3536 .

Дальнейшее чтение

[ редактировать ]
Arc.Ask3.Ru: конец переведенного документа.
Arc.Ask3.Ru
Номер скриншота №: d0e996160acc8be5d03159cff1c99e8c__1720513680
URL1:https://arc.ask3.ru/arc/aa/d0/8c/d0e996160acc8be5d03159cff1c99e8c.html
Заголовок, (Title) документа по адресу, URL1:
Residue number system - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть. Любые претензии, иски не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, вы не можете использовать данный сайт и информация размещенную на нем (сайте/странице), немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, Денежную единицу (имеющую самостоятельную стоимость) можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)