Студопедия

КАТЕГОРИИ:


Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748)

Алгоритмы поиска больших простых чисел

 

Простым называется целое число, больше единицы, единственными множителями которого является 1 и оно само: оно не делится ни на одно другое число. Например, простыми являются 73, 2521, 2365347734339 и 2756839–1. Вся криптография с открытыми ключами основана на том факте, что существует бесконечно много простых чисел (Теорема Эвклида). В реальной криптографии используются большие простые числа, размер которых 512 бит и более.

Существует приблизительно 10151 простых чисел длиной 512 бит.

Для чисел, близких n, вероятность того, что случайно выбранное число окажется простым равна 1/ln(n ). Полное число простых чисел меньших n, приблизительно равно n/ ln(n).

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

Если кто-то создаст базу данных всех простых чисел, может сможет он ее использовать для вскрытия алгоритмов с открытыми ключами? Пусть мы будем хранить один гигабайт информации на устройстве, весящем 1 грамм, то перечень простых чисел размерос до 512 бит имел такую массу, что она превысила бы предел Чандрасе́кара. Наша флэшка бы сколлапсировала бы в черную дыру и извлечь откуда данные все равно будет невозможно.

Преде́л Чандрасе́кара — это верхний предел массы, при котором звезда может существовать как белый карлик. Если масса звезды превышает этот предел, то она становится нейтронной звездой.

Алгоритмы поиска больших простых чисел можно разделить на две группы: алгоритмы перебора и вероятностные алгоритмы. К первой группе относятся алгоритм прямого перебора с проверкой делимости и «решето Эратосфена». Такие алгоритмы неэффективны для больших чисел, поскольку работают очень медленно. Вторая группа алгоритмов использует вероятностные оценки для определения простоты числа. Наиболее широкое распространение получили алгоритм Рабина-Миллера и тест Лемана [8].

Алгоритм был разработан Гари Миллером в 1976 году и модифицирован Майклом Рабином в 1980 году

Алгоритм Рабина Миллера предлагает следующую схему генерации простого числа:

1. Выберите для проверки случайное число p. Вычислите b – число делений p – 1 на 2 (2 b – это наибольшая степень числа 2, на которое делится
p – 1). Затем вычислите m, такое что p = 1 + 2 b * m.

2. Выберите случайное число a < p.

3. Установите j = 0 и вычислить z = a×m mod p.

4. Если z = 1 или z = p – 1, то p проходит проверку и может быть

простым числом.

5. Если j > 0 и z = 1, то p не является простым числом.

6. Установите j = j + 1. Если j < b и z p – 1, установите z = 2 z mod p и

вернитесь к пункту 4. Если z = p – 1, то p проходит проверку и может

быть простым числом.

7. Если j = b и z p – 1, то p не является простым числом.

Число окажется составным через t проверок с вероятностью не большей (1/4) t , где t – это число итераций.

Альтернативный алгоритм для поиска простых чисел был разработан Леманом.

Вот последовательность действий при проверке простоты числа p:

1. Выбрать случайное число а, причем a<p;

2. Вычислить k= a(p-1) div2mod p;

3. Если k ≠ 1 или k≠ (p-1), то рассматриваемое p не является простым.

4. Если k =1 или k= (p-1), то вероятность того, что p не является простым, не более 50 процентов.

5. Попытку (1) – (4) повторить т раз с различными случайными значениями a.

Если результат вычислений равен 1 или (p –1), но не всегда равен 1, то p является простым числом с вероятностью ошибки 1/2 m.

Два числа называются взаимно простыми, если у них нет общих множителей кроме 1. Иными словами, если наибольший общий делитель этих чисел равен 1. Если n является простым числом, то любое число от 1 до n –1 взаимно просто с n. Взаимно просты числа 15 и 32, 27 и 64. Одним из способов вычислить наибольший общий делитель двух чисел является алгоритм Эвклида, описанный в книге Элементы (300 год до н. э.)

<== предыдущая лекция | следующая лекция ==>
Алгоритм расчета контрольной суммы CRC32 | Алгоритмы возведения в степень в конечном поле
Поделиться с друзьями:


Дата добавления: 2014-01-15; Просмотров: 1969; Нарушение авторских прав?; Мы поможем в написании вашей работы!


Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет



studopedia.su - Студопедия (2013 - 2025) год. Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав! Последнее добавление




Генерация страницы за: 0.012 сек.