Warning: Undefined array key "lang" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
94
Warning: Undefined array key "id" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
117
Warning: Undefined array key "width" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
119
Warning: Undefined array key "dir" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
128
Warning: Undefined array key "lang" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
94
Warning: Undefined array key "id" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
117
Warning: Undefined array key "width" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
119
Warning: Undefined array key "dir" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
128
Warning: Undefined array key "lang" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
94
Warning: Undefined array key "id" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
117
Warning: Undefined array key "width" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
119
Warning: Undefined array key "dir" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
128
Warning: Undefined array key "lang" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
94
Warning: Undefined array key "id" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
117
Warning: Undefined array key "width" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
119
Warning: Undefined array key "dir" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
128
Warning: Undefined array key "lang" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
94
Warning: Undefined array key "id" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
117
Warning: Undefined array key "width" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
119
Warning: Undefined array key "dir" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
128
Warning: Undefined array key "lang" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
94
Warning: Undefined array key "id" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
117
Warning: Undefined array key "width" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
119
Warning: Undefined array key "dir" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
128
Warning: Undefined array key "lang" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
94
Warning: Undefined array key "id" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
117
Warning: Undefined array key "width" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
119
Warning: Undefined array key "dir" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
128
Warning: Undefined array key "lang" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
94
Warning: Undefined array key "id" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
117
Warning: Undefined array key "width" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
119
Warning: Undefined array key "dir" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
128
Warning: Undefined array key "lang" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
94
Warning: Undefined array key "id" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
117
Warning: Undefined array key "width" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
119
Warning: Undefined array key "dir" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
128
Warning: Undefined array key "lang" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
94
Warning: Undefined array key "id" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
117
Warning: Undefined array key "width" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
119
Warning: Undefined array key "dir" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
128
Warning: Undefined array key "lang" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
94
Warning: Undefined array key "id" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
117
Warning: Undefined array key "width" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
119
Warning: Undefined array key "dir" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
128
Warning: Undefined array key "lang" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
94
Warning: Undefined array key "id" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
117
Warning: Undefined array key "width" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
119
Warning: Undefined array key "dir" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
128
Warning: Undefined array key "lang" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
94
Warning: Undefined array key "id" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
117
Warning: Undefined array key "width" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
119
Warning: Undefined array key "dir" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
128
Warning: Undefined array key "lang" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
94
Warning: Undefined array key "id" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
117
Warning: Undefined array key "width" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
119
Warning: Undefined array key "dir" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
128
Warning: Undefined array key "lang" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
94
Warning: Undefined array key "id" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
117
Warning: Undefined array key "width" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
119
Warning: Undefined array key "dir" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
128
Warning: Undefined array key "lang" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
94
Warning: Undefined array key "id" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
117
Warning: Undefined array key "width" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
119
Warning: Undefined array key "dir" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
128
Warning: Undefined array key "lang" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
94
Warning: Undefined array key "id" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
117
Warning: Undefined array key "width" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
119
Warning: Undefined array key "dir" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
128
Warning: Undefined array key "lang" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
94
Warning: Undefined array key "id" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
117
Warning: Undefined array key "width" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
119
Warning: Undefined array key "dir" in
/home/signac/doku/lib/plugins/wrap/helper.php on line
128
📓 Ensemble de Julia et vectorisation
sol
Nous proposons ici de tracer des ensembles de Julia en noir et blanc, puis en couleur. Dans un premier
temps nous ferons un calcul non optimisé pour la vitesse, puis nous verrons comment vectoriser le calcul
en utilisant numpy
Références
Version monochrome
Rappels sur les ensembles de Julia
Notons tout d'abord qu'il existe plusieurs ensembles de Julia. Pour chaque nombre complexe $c$ choisi, il y a un ensemble. Nous noterons $J©$ l'ensemble des points du plan appartenant à l'ensemble de Julia paramétré par $c$.
L'ensemble de Julia $J©$ étant un ensemble de points du plan, nous pouvons le voir comme un ensemble de nombres complexes. Les nombres complexes appartenant à $J©$ sont les nombres $u_0$ tels que la suite :
$$\forall n>0, u_n=u_{n-1}^2+c$$
a un module qui reste fini.
Dans un premier temps, nous tracerons l'ensemble de Julia correspondant à $c=-0.85 + 0.2 i$. Il faut que cette valeur soit facile à modifier par la suite\ : gardez ceci à l'esprit tout au long de la construction du programme (car nous testerons d'autres valeurs).
On ne peut pas déterminer sur une machine si les termes de la suite précédente ont un module qui reste fini ou non en calculant simplement un grand nombre de termes. Il faudra donc faire quelques concessions à l'exactitude. Une bonne approximation consiste à calculer les 100 premiers termes de la suite et à utiliser cette propriété (valable si le module de c est strictement inférieur à 2) :
S'il existe $N$, entier, tel que le module de $u_N$ soit strictement plus grand que 2, alors la suite n'a pas un module qui reste fini.
Ainsi, si nous trouvons un terme de module supérieur à deux, nous pourrons conclure que le point n'est pas dans l'ensemble de Julia. Si au bout du 100ème terme, aucun n'a dépassé 2 en module, on conclura (parfois faussement) que le point est dans l'ensemble de Julia.
Première fonction
En vous aidant des indications données précédement, et de la manière de manipuler les nombres complexes en Python (voir [[stu:python:python_notes|Aide mémoire / Notes sur Python 3]]), écrivez une fonction julia(u,c)
qui indique en renvoyant 0 ou 1 si u
est dans ''J(c).
<code python >
def julia(u,c) :
“”“
Indique si le complexe u appartient (1)
ou non (0) à J©
”“”
pass
</code>
Testez votre fonction en comparant vos résultats avec ceux-ci, obtenus pour $c=-0.85+0.2i$ :
les 3 points : 0, 0.3j et 1 sont dans l'ensemble de Julia
les 2 points 0.3 et 1+j ne sont pas dans l'ensemble de Julia
Donnez un copié/collé des tests effectués.
==== Représentation de l'image ====
La première chose à décider est le nombre de points que nous allons calculer. Restons modestes dans un premier
temps, et calculons 200×200 pixels. Les valeurs de ces pixels (1 ou 0 selon qu'on est ou pas dans
l'ensemble de Julia) seront stockés dans une matrice numpy :
<code python>
import numpy as np
image = np.zeros1)