Научная статья на тему 'Методы и алгоритмы генерации многоразрядных простых чисел в криптографических системах'

Методы и алгоритмы генерации многоразрядных простых чисел в криптографических системах Текст научной статьи по специальности «Компьютерные и информационные науки»

CC BY
1047
104
i Надоели баннеры? Вы всегда можете отключить рекламу.

Аннотация научной статьи по компьютерным и информационным наукам, автор научной работы — Горбенко Иван Дмитриевич, Мельникова Оксана Анатольевна

Проведены анализ и сравнение методов проверки простоты чисел с точки зрения их соответствия требованиям криптографических приложений. Приведена методика проверки и оценки характеристик тестов простоты, позволяющая сравнить их эффективность по различным параметрам (времени выполнения единичного теста, поиска простого числа, эффективности отсеивания и т.д.) при изменении режима выбора начальных приближений. Предлагаются рекомендации по разработке комплексного метода поиска простого числа.

i Надоели баннеры? Вы всегда можете отключить рекламу.

Похожие темы научных работ по компьютерным и информационным наукам , автор научной работы — Горбенко Иван Дмитриевич, Мельникова Оксана Анатольевна

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.
i Надоели баннеры? Вы всегда можете отключить рекламу.

Текст научной работы на тему «Методы и алгоритмы генерации многоразрядных простых чисел в криптографических системах»

УДК 681.3.067

МЕТОДЫ И АЛГОРИТМЫ ГЕНЕРАЦИИ МНОГОРАЗРЯДНЫХ ПРОСТЫХ ЧИСЕЛ В КРИПТОГРАФИЧЕСКИХ СИСТЕМАХ

ГОРБЕНКО И.Д., МЕЛЬНИКОВА О.А

Проведены анализ и сравнение методов проверки простоты чисел с точки зрения их соответствия требованиям криптографических приложений. Приведена методика проверки и оценки характеристик тестов простоты, позволяющая сравнить их эффективность по различным параметрам (времени выполнения единичного теста, поиска простого числа, эффективности отсеивания и т.д.) при изменении режима выбора начальных приближений. Предлагаются рекомендации по разработке комплексного метода поиска простого числа.

В настоящее время в системах защиты информации широко используются несимметричные криптографические преобразования (например, RSA — схемы шифрования и подписи, класс подписей типа Эль — Гамаля, схема Диффи — Хеллмана и другие). В несимметричной криптографии в качестве ключевых параметров или их секретных составляющих повсеместно используются простые числа (или пары простое число — первообразный элемент). Отметим, что для обеспечения требуемого уровня стойкости криптографических систем необходимо использовать простые числа большой разрядности (например, не менее 512 бит) и, следовательно, использовать трудоемкие операции арифметики многократной точности. Кроме того, используемые простые числа во многих криптографических схемах должны удовлетворять еще ряду довольно жестких требований и ограничений, что создает дополнительные трудности при их формировании и требует значительных вычислительных затрат на повторную перегенерацию при неудовлетворительном качестве сформированных чисел. Поскольку в криптографических системах вычислительная сложность алгоритмов является, как правило, критическим параметром, то особую актуальность приобретает проблема быстрого формирования простых чисел с заданными свойствами (т.е. создания быстрого комплексного теста проверки простоты задаваемых чисел, обеспечивающего требуемый уровень достоверности).

1. Анализ методов проверки простоты чисел

К настоящему времени разработан ряд методов проверки простоты чисел. Их можно разделить на три группы. К первой относятся математически строгие методы, которые позволяют однозначно ответить на вопрос о простоте числа. Методы Монте-Карло (группа вероятностных методов) позволяют подтвердить предположение о простоте числа только с определенной вероятностью. К третьей группе относятся методы, базирующиеся на использовании гипотез, в частности, на предположении истинности очень правдоподобной, но не доказанной гипотезы.

К математически строгим (аналитическим) методам относятся: метод пробных делений, решето Эратосфена, методы прямой факторизации с использованием различных вычислительных алгоритмов, использование чисел специального вида (Ферма,

Мерсенна и других), а также методы, использующие известные разложения чисел N ± 1 и других. Вероятностные методы базируются на использовании так называемых вероятностных тестов проверки на простоту. Основными из них являются: тест, основанный на использовании теоремы Ферма, тест Лемана, тест Соловея -Штрассена, тест Рабина, стохастический тест Малма и другие. К основным методам, базирующимся на использовании предположения о справедливости определенной гипотезы (в частности, расширенной гипотезы Римана), относятся методы, использующие следующие алгоритмы: Полларда, Миллера, Адлемана-Румели, Ленстры- Коэна и другие.

Все названные методы могут быть использованы для проверки чисел на простоту. При работе с криптографическими системами основным критерием предпочтительности выбора того или иного метода проверки простоты чисел является минимизация вычислительной сложности (а следовательно, и времени построения простых чисел). Здесь подразумевается построение больших простых чисел (например, не менее 512-битных чисел).

Обобщим результаты сравнения трех групп мето -дов. Аналитические методы дают строгое решение вопроса о простоте, но обладают рядом существенных недостатков: требуют полного или частичного разложения на простые сомножители, что является трудо -емкой задачей; часто сложны для реализации из-за высокой вероятности сбоя или ошибки программирования. Методы гипотез относительно легко реализуемы и принятые ими числа действительно будут простыми, если будет доказана соответствующая гипотеза. Однако если изначальная гипотеза окажется неверной, то методы нельзя считать строгими доказательствами простоты. Методы гипотез требуют также выполнения длительных вычислений. Вероятностные методы не дают строгого математического доказательства простоты числа, но легко реализуемы, не требуют разложения на сомножители и обеспечивают быстрое выполнение проверки.

Анализ показал, что наиболее оптимальными по вычислительным затратам являются вероятностные алгоритмы. Учитывая особенности криптографических приложений, требующих быстрого оперирования с числами большой разрядности, в настоящее время предпочтительней использовать класс вероятностных методов проверки простоты. Рассмотрим кратко основные вероятностные тесты. Эти тесты проверяют выполнение некоторых условий на последовательности равномерно распределенных случайных чисел из отрезка [1, А]. При выполнении условий для всех случайно выбранных значений можно с некоторой вероятностью (зависящей от вида теста) утверждать, что Аявляется простым числом. Вероятность зависит от объема выборки случайных чисел, а также от качества случайности используемой выборки.

Тест Ферма [1,2] использует малую теорему Ферма и проверяет выполнение условия

aN-1 = 1mod N (1)

для случайных чисел aj из интервала [1, А]. Вычислительная сложность теста может быть оценена как о(|N\ • M(|N\)) шагов [2], где M(\N\) — количество шагов для умножения двух чисел длины |А| при использовании стандартной техники [3].

РИ, 1997, № 1

99

Числа N, удовлетворяющие (1), принято называть псевдопростыми по основанию aj или aj-псп [2]. Известно, что существует бесконечно много составных аі-псп чисел. Существуют также составные числа Кармайкла, которые являются псевдопростыми для любого aj, такого, что (a, N) = 1 (абсолютно псевдопростые). Таким образом, тест Ферма может оказаться неудачным для составного числа N, если оно является числом Кармайкла, или поиск первого aj, не удовлетворяющего (1), может потребовать слишком больших вычислительных затрат. Черник дал метод получения чисел Кармайкла [4], но до сих пор еще не известно, существует ли бесконечное множество таких чисел и неизвестен их закон распределения. В ходе исследований при создании методики проверки и оценки характеристик тестов для эмпирической проверки эффективности отсеивания тестов был реализован метод Черника и получены 28800 чисел Кармайкла

вида N = (6t + l)(l2t + l)(l8t +1) в диапазоне до 10 байт (минимальное число — 1729 = 713 19, максимальное число —

43606UL938121998UL3946586977UL=51180631UL 102361261UL 153541891 UL). Отличие диапазона чисел Кармайкла, используемых при проведении экспериментов в данной работе, от диапазона реально используемых в криптографии чисел (256 — 1024 бит) объясняется вычислительными ограничениями в методе генерации достоверных трехкомпонентных чисел Кармайкла. В дальнейшем предполагается проведение и публикация результатов отдельных углубленных исследований по данному вопросу: разработка методики и алгоритма формирования «вероятностных» чисел Кармайкла большой длины (256, 512 бит), исследование их распределения и свойств (возможности отсеивания различными тестами) для данных длин. Для целей настоящей работы данное ограничение не является критичным.

Тест Лемана [5] основан на использовании малой теоремы Ферма (1) в преобразованном виде:

(+l)af-l)= 0 mod N

Р

N -1 2

или

aj = 1 mod N , ав = -1 mod N .

(2)

В классическом варианте теста Лемана условия (2) проверяются на k случайных значениях чисел aj из интервала [1, N] и ставится требование хотя бы одного появления “-1” на наборе {a;, ... , ak}. При этом вероятность ошибки (ошибочного принятия составного числа) [5] не превышает 2-k.

Основными недостатками классического варианта теста Лемана является то, что при малых (в соотношении с размерностью N) значениях k тест может ошибочно браковать простые числа, а также то, что в большинстве случаев возникает необходимость выполнения проверки на всех k значениях aj. Другие вероятностные тесты позволяют при выполнении проверок на составных числах досрочно выходить из цикла по k, что значительно уменьшает среднее время выполнения теста при поиске простых чисел (подтверждается приведенными далее экспериментальными данными).

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

100

(аг, N) = 1 ,

N-1 ( ) (3)

aj = J(aj, N) mod N ,

где J(aj, N) — символ Якоби, для k случайно выбранных значений aj из интервала [1, N-1] нечетное число Nявляется простым числом с вероятностью ошибки

не более 2 -k . Вычислительная сложность теста, по сведениям [7], может быть оценена как Onlog N )2+s) Vs> 0 и определяется сложностью вычисления степени по модулю [3] и вычислительной сложностью определения символа Якоби [8].

Тест Рабина, по имеющимся сведениям [2], является обобщенной и более сильной версией теста Соловея-Штрассена. Поскольку проверяемое число N нечетно, то его можно представить в виде N = 2r ■ s +1, где s — нечетное число.

При выполнении условий

aj = 1 mod N ,

(а 2 ) = -1 mod N , для некоторого j = 1, r -1, (4)

для k случайно выбранных из интервала [1,N-1] значений aj, Nявляется простым числом с ве-

роятностью ошибки не более 4 - k (оценка лучше, чем для теста Соловея-Штрассена). Вычислительная сложность, по данным [7], оценивается как O(log2 N) операций над большими целыми числами.

Стохастический тест Малма [2] использует результаты Лемера и дает вероятность ошибки не более 2-к■(т-1) , где т — количество различных простых делителей числа N. Этот тест более трудоемок, чем рассматривавшиеся ранее тесты Соловея-Штрассена и Рабина, но при этом не снижает вероятность ошибки.

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

2. Методика проверки и оценки характеристик тестов проверки простоты.

Позволяет провести дополнительную проверку правильности реализации тестов, сравнить эффективность тестов по различным параметрам (времени

РИ, 1997, № 1

выполнения единичного теста, времени поиска простого числа, эффективность отсеивания) при изменении режима выбора начальных приближений формируемых простых чисел, а также сформулировать предложения по созданию комплексного теста. В процессе исследования тестов необходимо выполнить следующие этапы проверок, проводящиеся отдельно для наиболее часто используемых в настоящее время в криптографических системах длин простых чисел: 1. Проверить эмпирические вероятности эффективности проверки для заведомо составных чисел (для RSA-модуля N = PQ) при различных значениях к (количества итераций теста); 2. То

же для заведомо простых чисел (например, для используемых в RS A-схеме и в Эль - Гамаля-подобных схемах).

Первые два шага позволяют удостовериться в правильности выполнения тестов и оценить достаточное минимальное значение параметра к для каждого теста и для данной длины формируемых чисел. Проведенные по первым двум этапам исследования показали, что для длин 256 и 512 бит все тесты, кроме теста Лемана, правильно распознают заведомо простые и составные числа даже при к = 1. Тест Лемана при малых значениях к может ошибочно браковать простые числа и требует минимально допустимого значения к = 9 для 256-битных чисел и к = 4 для 512битных чисел.

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

4. Оценить временные характеристики вероятностных тестов на числах различного типа (гарантировано простых и составных, на числах специального вида) и для часто используемых длин.

В нашем случае в качестве чисел специального вида использовались, как указывалось ранее, числа Кармайкла. Как показали исследования (табл. 1, 2), лучшими соотношениями вероятности отсеивания и

значениями параметра к для эффективного отсеивания чисел Кармайкла являются 5, 10 и 20 для тестов Рабина, Соловея-Штрассена и Лемана.

5. Оценить эффективность отсеивания при различных значениях параметра к при выполнении поиска простых чисел различной длины среди случайных нечетных чисел. Для каждого теста определить минимально допустимые значения к для обеспечения оптимальной эффективности отсеивания составных чисел. Исследования показали: поиск простых чисел среди нечетных случайных чисел неприемлем по значительным временным затратам.

6. Учитывая значительные временные затраты вероятностных тестов при проведении поиска простых чисел среди нечетных случайных чисел и, следовательно, необходимость проведения предварительного быстрого отбора чисел, провести оценку эффективности отсеивания составных чисел частичными тестами деления на одно- и двухбайтовые простые числа при выполнении поиска простых чисел различной длины среди случайных нечетных чисел или другими быстрыми тестами предварительного отбора. Некоторая информация о подобной методике предварительного отсеивания в настоящее время уже существует и используется [9]. Нашей задачей является определение временных характери-

Таблица1

Параметр теста Эмпирическая вероятность отсеивания чисел Кармайкла тестом

Лемана Соловея -Штрассена Рабина

1 0.9782 0.9340 0.9465

2 0.9664 0.9458 0.9479

3 0.9601 0.9505 0.9536

4 0.9568 0.9525 0.9540

5 0.9555 0.9534 0.9541

10 0.9540 0.9541 0.9541

20 0.9541 0.9541 0.9541

Таблица 2

Параметры тестируемых чисел : Характеристики вероятностного теста

Ферма Лемана Соловея -Штрассена Рабина

тип длина (бит) Mt Dt Mt Dt Mt Dt Mt Dt

Простые P 256 1.2-10"2 1.04-10-5 1.38-10-2 2.29-10-5 1.46-10-2 2.74-10-5 0.94-10-2 1.51 -10-5

512 8.33-10-2 4.55-10-6 8.39-10-2 7.33-10-6 9.04-10-2 7.80-10-6 7.59-10-2 5.51-10-6

Случайные составные 256 1.17-10-2 5.20-10-4 1.19-10-2 5.07-10-4 1.46-10-2 6.13-10-4 1.00-10-2 1.74-10-4

512 8.04-10-2 7.50-10-4 7.54-10-2 7.39-10-4 7.91-10-2 7.54-10-4 5.11-10-2 0.92-10-4

Случайные нечетные 256 8.60-10-3 4.22-10-4 2.95-10-3 1.61-10-4 3.22-10-3 1.51-10-4 2.17-10-3 0.46-10-4

512 4.94-10-2 2.94-10-4 1.26-10-2 5.37-10-4 1.27-10-2 5.46-10-4 0.93-10-2 1.68-10-4

Случ. с дел. на 1 байт 256 2.30-10-3 1.17-10-4 3.80-10-3 1.94-10-4 1.76-10-3 0.94-10-4 3.06-10-3 0.74-10-4

512 1.47-10-2 5.83-10-4 1.30-10-2 5.32-10-4 1.41-10-2 5.64-10-4 0.86-10-2 1.59-10-4

Случ. с дел. на 2 байта 256 2.20-10-3 1.17-10-4 2.42-10-3 1.17-10-4 1.82-10-3 0.84-10-4 3.05-10-3 0.76-10-4

512 1.20-10-2 5.16-10-4 1.27-10-2 5.46-10-4 1.21 -10-2 5.25-10-4 1.02-10-2 1.79-10-4

Кармайкла до 10б. 8.01-10-4 4.03-10-5 8.00-10-4 4.08-10-5 8.50-10-4 4.35-10-5 15.4-10-4 3.94-10-5

M — среднее время выполнения единичного теста (в секундах);

Dt — дисперсия времени выполнения единичного теста (в секундах).

среднего времени выполнения единичного теста обладают тесты Рабина и Соловея-Штрассена, причем по временным характеристикам тест Рабина значительно лучше, а минимально допустимыми

стики частичных тестов деления при различных условиях выбора тестируемых чисел (при полностью случайном выборе проверяемых значений и при случайном начальном выборе проверяемого значе-

РИ, 1997, № 1

101

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

Как показали исследования (табл. 3, 4), предварительные тесты деления отсеивают среди нечетных случайно выбираемых чисел 81,2 % и 90,8 % составных 256-битных чисел для одно- и двухбайтовых тестов деления соответственно, а для 512-битных чисел 81,5 % и 90,5 % составных чисел соответственно . По временным затратам на поиск простых чисел (для 256 и 512-битных) оптимальным является двухбайтовый тест деления.

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

Как показали исследования, время поиска несущественно зависит от значения параметра к. Для всех тестов, кроме Лемана, даже при к = 1 процент ошибок близок к нулю. Для теста Лемана минимально допустимое значение к = 8 для 256 - битных чисел и к = 5 для 512 - битных чисел.

По временным характеристикам, с учетом эффективности тестов, предпочтительным является тест Рабина. Заметим, что временные характеристики поиска значительно улучшаются при использовании двухбайтового предварительного теста деления. Для примера можно привести следующие данные по тесту Рабина: среднее время поиска простого числа (512 бит) при к = 100 составляет 95,83, 21,89, 15,82 с. при использовании случайных нечетных чисел, предварительного теста деления на простые числа в диапа-

Таблица 3

Длина Эффективности отсеивания (в %) для длины

числа простых делителей в пределах

(бит) 1-го байта 2-х байтов

Всего Отсеяно из Всего Отсеяно из

отсеяно составных отсеяно составных

128 79.71 81.31 89.71 91.84

256 79.73 81.18 89.92 90.81

Таблица 4

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.

Длина тестируемого числа (бит) Режим выбора числа: Среднее время поиска при выполнении деления в диапазоне

1-го байта 2-х байтов

256 регулярно случайный ■'Г © 05 -t 3.37- 10-2

с увеличением случ. значения на 2 3.9- 10-4 3.71 - 10-2

512 регулярно случайный 9.4- 10-4 6.29- 10-2

с увеличением случ. значения на 2 7.6- 10-4 6.85- 10-2

зоне 1-го и 2-х байт соответственно. В той же пропорции изменяются временные характеристики и для других тестов.

8. Определить среднее время поиска простых чисел различной размерности при увеличении случайно выбранного начального значения тестируемо -го числа на 2, а также при увеличении случайно выбранного начального значения тестируемого числа на 2 и предварительном использовании одно- и двухбайтового частичных тестов деления.

102

Как показали эксперименты, при выборе тестируемых чисел с увеличением случайно выбранного начального значения тестируемого числа на 2 временные характеристики несущественно отличаются от варианта поиска при случайном выборе тестируемого числа, что объясняется использованием при проведении экспериментов упрощенного быстрого генератора ПСП, не обеспечивающего требуемого качества характеристик ПСП. Однако в реальных ситуациях, при необходимости использования достаточно сложных генераторов ПСП, обеспечивающих требуемые характеристики начальных приближений, вариант при увеличении случайно выбранного начального значения на 2 чаще всего дает выигрыш во времени.

Проведенные в соответствии с разработанной методикой экспериментальные исследования подтвердили предварительные теоретические выводы о предпочтительности использования вероятностного теста Рабина в качестве одного из составных частей при разработке комплексного теста проверки просто -ты числа. При разработке комплексного теста поиска простого числа рекомендуется для улучшения временных характеристик использовать предварительное отсеивание с использованием двухбайтового теста деления. Режим выбора проверяемых чисел (случайный или с увеличением на 2) также может влиять на время поиска простого числа и должен анализироваться и выбираться отдельно для каждого используемого генератора ПСП (при большой вычислительной сложности выполнения случайной генерации режим с увеличением случайного начального значения на 2 является более эффективным).

Литература: 1. Мафтик С. Механизмы защиты в сетях ЭВМ.- М.: Мир.— 1993.- 216 с. 2. Уильямс X. Проверка чисел на простоту с помощью вычислительных машин // Кибернетический сборник.— Вып. 23.- М.: Мир.— 1986.- С. 51- 99. 3. Кнут Д. Искусство программирования для ЭВМ. Т.2. Получисленные алгоритмы.- М.: Мир.— 1977.- 724 с. 4. Muller W.B., Oswald A. Dickson Pseudoprimes and Primality Testing // Crypto’85.- Р. 512- 516. 5. Schneier B. Applied cryptography second edition: protocols, algorithms, and source code in C.- New York: John Wiley & Sons, 1996.- 758 p. 6. Василенко O.H. Современные способы проверки простоты чисел // Кибернетический сборник.— Вып. 25.- М.: Мир.— 1988.- С. 162-188. 7. Ленстра X. Алгоритмы проверки на простоту [по Эдле-ману, Румли и Уильямсу] // Алгебра и теория чисел: избранные доклады семинара Н.Бурбаки.- М.: Мир.— 1987.- С. 47- 66. 8. БухштабА.А. Теория чисел.- М.: Просвещение.— 1966.- 384 с. 9. Wunderlich M.C. Computational methods for factoring large integers// ABACUS.- №. 2- 1988.- Р. 19-33.

Поступила в редакцию 15.12.97 Горбенко Иван Дмитриевич, проф., д-р техн. наук., проректор по научной работе ХТУРЭ. Научные интересы: защита информации в компьютерных системах и сетях. Адрес: 310726, Харьков, пр.Ле-нина 14, тел. 30-24-50.

Мельникова Оксана Анатольевна, аспирантка кафедры ЭВМ ХТУРЭ. Научные интересы: криптография. Адрес: 310726, Украина, Харьков, пр.Ле-нина, 14, тел. 30-24-50.

РИ, 1997, № 1

i Надоели баннеры? Вы всегда можете отключить рекламу.