基于FFT的大整数乘法

更新时间:2023-10-15 01:14:01 阅读量: 综合文库 文档下载

说明:文章内容仅供预览,部分内容可能不全。下载后的文档,内容与下面显示的完全一致。下载之前请确认下面内容是否您想要的,是否完整无缺。

基于FFT的大整数乘法

1背景

对于两个长度为n的大整数,普通的大整数乘法的时间复杂度是On2,而采用一种精心构造的分治算法,则可以将时间复杂度降低为Onlog23?On1.585。此处则是受到快速傅立叶变换算法的启发,提出一种新的大整数乘法,该算法基于模-p的有限域运算,采用类似于FFT的算法,可以将大整数乘法的时间复杂度降低为On1.5,甚至,从某种意义上说,可以达到O?nlogn?。

????????2 基础

2.1 FFT(可以参考《算法导论》及《算法概论》相关内容)

对于两个n-1次多项式

3 基于FFT的大整数乘法

3.1大整数的表示方法

为简便起见,这里只考虑10进制大整数,但是这样并不会失去其一般性。对于一个10进制整数,可以将其表示为:

A?10??an?1?10n?1?an?2?10n?2???a1?10?a0

这样,就可以将一个大整数对应到一个n-1次多项式上去:

NA?A?x??an?1xn?1?an?2xn?2???a1x?a0,其中ai??0,1,2,3,4,5,6,7,8,9?

3.2大整数的乘法

对于两个十进制大整数NA和NB,设NA各个位上的数字如下:

an?1an?2?a1a0

而NB各个位上的数字如下:

bn?1bn?2?b1b0

另外记多项式

A?x??an?1xn?1?an?2xn?2???a1x?a0, B?x??bn?1xn?1?bn?2xn?2???b1x?b0

于是有NA?A?10?,NB?B?10?。

记大整数NC?NA?NB,多项式C?x??A?x??B?x?则有:

NC?NA?NB?A?10??B?10??C?10?

于是已知NA和NB,要得到NC,可以采用如下方法:

liner time an?1an?2?a1a0A?x??an?1xn?1?an?2xn?2???a1x?a0bn?1bn?2?b1b0 B?x??bn?1xn?1?bn?2xn?2???b1x?b0 time??? liner time c2n?2'c2n?3'?c1'c0' C?x??c2n?2x2n?2?c2n?3x2n?3???c1x?c0

于是,关键的问题是找到一个有效的算法以计算C?x??A?x??B?x?。可惜的

2?2??isin的,因此必nn须要进行三角函数之类的浮点运算,从而会有一定程度的误差。那么问题在于能否找到一个合适的方法来进行整系数多项式的乘法而没有任何的误差呢?据笔者所知,还没有一种十分合适的类似于FFT的针对于一般的整系数多项式的乘法。但是,大整数乘法中所要用到的多项式乘法十分特殊:即两个因子多项式中,每一个系数都不大于10. 因此下面所要找的, 就是对于这样一种特殊的整系数多项式的比较合适的乘法算法。

我们的工具是模-p的有限域。首先,如果我们在模-p的有限域上能够计算出:

是,传统的FFT算法是基于复数上的n次单位根?n?cosC'?x??A?x??B?x??modp?

即有ci'?ci?mop?,0?i?2n?2,又根据多项式乘法可以知道,dci?jk0?j,k?n?1,j?k?i?ab?0?j,k?n?1,j?k?i?9?9?0?j,k?n?1,j?k?i?81?81?n?1?,因此如果我们挑选一个足

够大的p使得p?81?n?1?,则可知ci?p,又有:ci'?p,ci'?ci?modp?,从而可知ci'?ci.

3.3关于p的选择

于是我们现在需要做的就是对于给定的一个数p,设计一个类似于FFT的算法,求出C'?x??A?x??B?x??modp?。我们可以将p的取值范围缩小一点,针对于p为素数,且p足够大(显然要大于2n-2)的情况来讨论。

这个任务其实就是要证明在模-p的域上的“n次单位根”具有与复数域上的n次单位根类似的性质。即证明模-p的域上的FFT算法是合法的。 【定理1】模-p乘法群是p-1阶循环群。

【证明】此定理等价于同余方程xp?1?1?modp?有p-1次本原单位根。这个定理的证明可以参考《数论概论》中关于模-p的本原根的内容。在一般的近世代数教材中也会有这一内容。■

由此,记m=p-1,于是可以找到一个次单位根?。由于p>>n,所以m=p-1>n.从而A(x)和B(x)都可以表示成m-1次多项式。

A????am?1?m?1???a1??a0

将此A?x?分成两部分:

A?x??2k?m?1?a2kx2??k?x2k?1?m?1?a2k?1x2??k?A1x2?xA2x2

????于是

A?x??A1x2?xA2x2,A??x??A1x2?xA2x2

由上式可知,要计算A?x?和A??x?,只需要先计算A1x2和A2x2,然后再做一次乘法、一次加法和一次减法即可,要计算k个自变量的函数,需要的时间是:

????????????T?k??2T?k/2????k????1?,

从而可得T?m??O?mlogm?。

由上面的式子可以看出,要想进行FFT变换,其关键在于对于n个自变量

?,?2,...,?m

求它们的函数的问题可以转化为求

?2,?4,...,?m

对于另外一些多项式的函数问题。

但是问题是在进行逆变换时必须要满足??k?0?modp?,根据等比数列公

k?1m???m?1?式????0?modp?,这样必有?m?1,也就是说,必须找到n次单位

??1k?1mk根。根据群论中的Lagrange定理,m|p-1,从而p-1必须精心选择,使得它包含较多的素因子2.

事实上,?必须满足两个条件:折半引理和求和引理。求和引理已经在上一段描述过了。折半引理指的是?i?m/2???i。因为只有这样我们才能够实施分治策略。

网络上有一种算法,是直接找出一个符合条件的大的素数p。这种方法有不完美之处:当n变得很大,超出了p的范围时,该算法就不适用了。当然,这种方法已经能够满足现实中的大部分需求了。而且由于是事先计算好的模-p的域,因而节省了大量的工作,其时间性能比较好。

我们的目的是寻找一种好的方法,使得该算法能够更容易地扩展,以适应任何长度的大整数。关于p为素数的情况,现在貌似也找不到一种好的方法来。

对于合数的情况,参见《基于快速傅立叶变换的大整数乘法研究》这篇论文。虽然其定理十分优美,但是没有实用性。因为它所选取的合数c对n成指数级。即c?2n?1。这样在做运算的时候就失去了大整数乘法的时间优势,相当于白费力。

本文来源:https://www.bwwdw.com/article/t6jf.html

Top