Ich habe versucht, Python zu verwenden, um ein Skript zu erstellen, mit dem ich eine große Anzahl von Punkten generieren kann, die in der Monte-Carlo-Methode verwendet werden, um eine Schätzung für Pi zu berechnen. Das Skript, das ich bisher habe, ist das:
%Vor%Bisher kann ich alle benötigten Punkte generieren, aber die Anzahl der Punkte, die beim Ausführen des Skripts für eine spätere Berechnung ausgegeben werden, möchte ich gerne erhalten. Ich suche nicht nach unglaublich genauen Ergebnissen, nur eine gute Schätzung. Irgendwelche Vorschläge würden sehr geschätzt werden.
Wenn Sie irgendeine Art von numerischer Berechnung für hohe Belastungen durchführen, in Betracht ziehen, numpy
zu lernen. Ihr Problem ist im Wesentlichen ein ein-lineares mit einem ansatzlosen Setup:
Geben:
%Vor%Die letzte Zahl ist die Anzahl der gezählten Ereignisse, d. h. die Anzahl der Punkte, deren Radius kleiner als eins ist.
Nicht sicher, ob Sie das suchen, aber Sie können enumerate
auf range
ausführen und die Position in Ihrer Iteration abrufen:
In diesem Fall würde index + 1
den aktuellen Punkt darstellen, der gerade erstellt wird ( index
selbst wäre die Gesamtzahl der Punkte, die am Anfang einer gegebenen Iteration erstellt wurden). Auch wenn Sie Python 2.x verwenden, ist xrange
im Allgemeinen für diese Art von Iterationen besser, da es nicht die gesamte Liste in den Speicher lädt, sondern auf sie bei Bedarf zugreift.
Tags und Links python montecarlo