mirror of
https://app-learninglab.inria.fr/moocrr/gitlab/da84ababf0696af51bddad556af86353/mooc-rr.git
synced 2026-06-21 19:45:24 +02:00
Module 2 Exo1 fichier python
This commit is contained in:
parent
8040791174
commit
2bb9a3d867
1 changed files with 51 additions and 68 deletions
|
|
@ -1,4 +1,4 @@
|
||||||
#+TITLE: Le Toy Document
|
#+TITLE: À propos du calcul de \pi
|
||||||
#+AUTHOR: Louis Lacoste
|
#+AUTHOR: Louis Lacoste
|
||||||
#+DATE: 2022-11-17
|
#+DATE: 2022-11-17
|
||||||
#+LANGUAGE: fr
|
#+LANGUAGE: fr
|
||||||
|
|
@ -11,83 +11,66 @@
|
||||||
#+HTML_HEAD: <script type="text/javascript" src="http://www.pirilampo.org/styles/lib/js/jquery.stickytableheaders.js"></script>
|
#+HTML_HEAD: <script type="text/javascript" src="http://www.pirilampo.org/styles/lib/js/jquery.stickytableheaders.js"></script>
|
||||||
#+HTML_HEAD: <script type="text/javascript" src="http://www.pirilampo.org/styles/readtheorg/js/readtheorg.js"></script>
|
#+HTML_HEAD: <script type="text/javascript" src="http://www.pirilampo.org/styles/readtheorg/js/readtheorg.js"></script>
|
||||||
|
|
||||||
* Quelques explications
|
* En demandant à la lib maths
|
||||||
|
Mon ordinateur m'indique que \pi vaut /approximativement/:
|
||||||
Ceci est un document org-mode avec quelques exemples de code
|
|
||||||
python. Une fois ouvert dans emacs, ce document peut aisément être
|
|
||||||
exporté au format HTML, PDF, et Office. Pour plus de détails sur
|
|
||||||
org-mode vous pouvez consulter https://orgmode.org/guide/.
|
|
||||||
|
|
||||||
Lorsque vous utiliserez le raccourci =C-c C-e h o=, ce document sera
|
|
||||||
compilé en html. Tout le code contenu sera ré-exécuté, les résultats
|
|
||||||
récupérés et inclus dans un document final. Si vous ne souhaitez pas
|
|
||||||
ré-exécuter tout le code à chaque fois, il vous suffit de supprimer
|
|
||||||
le # et l'espace qui sont devant le ~#+PROPERTY:~ au début de ce
|
|
||||||
document.
|
|
||||||
|
|
||||||
Comme nous vous l'avons montré dans la vidéo, on inclue du code
|
|
||||||
python de la façon suivante (et on l'exécute en faisant ~C-c C-c~):
|
|
||||||
|
|
||||||
#+begin_src python :results output :exports both
|
|
||||||
print("Hello world!")
|
|
||||||
#+end_src
|
|
||||||
|
|
||||||
#+RESULTS:
|
|
||||||
: Hello world!
|
|
||||||
|
|
||||||
Voici la même chose, mais avec une session python, donc une
|
|
||||||
persistance d'un bloc à l'autre (et on l'exécute toujours en faisant
|
|
||||||
~C-c C-c~).
|
|
||||||
#+begin_src python :results output :session :exports both
|
#+begin_src python :results output :session :exports both
|
||||||
import numpy
|
from math import *
|
||||||
x=numpy.linspace(-15,15)
|
print(pi)
|
||||||
print(x)
|
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
#+RESULTS:
|
#+RESULTS:
|
||||||
#+begin_example
|
: 3.141592653589793
|
||||||
[-15. -14.3877551 -13.7755102 -13.16326531 -12.55102041
|
|
||||||
-11.93877551 -11.32653061 -10.71428571 -10.10204082 -9.48979592
|
|
||||||
-8.87755102 -8.26530612 -7.65306122 -7.04081633 -6.42857143
|
|
||||||
-5.81632653 -5.20408163 -4.59183673 -3.97959184 -3.36734694
|
|
||||||
-2.75510204 -2.14285714 -1.53061224 -0.91836735 -0.30612245
|
|
||||||
0.30612245 0.91836735 1.53061224 2.14285714 2.75510204
|
|
||||||
3.36734694 3.97959184 4.59183673 5.20408163 5.81632653
|
|
||||||
6.42857143 7.04081633 7.65306122 8.26530612 8.87755102
|
|
||||||
9.48979592 10.10204082 10.71428571 11.32653061 11.93877551
|
|
||||||
12.55102041 13.16326531 13.7755102 14.3877551 15. ]
|
|
||||||
#+end_example
|
|
||||||
|
|
||||||
Et enfin, voici un exemple de sortie graphique:
|
* En utilisant la méthode des aiguilles de Buffon
|
||||||
#+begin_src python :results output file :session :var matplot_lib_filename="./cosxsx.png" :exports results
|
Mais calculé avec la *méthode* des [[https://fr.wikipedia.org/wiki/Aiguille_de_Buffon][aiguilles de Buffon]], on obtiendrait
|
||||||
|
comme *approximation* :
|
||||||
|
#+begin_src python :results output :session :exports both
|
||||||
|
import numpy as np
|
||||||
|
np.random.seed(seed=42)
|
||||||
|
N = 10000
|
||||||
|
x = np.random.uniform(size=N, low=0, high=1)
|
||||||
|
theta = np.random.uniform(size=N, low=0, high=pi/2)
|
||||||
|
print(2/(sum((x+np.sin(theta))>1)/N))
|
||||||
|
#+end_src
|
||||||
|
|
||||||
|
#+RESULTS:
|
||||||
|
: 3.128911138923655
|
||||||
|
|
||||||
|
* Avec un argument "fréquentiel" de surface
|
||||||
|
Sinon, une méthode plus simplé à comprendre et ne faisant pas
|
||||||
|
intervenir d'appel à la fonction sinus se base sur le fait que si $X \sim
|
||||||
|
U(0,1)$ et $Y \sim U(0,1)$ alors $P[X^2+Y^2 \leq 1] = \pi / 4$ (voir
|
||||||
|
[[https://fr.wikipedia.org/wiki/M%C3%A9thode_de_Monte-Carlo#D%C3%A9termination_de_la_valeur_de_%CF%80][méthode de Monte Carlo sur Wikipedia]]). Le code suivant illustre ce
|
||||||
|
fait :
|
||||||
|
#+begin_src python :results output :session :exports both
|
||||||
import matplotlib.pyplot as plt
|
import matplotlib.pyplot as plt
|
||||||
|
|
||||||
plt.figure(figsize=(10,5))
|
np.random.seed(seed=42)
|
||||||
plt.plot(x,numpy.cos(x)/x)
|
N = 1000
|
||||||
plt.tight_layout()
|
x = np.random.uniform(size=N, low=0, high=1)
|
||||||
|
y = np.random.uniform(size=N, low=0, high=1)
|
||||||
|
|
||||||
plt.savefig(matplot_lib_filename)
|
accept = (x*x+y*y) <= 1
|
||||||
print(matplot_lib_filename)
|
reject = np.logical_not(accept)
|
||||||
|
|
||||||
|
fig, ax = plt.subplots(1)
|
||||||
|
ax.scatter(x[accept], y[accept], c='b', alpha=0.2, edgecolor=None)
|
||||||
|
ax.scatter(x[reject], y[reject], c='r', alpha=0.2, edgecolor=None)
|
||||||
|
ax.set_aspect('equal')
|
||||||
|
|
||||||
|
plt.savefig('montecarlo.png')
|
||||||
|
print('file:'+'montecarlo.png')
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
#+RESULTS:
|
#+RESULTS:
|
||||||
[[file:./cosxsx.png]]
|
: file:montecarlo.png
|
||||||
|
file:montecarlo.png
|
||||||
|
|
||||||
Vous remarquerez le paramètre ~:exports results~ qui indique que le code
|
Il est alors aisé d'obtenir une approximation (pas terrible) de \pi en
|
||||||
ne doit pas apparaître dans la version finale du document. Nous vous
|
comptant combien de fois, en moyenne, $X^2+Y^2$ est inférieur à 1 :
|
||||||
recommandons dans le cadre de ce MOOC de ne pas changer ce paramètre
|
#+begin_src python :results output :session :exports both
|
||||||
(indiquer ~both~) car l'objectif est que vos analyses de données soient
|
4*np.mean(accept)
|
||||||
parfaitement transparentes pour être reproductibles.
|
#+end_src
|
||||||
|
|
||||||
Attention, la figure ainsi générée n'est pas stockée dans le document
|
#+RESULTS:
|
||||||
org. C'est un fichier ordinaire, ici nommé ~cosxsx.png~. N'oubliez pas
|
: 3.112
|
||||||
de le committer si vous voulez que votre analyse soit lisible et
|
|
||||||
compréhensible sur GitLab.
|
|
||||||
|
|
||||||
Enfin, n'oubliez pas que nous vous fournissons dans les ressources de
|
|
||||||
ce MOOC une configuration avec un certain nombre de raccourcis
|
|
||||||
claviers permettant de créer rapidement les blocs de code python (en
|
|
||||||
faisant ~<p~, ~<P~ ou ~<PP~ suivi de ~Tab~).
|
|
||||||
|
|
||||||
Maintenant, à vous de jouer! Vous pouvez effacer toutes ces
|
|
||||||
informations et les remplacer par votre document computationnel.
|
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue