Алгоритм Берлекампа – Рабина - Berlekamp–Rabin algorithm

В теория чисел, Алгоритм поиска корня Берлекампа, также называемый Алгоритм Берлекампа – Рабина, это вероятностный метод поиск корней из многочлены через поле . Метод был открыт Элвин Берлекамп в 1970 году[1] как вспомогательное средство алгоритм для полиномиальной факторизации над конечными полями. Позднее алгоритм был изменен Рабин для произвольных конечных полей в 1979 г.[2] Этот метод был также независимо открыт до Берлекампа другими исследователями.[3]

История

Метод был предложен Элвин Берлекамп в его работе 1970 года[1] о полиномиальной факторизации над конечными полями. Его оригинальной работе не хватало формального правильность доказательство[2] и позже был уточнен и модифицирован для произвольных конечных полей Майкл Рабин.[2] В 1986 году Рене Перальта предложил похожий алгоритм.[4] для нахождения квадратных корней в .[5] В 2000 г. метод Перальты был обобщен на кубические уравнения.[6]

Постановка проблемы

Позволять нечетное простое число. Рассмотрим многочлен над полем остатков по модулю . Алгоритм должен найти все в такой, что в .[2][7]

Алгоритм

Рандомизация

Позволять . Нахождение всех корней этого многочлена эквивалентно нахождению его разложения на линейные множители. Чтобы найти такую ​​факторизацию, достаточно разбить многочлен на любые два нетривиальных делителя и рекурсивно разложить их на множители. Для этого рассмотрим полином где какой-нибудь элемент . Если можно представить этот многочлен как произведение то в терминах исходного полинома это означает, что , что обеспечивает необходимую факторизацию .[1][7]

Классификация элементы

Из-за Критерий Эйлера, для каждого одночлен выполняется ровно одно из следующих свойств:[1]

  1. Моном равен если ,
  2. Моном делит если является квадратичный вычет по модулю ,
  3. Моном делит если квадратично не остаточно по модулю .

Таким образом, если не делится на , что можно проверить отдельно, то равен произведению наибольшие общие делители и .[7]

Метод Берлекампа

Указанное выше свойство приводит к следующему алгоритму:[1]

  1. Явно вычислите коэффициенты ,
  2. Рассчитать остаток от по модулю возводя в квадрат текущий полином и взяв остаток по модулю ,
  3. С помощью возведение в степень возведением в квадрат а полиномы, вычисленные на предыдущих шагах, вычисляют остаток от по модулю ,
  4. Если тогда упомянутые выше обеспечивают нетривиальную факторизацию ,
  5. В противном случае все корни являются либо остатками, либо не остатками одновременно, и нужно выбрать другой .

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

Модульный квадратный корень

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

  1. GCD невероятно похож на которое значит что и оба квадратичных невычетов,
  2. GCD невероятно похож на что означает, что оба числа являются квадратичными вычетами,
  3. GCD невероятно похож на что означает, что ровно одно из этих чисел является квадратичным вычетом.

В третьем случае НОД равен либо или . Это позволяет записать решение в виде .[1]

пример

Предположим, нам нужно решить уравнение . Для этого нам нужно разложить на множители . Рассмотрим некоторые возможные значения :

  1. Позволять . потом , таким образом . Оба числа являются квадратичными невычетами, поэтому нам нужно взять другие .
  1. Позволять . потом , таким образом . Из этого следует , так и .

Проверка вручную показывает, что действительно и .

Доказательство правильности

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

Сложность

Пусть многочлен имеет степень . Получим сложность алгоритма следующим образом:

  1. Из-за биномиальная теорема , мы можем перейти от к в время.
  2. Умножение полиномов и взятие остатка от одного полинома по модулю другого можно выполнить в , таким образом, расчет делается в .
  3. Двоичное возведение в степень работает в .
  4. Принимая двух полиномов через Евклидов алгоритм работает в .

Таким образом, вся процедура может быть выполнена в . С использованием быстрое преобразование Фурье и алгоритм Half-GCD,[9] сложность алгоритма может быть улучшена до . Для модульного случая квадратного корня степень равна , поэтому вся сложность алгоритма в таком случае ограничена за итерацию.[7]

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

  1. ^ а б c d е ж г Берлекамп, Э. Р. (1970). «Факторизация многочленов над большими конечными полями». Математика вычислений. 24 (111): 713–735. Дои:10.1090 / S0025-5718-1970-0276200-X. ISSN  0025-5718.
  2. ^ а б c d М. Рабин (1980). «Вероятностные алгоритмы в конечных полях». SIAM Журнал по вычислениям. 9 (2): 273–280. Дои:10.1137/0209024. ISSN  0097-5397.
  3. ^ Дональд Э. Кнут (1998). Искусство программирования. Vol. 2 т. 2. ISBN  978-0201896848. OCLC  900627019.
  4. ^ Цз-Во Сзе (2011). «О извлечении квадратных корней без квадратичных невычетов над конечными полями». Математика вычислений. 80 (275): 1797–1811. arXiv:0812.2591. Дои:10.1090 / s0025-5718-2011-02419-1. ISSN  0025-5718.
  5. ^ Р. Перальта (ноябрь 1986 г.). «Простой и быстрый вероятностный алгоритм для вычисления квадратных корней по модулю простого числа (Corresp.)». IEEE Transactions по теории информации. 32 (6): 846–847. Дои:10.1109 / TIT.1986.1057236. ISSN  0018-9448.
  6. ^ С. Падро, Г. Саез (август 2002 г.). «Корни куба в Zm». Письма по прикладной математике. 15 (6): 703–708. Дои:10.1016 / s0893-9659 (02) 00031-9. ISSN  0893-9659.
  7. ^ а б c d Альфред Дж. Менезес, Ян Ф. Блейк, Сю Хонг Гао, Рональд К. Маллин, Скотт А. Ванстон (1993). Приложения конечных полей. Серия Springer International в области инженерии и информатики. Springer США. ISBN  9780792392828.CS1 maint: несколько имен: список авторов (ссылка на сайт)
  8. ^ Маршалл Холл (1998). Комбинаторная теория. Джон Вили и сыновья. ISBN  9780471315186.
  9. ^ Ахо, Альфред В. (1974). Разработка и анализ компьютерных алгоритмов. Аддисон-Уэсли Паб. Co. ISBN  0201000296.