写了一个BBP算法的实现库,欢迎讨论

BBP 算法可以直接计算 π 的第 n 个十六进制数字,而无需计算前面的所有数字。

我的仓库:https://github.com/davelet/bbp


先来说说π这个老朋友吧。π,3.14159......,数学界的"网红",从古希腊的阿基米德开始,就有无数人试图用它丈量圆的秘密。为什么这么迷人?因为它是个无理数,十进制小数点后无限不循环,藏着无穷的奥秘。想象一下,你想知道π的第1000位是什么?传统方法呢?得从头算起,一位一位啃,像啃一根永不完的甘蔗,累不累啊?早年的数学家们用多边形逼近法,或者级数展开,比如莱布尼茨公式:π/4 = 1 - 1/3 + 1/5 - 1/7 + ...... 收敛得慢,算到几百位就得花好几天机时。更别提现代超级计算机了,算到万亿位也得从头来过。

不过1995年,一切都变了。那一年,加拿大数学家 Simon Plouffe 在玩一个叫PSLQ的整数关系发现算法时,意外挖到了金矿。他和 David Bailey、Jonathan Borwein 合作,发表了BBP公式(Bailey-Borwein-Plouffe公式)。

这公式一出,数学圈炸锅了!为什么?因为它允许你直接计算π的任意一位十六进制数字,而不用管前面的那些。

十六进制?对,就是我们电脑里常见的0-9和A-F那种。为什么用十六进制?因为公式设计得特别巧妙,和二进制、十六进制兼容,计算起来高效。

Plouffe当时用一台普通的电脑,就算出了π的第100万位------不是从头算,而是直奔那里!这感觉就像科幻小说里的"传送门",啪的一声,你就到目的地了。


我在仓库里提供了算法和项目的说明,欢迎大家讨论:README 读我

相关推荐
echoarts7 小时前
Rayon Rust中的数据并行库入门教程
开发语言·其他·算法·rust
ftpeak16 小时前
从零开始使用 axum-server 构建 HTTP/HTTPS 服务
网络·http·https·rust·web·web app
咸甜适中17 小时前
rust语言 (1.88) 学习笔记:客户端和服务器端同在一个项目中
笔记·学习·rust
救救孩子把21 小时前
2-机器学习与大模型开发数学教程-第0章 预备知识-0-2 数列与级数(收敛性、幂级数)
人工智能·数学·机器学习
咸甜适中21 小时前
rust语言 (1.88) egui (0.32.2) 学习笔记(逐行注释)(二十八)使用图片控件显示图片
笔记·学习·rust·egui
huli33201 天前
pingora_web:首款基于 Cloudflare Pingora 的企业级 Rust Web 框架
rust
Pomelo_刘金1 天前
如何优雅地抽离 Rust 子工程:以 rumqttd 为例
rust
几颗流星1 天前
Rust 常用语法速记 - 错误处理
后端·rust
向上的车轮1 天前
如何用 Rust 重写 SQLite 数据库(二):是否有市场空间?
数据库·rust·sqlite