Deutsch   English   Français   Italiano  
<tb9tvi$beu$1@cabale.usenet-fr.net>

View for Bookmarking (what is this?)
Look up another Usenet article

Path: ...!weretis.net!feeder8.news.weretis.net!news.trigofacile.com!usenet-fr.net!.POSTED!not-for-mail
From: Olivier Miakinen <om+news@miakinen.net>
Newsgroups: fr.comp.lang.python,fr.sci.maths
Subject: =?UTF-8?Q?Re:_Python=2c_Turtle_et_=c3=a9toiles...?=
Followup-To: fr.sci.maths
Date: Thu, 21 Jul 2022 00:01:21 +0200
Organization: There's no cabale
Lines: 66
Message-ID: <tb9tvi$beu$1@cabale.usenet-fr.net>
References: <tb9fq4$1hc9$1@gioia.aioe.org>
NNTP-Posting-Host: 220.12.205.77.rev.sfr.net
Mime-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
X-Trace: cabale.usenet-fr.net 1658354482 11742 77.205.12.220 (20 Jul 2022 22:01:22 GMT)
X-Complaints-To: abuse@usenet-fr.net
NNTP-Posting-Date: Wed, 20 Jul 2022 22:01:22 +0000 (UTC)
User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101
 Firefox/52.0 SeaMonkey/2.49.4
In-Reply-To: <tb9fq4$1hc9$1@gioia.aioe.org>
Bytes: 3415

[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