Die Monte-Carlo-Methode ist eine Methode zum Wiederholen von Versuchen unter Verwendung von Zufallszahlen. Es ist bekannt, dass es einen Weg gibt, das Umfangsverhältnis auf diese Weise zu finden, aber ... dachte ich plötzlich. ** Ist es wirklich genauer als die einfache Methode? ** ... Also lass uns tatsächlich experimentieren.
Stellen Sie sich ein 1 * 1-Quadrat vor und setzen Sie ein Viertel eines Kreises mit einem Radius von 1 ein. Verwenden Sie ** Zufallszahlen, um viele ** Punkte in diesem Quadrat zu erhalten. Sei * N * die Anzahl der platzierten Punkte. Wenn * N * groß genug ist, können Sie gleichmäßig punkten. Wenn von diesen Punkten die im Kreis enthaltenen Punkte als * A * gezählt werden, beträgt die Fläche des Quadrats 1 und die Fläche des Viertelkreises * π / 4 *.
Monte.java
import java.util.Random;
public class Monte {
public static void main(String[] args) {
for (int i = 0; i < 3 ; i++) {
monte();
}
}
public static void monte() {
Random r = new Random(System.currentTimeMillis());
int cnt = 0;
final int n = 400000000; //Anzahl von Versuchen
double x,y;
for (int i = 0; i < n; i++) {
x = r.nextDouble();
y = r.nextDouble();
//Ist dieser Punkt im Kreis?(Ist der Abstand vom Ursprung zum Punkt 1 oder geringer?)
if(x * x + y * y <= 1){
cnt++;
}
}
System.out.println((double)cnt / (double)n * 4D);
}
}
Stellen Sie sich ein 1 * 1-Quadrat vor und setzen Sie ein Viertel eines Kreises mit einem Radius von 1 ein. Machen Sie in diesem Quadrat viele ** gleichmäßig verteilte ** Punkte von Ende zu Ende. Sei * N * die Anzahl der platzierten Punkte. Wenn * N * groß genug ist, können Sie gleichmäßig punkten. (Auf einer Seite erscheinen Punkte mit nur der Quadratwurzel von * N *.) Wenn von diesen Punkten die im Kreis enthaltenen Punkte als * A * gezählt werden, beträgt die Fläche des Quadrats 1 und die Fläche des Viertelkreises * π / 4 *.
Grid.java
public class Grid {
public static void main(String[] args) {
int cnt = 0;
final int ns = 20000; //Quadratwurzel der Anzahl der Versuche
for (double x = 0; x < ns; x++) {
for (double y = 0; y < ns; y++) {
if(x / (double)(ns - 1) * x / (double)(ns - 1) +
y / (double)(ns - 1) * y / (double)(ns - 1) <= 1D){
cnt++;
}
}
}
System.out.println((double)cnt / ((double)ns * (double)ns) * 4D);
}
}
100 | 10000 | 1000000 | 100000000 | 400000000(Referenz) | |
---|---|---|---|---|---|
Erstes Mal | 3.16 | 3.1396 | 3.139172 | 3.14166432 | 3.14149576 |
Zweites Mal | 3.2 | 3.1472 | 3.1426 | 3.14173924 | 3.1414574 |
drittes Mal | 3.08 | 3.1436 | 3.142624 | 3.14167628 | 3.1415464 |
Ergebnis(Median) | 3.16 | 3.1436 | 3.1426 | 3.14167628 | 3.14149576 |
100(10^2) | 10000(100^2) | 1000000(1000^2) | 100000000(10000^2) | 400000000(Referenz)(20000^2) | |
---|---|---|---|---|---|
Monte-Carlo-Methode | 3.16 | 3.1436 | 3.1426 | 3.14167628 | 3.14149576 |
Leistungspferd(Gitter) | 2.92 | 3.1156 | 3.139156 | 3.141361 | 3.14147708 |
Idealer Wert | 3.1415926535 | 3.1415926535 | 3.1415926535 | 3.1415926535 | 3.1415926535 |
Fehlerrate(Monte)[%] | 0.568 | 0.064 | 0.032 | 0.003 | -0.003 |
Fehlerrate(Gitter)[%] | -7.054 | -0.827 | -0.078 | -0.007 | -0.004 |
(In meiner Umgebung wurde der Computer von ungefähr 100000000 schwer.) Solange die Anzahl der Versuche gering ist, kann gesagt werden, dass die Monte-Carlo-Methode genauer ist. Die Zunahme der Genauigkeit hat jedoch begonnen, von etwa 100000000 abzunehmen, und kann man sagen, dass dies der Berg von Seki mit Pseudozufallszahlen ist?
** Manchmal ist ein zufälliger Angriff besser als ein totaler Angriff! ** ** ** Es hängt von der Genauigkeit der verwendeten Pseudozufallszahl ab, aber es macht auch Spaß, Zufallszahlen zu verwenden. Es gibt jedoch Grenzen. Wenn Sie es also vollständig genau finden möchten, gibt es andere Methoden.
Recommended Posts