做客中文网

第19章 你们的超算是不是不太行啊(第1页)

天才一秒记住【做客中文网】地址:https://www.zk01.net

当然,尽管是确定了阅读顺序,林枫也没有马上开始。

任何星辰大海那都是遥远的梦想,想要追求遥远的梦想这没什么。

但前提是要在此之前不需要为物质而烦恼。

想想那令人压抑的信用卡账单,林枫就一个头两大。

林枫现在还得为物质奔波。

「去码头整点薯条jpg」林枫记得当时加州大学洛杉矶分校高性能计算实验室可是在第一时间表示他们已经安排超算集群开始验证2-1和2-1是否是梅森素数了。

怎么这么久还没出结果呢?虽然说漫无目的地去寻找梅森素数挺困难的。

但要通过超级计算机验证一个数是不是梅森素数还真不费劲。

一般来说,要验证2-1是否是素数。

直接计算出这个数并检查它是否有其他因数是最容易想到的思路。

但这明显不可行。

像是2-1这种超大数的位数太多,如果暴力因式分解挨个试肯定无法在合理的时间内完成。

不过也不是毫无办法。

卢卡斯-莱默测试可以有效简化这个过程。

在借助这个方法的情况下完全通过递归迭代序列验证是否满足特定条件。

具体步骤也不复杂。

此前在写论文的时候林枫还特别了解过这方面。

先是初始化设s_0=4,而后递归:计算s_(n+1)=s_(n2-2)模2p-1,运算从n=1开始,直到n=p-2为止。

如果最终结果s_(p-2)是0,那么2p-1就是一个素数;否则它不是素数。

听起来依旧是有点麻烦的。

但对于超级计算机来说这完全是小儿科好不好。

而且由于卢卡斯-莱默测试的复杂度是线性时间复杂度,即o(p),这意味着计算的时间与p成正比。

对于2-1来说,只需要执行次循环,每次计算一个模运算。

卢卡斯-莱默测试每次迭代中包含的运算量比较复杂,涉及到大整数的平方和模运算。

不过估算的话也不是没办法。

可以粗略假设每次迭代进行模运算需要进行约106次计算。

这样计算的话,总的计算次数是:106约等于7421013次计算。

如果计算机每秒可以执行1015次计算。

则总时间为00742秒。

理论上,一台超级计算机可以在不到01秒的时间内验证2-1是否是一个梅森素数。

本章未完,请点击下一章继续阅读!若浏览器显示没有新章节了,请尝试点击右上角↗️或右下角↘️的菜单,退出阅读模式即可,谢谢!

如遇章节错误,请点击报错(无需登陆)

新书推荐

修仙从星际开始恶魔公寓书生有种一切从宝芝林开始气运被夺,真千金玄术炸翻娱乐圈囤货重生,娇知青在七零被糙汉宠爆了仙傲我的亮剑生涯我的姐夫是太子老祖出棺1825我的新大明吞噬星空之黑龙传说我在春秋不当王超凡大卫绝色魔妃倾天下将夜圣墟无尽剑装武道成圣:从皇家禁地开始帝枭盛宠:总统大人买一送二网游开局契约生命之树全职高手之世邀赛同人我在末世有套房星际穿越:位面女王专治不服我们的家族没落了