Умножение по Монтгомери — различия между версиями
(Новая страница: «'''Алгоритм Монтгомери''' — приём, позволяющий ускорить выполнение операций умножения и во…») |
(нет различий)
|
Версия 22:32, 8 октября 2010
Алгоритм Монтгомери — приём, позволяющий ускорить выполнение операций умножения и возведения в квадрат, необходимых при возведение числа в степень по модулю, когда модуль велик (порядка сотен бит). Был предложен в 1985 году Питером Монтгомери.
По данным целым числам a, b < n, r, НОД алгоритм Монтгомери вычисляет
Умножение Монтгомери
Положим
.Определим n-остаток (n-residue) числа
как .Алгоритм Монтгомери использует свойство, что множество полной системой вычетов, то есть содержит все числа от 0 до n-1.
являетсяMonPro вычисляет
. Результат является n-остатком от , так как
Определим n' так, что
. и можно вычислить с помощью расширенного алгоритма Евклида.Функция
1.2. 3. if then return else return
Операции умножения и деления на r выполняются очень быстро, так как при
представляют собой просто сдвиги бит. Таким образом алгоритм Монтгомери быстрее обычного вычисления , которое содержит деление на n. Однако вычисление n' и перевод чисел в n-остатки и обратно — трудоёмкие операции, вследствие чего применять алгоритм Монтгомери при вычислении произведения двух чисел представляется неразумным.Возведение в степень Монтгомери
Использование алгоритма Монтгомери оправдывает себя при возведении числа в степень по модулю
.Функция
1.2. 3. for i=j-1 downto 0 if then 4. return
Возведение числа в степень битовой длины k алгоритмом быстрого возведения в степень включает в себя от k до 2k умножений, где k имеет порядок сотен или тысяч бит. При использовании алгоритма возведения в степень Монтгомери объём дополнительных вычислений фиксирован (вычисления , , в начале и в конце), а операция MonPro выполняется быстрее обычного умножения по модулю, поэтому алгоритм возведения в степень Монтгомери даст выигрыш в производительности по сравнению с алгоритмом быстрого возведения в степень.