百科问答小站 logo
百科问答小站 font logo



如何看待O(n log n)时间的整数乘法算法? 第1页

  

user avatar   Gh0u1L5 网友的相关建议: 
      

怎么看?跪着看呗。不过这次的结果虽然令人五体投地,但对工业界来说影响不一定会很大。

早在1971年,整数乘法的时间复杂度就已经被德国数学家推到 了,也就是著名的Schönhage–Strassen算法。其基本原理是

  1. 对两个长度为n的大整数分别做一次环上的FFT,转换为频域分布。
  2. 对两个整数的频域分布做pointwise multiplication,得到乘积的频域分布。
  3. 对乘积的频域分布做一次环上的IFFT,由此得到乘积。

而这次的新算法,姑且叫Harvey-van der Hoeven算法吧,是在原本的Schönhage–Strassen算法上做了一次改进。原本的算法是在一个一维的一元多项式环上完成的,两位大佬发现如果把问题转换到多元多项式环上面的话,同样的计算就可以更加高效地完成。

于是在这篇论文里,两位大佬先是花了1.2.1和1.2.2两节讨论了如何把整数乘法从一维多项式环拓展到高维,然后在2、3、4节里讨论了高维多项式环的相关运算,最后第5节证了一个时间复杂度,功成名就,圆满收工。


那么,我为什么说这次的新算法对工业界影响有限呢?因为在新算法之前,已经有不少Schönhage–Strassen算法的优化算法了,目前最快的时间复杂度是 。这个 是个什么概念呢?是说哪怕你的整数长度为 位, 也仅仅只有256而已。

而新算法在加速的同时,还引入了不少额外的开销(高维多项式环的转换、存取、计算等)。论文里面证明环的维度需要达到 ,时间复杂度才会收敛在 上。那么这个算法实际落地之后,可能只有在运算一些没有实用价值的天文数字时才能超越现有的算法。

因此,在这个算法落地之前,我们暂时还没法保证它一定是某种解决问题的灵丹妙药,只能先保持观望态度了。


user avatar   hqztrue 网友的相关建议: 
      

因为intel换酷睿系列商标了:


user avatar    网友的相关建议: 
      

因为intel换酷睿系列商标了:




  

相关话题

  N 个乒乓球中有一个和其他的质量不同,用天平最少几次一定能称出来? 
  有一个三位数密码锁,如果输入的三位密码有1位是正确的,就会嘀一声响,请问最少要输入几次才一定能开锁? 
  世界上大约有多少人可以完全看懂并理解怀尔斯对于费马大定理的证明? 
  如何理解算法时间复杂度的表示法,例如 O(n²)、O(n)、O(1)、O(nlogn) 等? 
  黎曼 ζ 函数为什么要那么解析延拓? 
  是否存在时间复杂度是O(tan N)的算法? 
  如何证明方程 x³+y³=2020 没有整数解? 
  刷完算法导论和leetcode,能找到什么水平的工作? 
  有哪些手算对数的方法? 
  如果我有一个函数 f(x) 表示第 x 个素数有什么用? 

前一个讨论
Spring是否代表着目前Java技术的顶峰,未来的Java将如何发展?
下一个讨论
假如《红楼梦》流传下来的只有70回而不是80回,那么红学探佚会有什么变化?





© 2025-01-05 - tinynew.org. All Rights Reserved.
© 2025-01-05 - tinynew.org. 保留所有权利