Pythonで学ぶ高校数学の美しい物語(ビュフォンの針)

※このサイトの記事内では広告を掲載している場合があります。

私は昔塾で数学を教えていました。

今回は、「ビュフォンの針」ということで、前回に引き続き確率論の内容で、とっても面白いです!楽しんで読んでください!

前回は、「モンテカルロ法」で円周率の近似値を求めました。
今回は、「ビュフォンの針」で円周率の近似値を求めていきます!

プログラミングスクールに関しては下の記事で詳しく記述しています。

こちらで紹介しているスクールは、すべて無料期間がある優良なスクールのみで、特徴を明確にし、読者のニーズに絞って丁寧に解説しました。初めての一歩として、無料説明会に参加してみてください。

ビュフォンの針とは

ビュフォンの針とは、18世紀の博物学者である、ジョルジュ=ルイ・ルクレール、コント・ド・ビュフォンが提起した数学上の問題です。

彼は、多数の平行線が描かれている床に針を落とすと、平行線と針が交わる確率は、円周率を使って表現できることを数学的に確立しました。この問題は、積分と幾何学を用いることで解けます。

適当に落とした針が平行線が交わる本数を数えることで確率が求まります。

昔の偉人は、コンピュータを使わずにビュフォンの実験を行っていたらしいです!

その結果がこちら!

ランキング名前投げた回数導いた円周率
1位ウルフ1800年代50003.1596
2位 ラッツァリーニ190134083.1415929
3位 スミス・ダベルディーン185532043.1553
4位 レイナ192525203.1795
5位 フォックス大尉186410303.1595

すでにかなり良い精度で近似値が得られていますが、今回は、もっと回数を多くするため、文明の利器を用いて10万回までシミュレーションしてきます!

円周率の求め方

理屈を知りたい方は、wikipedia高校数学の美しい物語を参照してください。

wikipedia は数式で理解したい人向け、高校数学の美しい物語は図も多く用いられているため理解しやすいと思います。

今回の記事で重要なのは、最終的な確率と積分によって求められた等式です。

  • 平行線の間隔:d
  • 針の長さ:l(エル)
  • すべての針の本数:N
  • 平行線と交わる針の本数:n

$$\frac{n}{N}=\frac{2l}{πd}(l \leq d)$$

$$\frac{n}{N}=\frac{2l}{πd}(1-\sqrt{1-\frac{d^{2}}{l^{2}}})+1-\frac{2}{π}\arcsin(\frac{d}{l})(l>d)$$

これらの式を「π」について解くと

$$π=\frac{2Nl}{nd}$$

$$π=\frac{2Nl}{d(n-N)}(1-\sqrt{1-\frac{d^{2}}{l^{2}}}-\arcsin(\frac{d}{l}))$$

プログラム作成

コメントでコードの解説をしていきます。

読みやすいコードを記述しているつもりですがわからなければコメントを残してくれると嬉しいです。

関数「Buffon」

関数「calc」

「math.sqrt」で平方根を求めることが出来ます。また、「math.asin」で「arcsin」の結果を返してくれます。

メイン関数

関数「Buffon」を呼び出します。

全体コード

最後にすべてをまとめたコードを載せます。コピペして実行してみると面白いです。

出力結果

ここでは、「d」= 50, 「l」= 25と固定して結果をまとめていきます。

まずは100本!

求まった「π」の近似値は、π: 3.3333333333333335でした。

次に1000本!

求まった「π」の近似値は、π: 3.2467532467532467でした。

先ほどよりも精度が良くなりました!

次に10000本!

求まった「π」の近似値は 、π: 3.1486146095717884でした。
すごいですね!ほぼ円周率です!

あと、この画面がかわいく見えてきます♡

次に100000本!

求まった「π」の近似値は 、π: 3.14564328405158874でした。
有刺鉄線みたいで面白いですねぇ~!

最後に100万本もやったのですが、僕の低スペックノートPCでは実行できませんでした笑。

ごめんポチ!

まとめ

今回は、ビュフォンの針で円周率の近似値を求めるプログラムを作成してみました。10万本で実行すると針がびっしり敷き詰められて、円周率の近似値が、確率と積分によって求められるのが直感的にわかりますね!

この考え方は、以前、「モンテカルロ法」でも円周率の近似値を求めていますのでもしよろしければそちらもご覧ください。

最後まで記事を読んでいただきありがとうございます!

昔、自分が参考にしていたプログラミングについての書籍を紹介します。
非常にわかりやすい内容で、言語は「Java」ですが参考にしてみてください!

プログラミングスクールに関しては下の記事で詳しく記述しています。

こちらで紹介しているスクールは、すべて無料期間がある優良なスクールのみで、特徴を明確にし、読者のニーズに絞って丁寧に解説しました。初めての一歩として、無料説明会に参加してみてください。

コメントを残す

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

CAPTCHA