Алгоритм Гельфонда — Шенкса
Алгоритм Гельфонда — Шенкса (англ. Baby-step giant-step; также называемый алгоритмом больших и малых шагов; также очень часто можно встретить название алгоритм согласования, например в книге Василенко "Теоретико-числовые алгоритмы криптографии") — в теории групп детерминированный алгоритм дискретного логарифмирования в мульпликативной группе кольца вычетов по модулю простого числа. Был предложен советским математиком Александром Гельфондом в 1962 году и Дэниелом Шенксом в 1972 году[1][2][3].
Метод теоретически упрощает решение задачи дискретного логарифмирования, на вычислительной сложности которой построены многие криптосистемы с открытым ключом. Относится к методам встречи посередине.
Область применения
Задача дискретного логарифмирования представляет большой интерес для построения криптосистем с открытым ключом. На предположении о чрезвычайно высокой вычислительной сложности решения этой задачи основаны такие криптоалгоритмы как, например, RSA, DSA, Elgamal, Diffie-Hellman, ECDSA, ГОСТ Р 34.10-2001, Rabin и другие. В них криптоаналитик может получить закрытый ключ путём взятия дискретного логарифма от открытого ключа (известного всем), и с его помощью преобразовать шифротекст в текст сообщения. Однако чем сложнее его найти (чем большее количество операций нужно проделать для нахождения дискретного логарифма), тем более стойкой является криптосистема. Одним из способов повысить сложность задачи дискретного логарифмирования является создание криптосистемы, основанной на группе с большим порядком (где логарифмирование будет происходить по модулю большого простого числа). В общем случае такая задача решается полным перебором, данный же алгоритм позволяет в некоторых случаях упростить нахождения показателя степени (уменьшить количество шагов) при вычислении по модулю простого числа, в самом благоприятном случае в квадратный корень раз[4], но этого сокращения всё равно недостаточно для решения задачи на электронно-вычислительной машине за разумное время (вопрос о решении задачи дискретного логарифма за полиномиальное время на персональном компьютере остаётся открытым до сих пор)[5].
Задача дискретного логарифмирования
Пусть задана циклическая группа [math]\displaystyle{ G }[/math] с образующим [math]\displaystyle{ g }[/math], содержащая [math]\displaystyle{ n }[/math] элементов. Целое число [math]\displaystyle{ x }[/math] (в диапазоне от [math]\displaystyle{ 0 }[/math] до [math]\displaystyle{ n-1 }[/math]) называется дискретным логарифмом элемента [math]\displaystyle{ h \in G }[/math] по основанию [math]\displaystyle{ g }[/math], если выполняется соотношение:
- [math]\displaystyle{ g^x = h. }[/math]
Задача дискретного логарифмирования — по заданным [math]\displaystyle{ h }[/math], [math]\displaystyle{ g }[/math] определить [math]\displaystyle{ x }[/math].
Формально задача дискретного логарифмирования ставится следующим образом[6]:
- [math]\displaystyle{ \begin{cases} \text{Input:} \quad & g, h, n \in \mathbb{N} \\ \text{Output:} \quad & x \in \mathbb{N}: \ g^x \equiv h\pmod n\\ \end{cases} }[/math]
при условии, что [math]\displaystyle{ x }[/math] может не существовать, а также [math]\displaystyle{ n }[/math] может быть как простым числом, так и составным.
Теория
Идея алгоритма состоит в выборе оптимального соотношения времени и памяти, а именно в усовершенствованном поиске показателя степени.
Пусть задана циклическая группа [math]\displaystyle{ G }[/math] порядка [math]\displaystyle{ n }[/math], генератор группы [math]\displaystyle{ \alpha }[/math] и некоторый элемент группы [math]\displaystyle{ \beta }[/math]. Задача сводится к нахождению целого числа [math]\displaystyle{ x }[/math], для которого выполняется
- [math]\displaystyle{ \alpha^x = \beta\,. }[/math]
Алгоритм Гельфонда — Шенкса основан на представлении [math]\displaystyle{ x }[/math] в виде [math]\displaystyle{ x = i\cdot m - j }[/math], где [math]\displaystyle{ m = \left\lfloor \sqrt{n} \right\rfloor + 1 }[/math], и переборе [math]\displaystyle{ 1 \leq i \leq m }[/math] и [math]\displaystyle{ 0 \leq j \lt m }[/math]. Ограничение на [math]\displaystyle{ i }[/math] и [math]\displaystyle{ j }[/math] следует из того, что порядок группы не превосходит [math]\displaystyle{ m }[/math], а значит указанные диапазоны достаточны для получения всех возможных [math]\displaystyle{ x }[/math] из полуинтервала [math]\displaystyle{ \left[0; m\right) }[/math]. Такое представление равносильно равенству
-
[math]\displaystyle{ \alpha^{im} = \beta \alpha^j\,. }[/math]
(1)
Алгоритм предварительно вычисляет [math]\displaystyle{ \alpha^{im} }[/math] для разных значений [math]\displaystyle{ i }[/math] и сохраняет их в структуре данных, позволяющей эффективный поиск, а затем перебирает всевозможные значения [math]\displaystyle{ j }[/math] и проверяет, если [math]\displaystyle{ \beta \alpha^j }[/math] соответствует какому-то значению [math]\displaystyle{ i }[/math]. Таким образом находятся индексы [math]\displaystyle{ i }[/math] и [math]\displaystyle{ j }[/math], которые удовлетворяют соотношению (1) и позволяют вычислить значение [math]\displaystyle{ x = i\cdot m - j }[/math] [7].
Алгоритм
Вход: Циклическая группа [math]\displaystyle{ G }[/math] порядка [math]\displaystyle{ n }[/math], генератор [math]\displaystyle{ \alpha }[/math] и некоторый элемент [math]\displaystyle{ \beta }[/math].
Выход: Число [math]\displaystyle{ x }[/math], удовлетворяющее [math]\displaystyle{ \alpha^{x}=\beta }[/math].
- [math]\displaystyle{ m }[/math] ← [math]\displaystyle{ \left\lfloor \sqrt{n} \right\rfloor +1 }[/math]
- Вычислить [math]\displaystyle{ \gamma }[/math] ← [math]\displaystyle{ \alpha^{m} }[/math].
- Для любого [math]\displaystyle{ i }[/math] где [math]\displaystyle{ 1 }[/math] ≤ [math]\displaystyle{ i }[/math] ≤ [math]\displaystyle{ m }[/math]:
- Записать в таблицу ([math]\displaystyle{ i }[/math], [math]\displaystyle{ \gamma }[/math]). (см. раздел «Реализация»)
- [math]\displaystyle{ \gamma }[/math] ← [math]\displaystyle{ \gamma }[/math] • [math]\displaystyle{ \alpha^{m} }[/math]
- Для любого [math]\displaystyle{ j }[/math] где [math]\displaystyle{ 0 }[/math] ≤ [math]\displaystyle{ j }[/math] ≤ [math]\displaystyle{ m-1 }[/math]:
Обоснование алгоритма
Нужно доказать, что одинаковые элементы в таблицах обязательно существуют, то есть найдутся такие [math]\displaystyle{ i }[/math] и [math]\displaystyle{ j }[/math], что [math]\displaystyle{ g^{mi} = \beta \cdot g^{j} = g^{x+j} }[/math]. Это равенство имеет место в случае [math]\displaystyle{ mi = x + j \pmod{n} }[/math], или [math]\displaystyle{ x = mi - j\pmod{n} }[/math]. При [math]\displaystyle{ 1 \le i \le m }[/math], [math]\displaystyle{ 1 \le j \le m }[/math] выполнено неравенство [math]\displaystyle{ 0 \le mi-j \le m^2 - 1 }[/math]. Для различных пар [math]\displaystyle{ (i_1, j_1) }[/math] и [math]\displaystyle{ (i_2, j_2) }[/math] имеем [math]\displaystyle{ mi_1 - j_1 \neq mi_2 - j_2 }[/math], так как в противном случае получилось бы [math]\displaystyle{ m(i_1 - i_2) = (j_1 - j_2) }[/math], что при указанном выборе [math]\displaystyle{ i_1, i_2 }[/math] возможно только в случае [math]\displaystyle{ i_1 = i_2 }[/math], и, следовательно, [math]\displaystyle{ j_1 = j_2 }[/math]. Таким образом, выражения [math]\displaystyle{ mi - j }[/math] принимают все значения в диапазоне от [math]\displaystyle{ 0 }[/math] до [math]\displaystyle{ m^2 - 1 }[/math], который, в силу того, что [math]\displaystyle{ m^2 \gt n }[/math], содержит все возможные значения [math]\displaystyle{ x }[/math] от [math]\displaystyle{ 0 }[/math] до [math]\displaystyle{ n - 1 }[/math]. Значит, для некоторых [math]\displaystyle{ i }[/math] и [math]\displaystyle{ j }[/math] имеет место равенство [math]\displaystyle{ x = mi - j\pmod{n} }[/math][2].
Оценка сложности алгоритма
Допустим, что необходимо решить [math]\displaystyle{ h = ng }[/math], где [math]\displaystyle{ h }[/math] и [math]\displaystyle{ g }[/math] — целые положительные числа меньше [math]\displaystyle{ 100 }[/math]. Один из способов — перебрать последовательно [math]\displaystyle{ n }[/math] от [math]\displaystyle{ 1 }[/math] до [math]\displaystyle{ 100 }[/math], сравнивая величину [math]\displaystyle{ n \cdot g }[/math] с [math]\displaystyle{ h }[/math]. В худшем случае нам потребуется [math]\displaystyle{ 100 }[/math] шагов (когда [math]\displaystyle{ n=99 }[/math]). В среднем это займет [math]\displaystyle{ 50 }[/math] шагов. В другом случае, мы можем представить [math]\displaystyle{ n }[/math] как [math]\displaystyle{ n=10a-b }[/math]. Таким образом, задача сводится к нахождению [math]\displaystyle{ a }[/math] и [math]\displaystyle{ b }[/math] . В этом случае можно переписать задачу как [math]\displaystyle{ h=(10a-b)g }[/math] или [math]\displaystyle{ h+bg=10ag }[/math]. Теперь мы можем перебрать все возможные значения [math]\displaystyle{ a }[/math] в правой части выражения. В данном случае это все числа от [math]\displaystyle{ 1 }[/math] до [math]\displaystyle{ 10 }[/math]. Это, так называемые, большие шаги. Известно, что одно из полученных значение для [math]\displaystyle{ a }[/math] — искомое. Мы можем записать все значения правой части выражения в таблице. Затем мы можем посчитать возможные значения для левой части для различных значений [math]\displaystyle{ b }[/math]. Такими являются все числа от [math]\displaystyle{ 0 }[/math] до [math]\displaystyle{ 9 }[/math] из которых одно является искомым, и вместе с правильным значением правой части дает искомый результат для [math]\displaystyle{ n }[/math]. Таким образом, задача сводится к перебору различных значений левой части и поиск их в таблице. Если нужное значение в таблице найдено, то мы нашли [math]\displaystyle{ b }[/math], и, следовательно, соответствующее [math]\displaystyle{ n=10a+b }[/math]. Данная иллюстрация демонстрирует скорость работы алгоритма. В среднем выполняется [math]\displaystyle{ 1.5\sqrt{n} }[/math] операций. В худшем случае требуется [math]\displaystyle{ 2\sqrt{n} }[/math] операций [3].
Пример
Ниже приведен пример решения задачи дискретного логарифмирования с маленьким порядком группы. На практике в криптосистемах используются группы с большим порядком для повышения криптостойкости.
Пусть известно [math]\displaystyle{ 5^x\equiv 3\pmod{23} }[/math]. В начале создадим и заполним таблицу для «больших шагов». Выберем [math]\displaystyle{ m=5 }[/math] ← ([math]\displaystyle{ \sqrt{16} + 1 }[/math]). Затем [math]\displaystyle{ i }[/math] пройдёт от [math]\displaystyle{ 1 }[/math] до [math]\displaystyle{ 5 }[/math].
[math]\displaystyle{ i }[/math] | 1 | 2 | 3 | 4 | 5 |
[math]\displaystyle{ 5^{im} = 20^{i} }[/math] | 20 | 9 | 19 | 12 | 10 |
Найдем подходящее значение [math]\displaystyle{ j }[/math] для [math]\displaystyle{ 3 \cdot 5^j\ \bmod\ 23 }[/math], чтобы значения в обеих таблицах совпали
[math]\displaystyle{ j }[/math] | 1 | 2 | 3 | 4 |
[math]\displaystyle{ \beta\alpha^{j}=3 }[/math]·[math]\displaystyle{ 5^{j} }[/math] | 15 | 6 | 7 | 12 |
Видно, что во второй таблице для [math]\displaystyle{ j=4 }[/math], такое значение уже находится в первой таблице. Находим [math]\displaystyle{ x=mi-j=5\cdot 4-4=16 }[/math][2].
Реализация
Существует способ улучшить производительность алгоритма Гельфонда — Шенкса. Он заключается в использовании эффективной схемы доступа к таблице. Лучший способ — использование хеш-таблицы. Следует производить хеширование по второй компоненте, а затем выполнять поиск по хешу в таблице в основном цикле по [math]\displaystyle{ \gamma }[/math]. Так как доступ и добавление элементов в хеш-таблицу работает за время [math]\displaystyle{ O(1) }[/math] (константа), то асимптотически это не замедляет алгоритм.
Время работы алгоритма оценивается как [math]\displaystyle{ O(\sqrt n) }[/math], что намного лучше, чем время работы [math]\displaystyle{ O(n) }[/math] полного перебора показателей степени[4].
Особенности
- Алгоритм Гельфонда — Шенкса работает для произвольной конечной циклической группы[7][3].
- Нет необходимости знать порядок группы [math]\displaystyle{ G }[/math] заранее. Алгоритм также работает, если [math]\displaystyle{ n }[/math] — верхняя граница порядка группы[7].
- Обычно алгоритм Гельфонда — Шенкса используется для групп, у которых порядок — простое число. Если порядком является составное число, то рекомендуется использование алгоритма Полига — Хеллмана[7].
- Алгоритму Гельфонда — Шенкса требуется [math]\displaystyle{ O(n) }[/math] памяти. Возможно выбрать меньшее [math]\displaystyle{ m }[/math] на первом шаге алгоритма. Это увеличивает время работы программы до [math]\displaystyle{ O(n/m) }[/math]. Также возможно использование ρ-метода Полларда для дискретного логарифмирования, который работает за то же самое время, но требует малое количество памяти[7].
Примечания
- ↑ 1,0 1,1 D. Shanks. The infrastructure of a real quadratic field and its applications. Proceedings of the Number Theory Conference. — University of Colorado, Boulder,, 1972. — С. pp. 217-224..
- ↑ 2,0 2,1 2,2 2,3 И. А. Панкратова. Теоретико-числовые методы в криптографии: Учебное пособие. — Томск: ТГУ, 2009. — С. 90-98. — 120 с..
- ↑ 3,0 3,1 3,2 В.И. Нечаев. Элементы криптографии. Основы теории защиты информации. — М.: Высшая школа, 1999. — С. 61-67. — 109 с. — ISBN 5-06-003644-8..
- ↑ 4,0 4,1 D. C. Terr. A modification of Shanks’ baby-step giant-step algorithm. — Mathematics of Computation. — 2000. — Т. 69. — С. 767–773..
- ↑ Василенко О. Н. Теоретико-числовые алгоритмы в криптографии. — Москва: МЦНМО, 2003. — С. 163-185. — 328 с. — ISBN 5-94057-103-4. Архивированная копия (недоступная ссылка). Дата обращения: 23 ноября 2016. Архивировано 27 января 2007 года..
- ↑ Yan, Song Y. Primality testing and integer factorization in public-key cryptography. — 2. — Springer, 2009. — С. 257-260. — 374 с. — ISBN 978-0-387-77267-7..
- ↑ 7,0 7,1 7,2 7,3 7,4 7,5 Глухов М. М, Круглов И. А., Пичкур А. Б., Черемушкин А. В. Введение в теоретико- числовые методы криптографии. — 1 изд.. — СПб.: Лань, 2010. — С. 279-298. — 400 с. с. — ISBN 978-5-8114-1116-0..
Литература
- А.О. Гельфонд, Ю.В. Линник. Элементарные методы в аналитической теории чисел. — М.: Физматгиз, 1962. — 272 с.