WikiSort.ru - Не сортированное

ПОИСК ПО САЙТУ | о проекте

Алгоритм Диксона — алгоритм факторизации, использующий в своей основе идею Лежандра, заключающуюся в поиске пары целых чисел и таких, что и

Метод Диксона является обобщением метода Ферма.

История [1]

В 20-х г. XX столетия Морис Крайчик (1882—1957), обобщая теорему Ферма предложил вместо пар чисел, удовлетворяющих уравнению , искать пары чисел, удовлетворяющих более общему уравнению . Крайчик заметил несколько полезных для решения фактов. В 1981 г. Джон Диксон опубликовал разработанный им метод факторизации, использующий идеи Крайтчика, и рассчитал его вычислительную сложность.[2]

Описание алгоритма [3]

  1. Составить факторную базу , состоящую из всех простых чисел , где .
  2. Выбрать случайное
  3. Вычислить .
  4. Проверить число на гладкость пробными делениями. Если является -гладким числом, то есть , следует запомнить вектора и :
    .
  5. Повторять процедуру генерации чисел до тех пор, пока не будет найдено -гладких чисел .
  6. Методом Гаусса найти линейную зависимость среди векторов :

    и положить:

    .
  7. Проверить . Если это так, то повторить процедуру генерации. Если нет, то найдено нетривиальное разложение:

Пример

Факторизуем число .

Все найденные числа с соответствующими векторами записываем в таблицу.

337 23814 1 5 0 2 0 0
430 5390 1 0 1 2 1 0
519 96 5 1 0 0 0 0
600 980 2 0 1 2 0 0
670 125 0 0 3 0 0 0
817 39204 2 4 0 0 2 0
860 21560 3 0 1 2 1 0

Решая линейную систему уравнений, получаем, что . Тогда

Следовательно,

.

Получилось разложение

Вычислительная сложность [5]

Обозначим через количество целых чисел таких, что и является -гладким числом, где . Из теоремы де Брёйна — Эрдёша , где . Значит, каждое -гладкое число будет в среднем попадаться с попыток. Для проверки, является ли число -гладким, необходимо выполнить делений. По алгоритму необходимо найти -гладкое число. Значит, вычислительная сложность поиска чисел

.

Вычислительная сложность метода Гаусса из уравнений

.

Следовательно, суммарная сложность алгоритма Диксона

.

Учитывая, что количество простых чисел меньше оценивается формулой , и что , после упрощения получаем

.

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

.

Дополнительные стратегии [6]

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

Стратегия LP

Стратегия LP использует большие простые числа для ускорения процедуры генерации чисел .

Алгоритм

Пусть найденное в пункте 4 число не является -гладким. Тогда его можно представить , где не делится на числа из факторной базы. Очевидно, что . Если дополнительно выполняется , то s — простое и мы включаем его в факторную базу. Это позволяет найти дополнительные -гладкие числа, но увеличивает количество необходимых гладких чисел на 1. Для возврата к первоначальной факторной базе после пункта 5 следует сделать следующее. Если найдено только одно число, в разложение которого входит в нечетной степени, то это число нужно вычеркнуть из списка и вычеркнуть из факторной базы. Если же, например, таких чисел два и , то их нужно вычеркнуть и добавить число . Показатель войдет в разложение в четной степени и будет отсутствовать в системе линейных уравнений.

Вариация стратегии

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

Вычислительная сложность

Теоретическая оценка сложности алгоритма Диксона с применением LP стратегии остается прежней

.

Стратегия EAS

Стратегия EAS (раннего обрыва) исключает некоторые из рассмотрения, не доводя проверку на гладкость до конца.

Алгоритм

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

Вариация стратегии

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

Вычислительная сложность

Алгоритм Диксона с применением стратегии EAS при оценивается

.

Стратегия PS

Стратегия PS использует алгоритм Полларда-Штрассена, который для и находит минимальный простой делитель числа НОД за .[7]

Алгоритм

Выбирается фиксированное . В алгоритме Диксона факторизуется пробными делениями на . В стратегии PS выбирается . Полагаем . Применяем алгоритм Полларда-Штрассена, выбирая за неразложенную часть, получим разложение .

Вычислительная сложность

Сложность алгоритма Диксона со стратегией PS минимальна при и равна

.

Примечания

  1. Ишмухаметов, 2011, с. 115.
  2. Dixon, J. D. (1981). “Asymptotically fast factorization of integers”. Math. Comp. 36 (153): 255—260. DOI:10.1090/S0025-5718-1981-0595059-1. JSTOR 2007743.
  3. Черемушкин, 2001, с. 77-79.
  4. Василенко, 2003, с. 79.
  5. Черемушкин, 2001, с. 79-80.
  6. Василенко, 2003, с. 81-83.
  7. Черемушкин, 2001, с. 74-75.

Литература

Данная страница на сайте WikiSort.ru содержит текст со страницы сайта "Википедия".

Если Вы хотите её отредактировать, то можете сделать это на странице редактирования в Википедии.

Если сделанные Вами правки не будут кем-нибудь удалены, то через несколько дней они появятся на сайте WikiSort.ru .




Текст в блоке "Читать" взят с сайта "Википедия" и доступен по лицензии Creative Commons Attribution-ShareAlike; в отдельных случаях могут действовать дополнительные условия.

Другой контент может иметь иную лицензию. Перед использованием материалов сайта WikiSort.ru внимательно изучите правила лицензирования конкретных элементов наполнения сайта.

2019-2024
WikiSort.ru - проект по пересортировке и дополнению контента Википедии