柔道の背負い投げは、
この背負い投げのコツを、
今回は、
data:image/s3,"s3://crabby-images/fa6af/fa6af2c4a6388f2e5a0cd0fb6eb121579a71c0a3" alt="図54.1 同じ技でも千差万別 図54.1 同じ技でも千差万別"
連続事象
コインやさいころのように、
data:image/s3,"s3://crabby-images/924f0/924f0ec90d0486d502f699d6f6082feb10f05084" alt="図54.2 連続事象とは 図54.2 連続事象とは"
一様分布
最も簡単な連続事象の確率分布の例として、の紙テープを屋外に水平一直線に渡します。雨が降ってきたとき、
に雨粒が落ちる個数は、
の長さに比例します。このとき、
のテープに落ちる雨粒のうち、
の区間に落ちる雨粒の確率
は次の式で表されます。
data:image/s3,"s3://crabby-images/773af/773afdc3b30a5e8e6c459bf47758c2b0363bc7d3" alt=""
data:image/s3,"s3://crabby-images/fee2c/fee2ce23b64d3968727b8a8f4098cf392c395849" alt="図54.3 一様分布の例 図54.3 一様分布の例"
モンテカルロ法
一様分布の連続事象をうまく利用した例にモンテカルロ法で円周率の値を求める方法があります。モンテカルロ法
正方形にぴったり内接する円をとります。この図形を屋外において、
円の中に落ちた雨粒の数と正方形の中に落ちた雨粒の全ての数の比は、
data:image/s3,"s3://crabby-images/4a298/4a2981c5e0a91e8abbafdbaf0a08250f84cb0613" alt="図54.4 モンテカルロ法で円周率を求める 図54.4 モンテカルロ法で円周率を求める"
data:image/s3,"s3://crabby-images/3e25e/3e25eb0626d607c6bf2865783b69bc89e8c40395" alt=""
ただし、は正方形の一辺の長さであると同時に、
ここで、、
data:image/s3,"s3://crabby-images/c3851/c3851947f9451f851f6579c430e4606d9e242eff" alt=""
なんともシンプルな形となりました。式53.
問題 モンテカルロ法で円周率を求めましょう。
大変シンプルな問題ですから、
解説
問題 モンテカルロ法で円周率を求めましょう
コードを簡単にするために、
data:image/s3,"s3://crabby-images/0b758/0b75881dda1d328683e9f10b6164cce4aa5e9625" alt="図54.5 4分の1円でモンテカルロ法 図54.5 4分の1円でモンテカルロ法"
このように問題を読みかえても、
data:image/s3,"s3://crabby-images/4b4b2/4b4b28cc6f8e8988ec8fdff889c4702a46ae2954" alt=""
/*
問題 モンテカルロ法で円周率を求めましょう。
filename : Sample_MC.java
uses : Dice.class
*/
class Sample_MC {
public static void main(String[] args) {
int trial = 1000000; //試行回数
//Dice クラスを使った場合
int r = 1000; //円の半径
Dice dx = new Dice(r); //x 軸用ダイス
Dice dy = new Dice(r); //y 軸用ダイス
int hit = 0; //円の中の雨粒
double MC_Pi = 0.0; //円周率値
//Math.random を使った場合
int hit2 = 0; //円の中の雨粒
double MC_Pi2 = 0.0; //円周率値
//---------------------------------
System.out.println("モンテカルロ法"
+trial+"個雨粒を落とす。");
for (int i=0; i<trial; ++i){
if ( Math.pow(dx.roll(1),2)
+ Math.pow(dy.roll(1),2)
<= Math.pow(r,2) ) ++hit;
if ( Math.pow(Math.random(),2)
+ Math.pow(Math.random(),2)
<= 1 ) ++hit2;
if ( i % (trial/10) == 0 )
System.out.print("*");
}
System.out.println();
MC_Pi = (double) hit / trial * 4;
MC_Pi2 = (double) hit2 / trial * 4;
System.out.println("<試行結果>");
System.out.println("Dice クラス使用π="+MC_Pi);
System.out.println("Math クラス使用π="+MC_Pi2);
}// end of main
}// end of class Sample_MC
サンプルコードの実行結果を示します。
C:\>java Sample_MC
モンテカルロ法1000000 個雨粒を落とす。
**********
<試行結果>
Dice クラス使用π = 3.134884
Math クラス使用π = 3.140752
Mathクラスを使った方が若干精度が良いのは、
今回はここまで
今回は、