Tracer une pyramide bigarrée - correction¶
Cet exercice est inspirée de l’article Les Fermes Miracle, un verger commercial de 5 acres inspiré de la permaculture dans le sud du Québec. Il s’agit de dessiner un motif. Correction.
[10]:
%matplotlib inline
Problème¶
Il s’agit de dessiner la pyramide suivante à l’aide de matplotlib.
[2]:
from IPython.display import Image
Image("biodiversite_tri2.png")
[2]:
data:image/s3,"s3://crabby-images/f70ad/f70adc643f6160f8f3dbb28380e493719710afe9" alt="../../_images/practice_tds-base_pyramide_bigarree_correction_3_0.png"
Idée de la solution¶
On sépare le problème en deux plus petits :
Trouver la position des boules dans un repère cartésien.
Choisir la bonne couleur.
Le repère est hexagonal. L’image suivante est tirée de la page wikipédia empilement compact.
[12]:
Image("hexa.png")
[12]:
data:image/s3,"s3://crabby-images/87bfd/87bfd7cdb7cc3ad50523396a331f797e11d8dfb9" alt="../../_images/practice_tds-base_pyramide_bigarree_correction_5_0.png"
Mais dans un premier temps, il faut un moyen de repérer chaque boule. On les numérote avec deux indices.
[3]:
Image("pyramide_num2.png")
[3]:
data:image/s3,"s3://crabby-images/24511/24511d0d904d625731be3728a4481396ca36600d" alt="../../_images/practice_tds-base_pyramide_bigarree_correction_7_0.png"
Les coordonnées¶
On prend comme exemple scatter_demo.py sur le site de matplotlib.
[14]:
import matplotlib.pyplot as plt
fig, ax = plt.subplots(1, 1)
n = 10
x = []
y = []
for i in range(1, n + 1):
for j in range(i, n + 1):
x.append(i)
y.append(j)
size = [300 for c in x]
colors = ["r" for c in x]
ax.scatter(x, y, s=size, c=colors, alpha=0.5);
data:image/s3,"s3://crabby-images/a7df0/a7df01e064f698c6e8dfd9c757f548a8ee249e47" alt="../../_images/practice_tds-base_pyramide_bigarree_correction_9_0.png"
On inverse.
[15]:
fig, ax = plt.subplots(1, 1)
n = 10
x = []
y = []
for i in range(1, n + 1):
for j in range(i, n + 1):
x.append(i)
y.append(-j)
size = [300 for c in x]
colors = ["r" for c in x]
ax.scatter(x, y, s=size, c=colors, alpha=0.5);
data:image/s3,"s3://crabby-images/cf8b7/cf8b766c46be9eee76122f4cab813fe0b42ab9c4" alt="../../_images/practice_tds-base_pyramide_bigarree_correction_11_0.png"
On décale.
[16]:
fig, ax = plt.subplots(1, 1)
n = 10
x = []
y = []
for i in range(1, n + 1):
for j in range(i, n + 1):
x.append(i - j * 0.5)
y.append(-j)
size = [300 for c in x]
colors = ["r" for c in x]
ax.scatter(x, y, s=size, c=colors, alpha=0.5);
data:image/s3,"s3://crabby-images/58300/583000b2ab8a834f2f0e2bfdc2a78aeaad269bf5" alt="../../_images/practice_tds-base_pyramide_bigarree_correction_13_0.png"
Cela ressemble à de l’hexagonal mais ce n’est pas encore tout à fait cela. La hauteur d’un triangle équilatéral de côté un est . Ca tombe bien car dans l’exemple précédente, le côté de chaque triangle est 1. Et on change la dimension du graphe tracé avec matplotlib pour éviter de réduire nos effort à néant.
[17]:
fig, ax = plt.subplots(1, 1, figsize=(4, 4 * (3**0.5) / 2))
n = 10
x = []
y = []
for i in range(1, n + 1):
for j in range(i, n + 1):
x.append(i - j * 0.5)
y.append(-j * (3**0.5) / 2)
size = [300 for c in x]
colors = ["r" for c in x]
ax.scatter(x, y, s=size, c=colors, alpha=0.5);
data:image/s3,"s3://crabby-images/0d952/0d9529aea1df823e3aaea80c8871decc710ab84b" alt="../../_images/practice_tds-base_pyramide_bigarree_correction_15_0.png"
La couleur¶
Je vous laisse retourner sur les deux premières images et observer la couleur de toutes les boules qui vérifient (i+j)%3 == 1
.
[18]:
fig, ax = plt.subplots(1, 1, figsize=(4, 4 * (3**0.5) / 2))
n = 10
x = []
y = []
colors = []
trois = "rgb"
for i in range(1, n + 1):
for j in range(i, n + 1):
x.append(i - j * 0.5)
y.append(-j * (3**0.5) / 2)
colors.append(trois[(i + j) % 3])
size = [300 for c in x]
ax.scatter(x, y, s=size, c=colors, alpha=0.5);
data:image/s3,"s3://crabby-images/de0b3/de0b399475891c5fdbc80bec57bf8a76c7fb662a" alt="../../_images/practice_tds-base_pyramide_bigarree_correction_17_0.png"
[ ]: