Groups | Search | Server Info | Keyboard shortcuts | Login | Register [http] [https] [nntp] [nntps]


Groups > fr.comp.lang.python > #3907

Re: Python, Turtle et étoiles...

From Olivier Miakinen <om+news@miakinen.net>
Newsgroups fr.comp.lang.python, fr.sci.maths
Subject Re: Python, Turtle et étoiles...
Followup-To fr.sci.maths
Date 2022-07-21 00:01 +0200
Organization There's no cabale
Message-ID <tb9tvi$beu$1@cabale.usenet-fr.net> (permalink)
References <tb9fq4$1hc9$1@gioia.aioe.org>

Cross-posted to 2 groups.

Followups directed to: fr.sci.maths

Show all headers | View raw


[diapublication, copie et suivi vers fr.sci.maths]

Bonsoir,

Le 20/07/2022 19:59, Dominique a écrit :
> 
> Je me suis amusé à écrire un script assez simple qui dessine des étoiles 
> avec Turtle :
> 
> from turtle import *
> #speed(0)
> nb=int(input('Itérations '))
> ang=float(input('Angle à gauche '))
> for x in range (nb):
>      forward(300)
>      right(ang+180)
> 
> Avec 5 itérations et une rotation à droite de 216° (180°+36°),

C'est-à-dire une rotation à gauche de 144° (180°−36°)

> j'obtiens 
> bien un pentagramme. C'est assez simple, parce qu'on est là sur des 
> triangles d'or.
> 
> Si je passe à 20 itérations et des rotations à droite de 198°(180° + 
> 18°),

Du coup des rotations à gauche de 162°.

> j’obtiens quelque chose d’intéressant.
> 
> Ce que je ne sais pas, c’est comment m’assurer que mon étoile est bien 
> exacte, c’est à dire que le curseur revient exactement à son point de 
> départ. La précision de Python est suffisamment élevée pour donner 
> l’impression de l’exactitude.
> 
> Existe-t-il une formule qui permet, à partir du nombre de branche qu’on 
> veut obtenir, de connaître l’angle de rotation du curseur ? Mes 
> connaissances en géométrie trébuchent...

Déjà, pour que ça finisse par tomber juste, il suffit que l'angle soit un
multiple rationnel d'un tour complet, soit 2pi ou 360°. En degrés, vu que
360 est un nombre entier, il suffit que l'angle soit rationnel.

Mais on peut faire mieux, et savoir au bout de combien d'itérations on
revient au point de départ pour la première fois. Soit (p/q)×360° l'angle
choisi. Si p et q sont premiers entre eux, alors il faudra exactement q
itérations pour que l'angle soit p×360°, soit 0° modulo 360°.

Par ailleurs, pour qu'une rotation « à droite » ne se transforme pas en
rotation à gauche, il suffit de choisir p et q de sorte que 0 < p < q/2.

Enfin, si tu veux des polygones étoilés et pas de bêtes polygones
convexes, il suffit de choisir p > 1, donc 2 ≤ p < q/2.

Reprenons tes exemples. Ta rotation à droite de 216°, c'est (3/5)×360° (ou
(2/5)×360° si tu choisis l'angle le plus petit). Il faut donc 5 itérations.
Quant à ta rotation de 198°, c'est (11/20)×360° ou (9/20)×360°, donc 20
itérations.

[suivi vers fr.sci.maths pour avoir d'autres avis]


-- 
Olivier Miakinen

Back to fr.comp.lang.python | Previous | NextPrevious in thread | Find similar


Thread

Python, Turtle et étoiles... Dominique <zzz@aol.com> - 2022-07-20 19:59 +0200
  Re: Python, Turtle et étoiles... Olivier Miakinen <om+news@miakinen.net> - 2022-07-21 00:01 +0200

csiph-web