Алгоритм Монтгомери

Материал из testwiki
Перейти к навигации Перейти к поиску

Алгоритм Монтгомери — приём, позволяющий ускорить выполнение операций умножения и возведения в квадрат, необходимых при возведении числа в степень по модулю, когда модуль велик (порядка сотен бит). Был предложен в 1985 году Питером Монтгомери.

По данным целым числам a, b < n, r, НОД(r,n)=1 алгоритм Монтгомери вычисляет

MonPro(a,b)=abr1modn

В приложениях обычно берётся r=2k, так как в этом случае деление с остатком и умножение на r, используемые внутри алгоритма, происходят быстро.

Умножение Монтгомери

Определим n-остаток (n-residue) числа a<n как a¯=armodn.

Алгоритм Монтгомери использует свойство, что множество {armodn0an1} является полной системой вычетов, то есть содержит все числа от 0 до n-1.

MonPro вычисляет c¯=a¯b¯r1modn. Результат является n-остатком от c=abmodn, так как

c¯=a¯b¯r1modn=arbrr1modn=crmodn

Определим n' так, что rr1nn=1. r1 и n можно вычислить с помощью расширенного алгоритма Евклида.

Функция MonPro(a¯,b¯)

1. t=a¯b¯
2. u=(t+(tnmodr)n)/r
3. while (u>=n)u=un
4. return  u

При r=2k операции умножения и деления на r выполняются очень быстро, так как представляют собой просто сдвиги бит, а при r>n цикл в строчке 3 выполнится не более одного раза. Таким образом алгоритм Монтгомери быстрее обычного вычисления abmodn, которое содержит деление на n. Однако вычисление n' и перевод чисел в n-остатки и обратно — трудоёмкие операции, вследствие чего применять алгоритм Монтгомери при однократном вычислении произведения двух чисел представляется неразумным.

Возведение в степень Монтгомери

Использование алгоритма Монтгомери оправдывает себя при возведении числа в степень по модулю aemodn.

Функция ModExp(a,e,n)

1. a¯=armodn
2. x¯=1rmodn
3. for i=j-1 downto 0
     x¯=MonPro(x¯,x¯)
     if ei=1 then x¯=MonPro(x¯,a¯)
4. return x=MonPro(x¯,1)

Возведение числа в степень битовой длины k алгоритмом «возводи в квадрат и перемножай» включает в себя от k до 2k умножений, где k имеет порядок сотен или тысяч бит. При использовании алгоритма возведения в степень Монтгомери объём дополнительных вычислений фиксирован (вычисления n, a¯, x¯ в начале и MonPro(x¯,1) в конце), а операция MonPro выполняется быстрее обычного умножения по модулю[1], поэтому алгоритм возведения в степень Монтгомери даст выигрыш в производительности по сравнению с алгоритмом «возводи в квадрат и перемножай».

Реализация алгоритма на JavaScript

function powMod(a, e, m) {
	var r = 1;
	while (e > 0) {
		console.log('A='+a+', E='+e+', R='+r);
		if ((e & 1) == 0) {
			e = e >> 1;
			a = (a * a) % m;
		} else {
			e = e - 1;
			r = (r * a) % m;
		}
	}
	console.log('A='+a+', E='+e+', R='+r);

	return r;
}

Примечания

Шаблон:Примечания

Литература

Шаблон:Math-stub