La suite de Syracuse
Enoncé de la conjecture - Idées de programmation - Calculer les termes de la suite de Syracuse - Records
Commentaires sur la conjecture de Collatz
Le problème 3x+1 ou la conjecture de Syracuse ou de Collatz (nom de mathématiciens qui l'a le plus répandu) est d'une étonnante simplicité, mais elle résiste pourtant au effort des mathématiciens à la démontrer (ou pas) depuis le milieu du 20 siècle, c'est en cela que son énoncé reste une conjecture, elle reste. Cette conjecture est apparue vers 1930 et c'est répandu vers 1950 grâce notamment à l'université de Syracuse d'où le nom. Le nom, mais aussi les noms qui sont nombreux : conjecture de Collatz, conjecture de Syracuse ou problème de 3x+1.
La suite de syracuse de Collatz ( Lothar Collatz )
On choisir un nombre entier :
- Si le nombre est pair, on le divise par 2 et on obtient le terme suivant de la suite.
- Si le nombre est impair, on le multiplie par 3, on ajoute 1 au résultat et on obtient le terme suivant de la suite.
On recommence la procédure avec le nouveau nombre obtenu.
On obtient une suite de nombres qui est appelée :
- le vol du nombre de départ,
- les nombres de la suite sont appelés les étapes du vol,
- le plus grand nombre obtenu dans la suite est appelé l'altitude maximale du vol,
- le nombre d'étapes avant de passer sous le nombre de départ est appelé la durée du vol en altitude,
- le nombre d'étapes avant d'obtenir 1 est appelé la durée du vol.
Une fois atteint le nombre 1, la suite des valeurs (1,4,2,1,4,2…) se répète indéfiniment en un cycle de longueur 3, appelé cycle trivial.
Nous pouvons définir la suite sous la forme qui suit, pour tout entier n > 1 :

Conjecture de Syracuse :
Quel que soit le nombre de départ dans la suite obtenue avec l'algorithme de Syracuse de Collatz, on finit toujours par obtenir 1.
Mais, pour le moment cela reste une conjecture et aucune preuve (démonstration) n'a été établi à ce jour .
Les avancés
(ce qui est démontré à ce jour nov 2011)
La conjecture de Syracuse est équivalente à l’un des énoncés suivants :
(1) la durée de tout vol est finie ;
(2) la durée de tout vol en altitude est finie ;
(3) tout vol a un nombre fini d’étapes paires ;
(4) tout vol a un nombre fini d’étapes paires en altitude ;
(5) tout vol a un nombre fini d’étapes impaires ;
(6) tout vol a un nombre fini d’étapes impaires en altitude ;
Les termes de la suite de syracuse pour 11,27,97,99
pour 11 nous obtenons :
2 - 1
La durée du vol pour 2 est de 1 et son altitude est de 2
3 - 10 - 5 - 16 - 8 - 4 - 2 - 1
La durée du vol pour 3 est de 7 et son altitude est de 16
4 - 2 - 1
La durée du vol pour 4 est de 2 et son altitude est de 4
5 - 16 - 8 - 4 - 2 - 1
La durée du vol pour 5 est de 5 et son altitude est de 16
6 - 3 - 10 - 5 - 16 - 8 - 4 - 2 - 1
La durée du vol pour 6 est de 8 et son altitude est de 16
7 - 22 - 11 - 34 - 17 - 52 - 26 - 13 - 40 - 20 - 10 - 5 - 16 - 8 - 4 - 2 - 1
La durée du vol pour 7 est de 16 et son altitude est de 52
8 - 4 - 2 - 1
La durée du vol pour 8 est de 3 et son altitude est de 8
9 - 28 - 14 - 7 - 22 - 11 - 34 - 17 - 52 - 26 - 13 - 40 - 20 - 10 - 5 - 16 - 8 - 4 - 2 - 1
La durée du vol pour 9 est de 19 et son altitude est de 52
10 - 5 - 16 - 8 - 4 - 2 - 1
La durée du vol pour 10 est de 6 et son altitude est de 16
pour 27 nous obtenons :
27 - 82 - 41 - 124 - 62 - 31 - 94 - 47 - 142 - 71 - 214 - 107 - 322 - 161 - 484 - 242 - 121 - 364 - 182 - 91 - 274 - 137 - 412 - 206 - 103 - 310 - 155 - 466 - 233 - 700 - 350 - 175 - 526 - 263 - 790 - 395 - 1186 - 593 - 1780 - 890 - 445 - 1336 - 668 - 334 - 167 - 502 - 251 - 754 - 377 - 1132 - 566 - 283 - 850 - 425 - 1276 - 638 - 319 - 958 - 479 - 1438 - 719 - 2158 - 1079 - 3238 - 1619 - 4858 - 2429 - 7288 - 3644 - 1822 - 911 - 2734 - 1367 - 4102 - 2051 - 6154 - 3077 - 9232 - 4616 - 2308 - 1154 - 577 - 1732 - 866 - 433 - 1300 - 650 - 325 - 976 - 488 - 244 - 122 - 61 - 184 - 92 - 46 - 23 - 70 - 35 - 106 - 53 - 160 - 80 - 40 - 20 - 10 - 5 - 16 - 8 - 4 - 2 - 1
La durée du vol pour 27 est de 111 et son altitude est de 9232
pour 97 nous obtenons :
97 - 292 - 146 - 73 - 220 - 110 - 55 - 166 - 83 - 250 - 125 - 376 - 188 - 94 - 47 - 142 - 71 - 214 - 107 - 322 - 161 - 484 - 242 - 121 - 364 - 182 - 91 - 274 - 137 - 412 - 206 - 103 - 310 - 155 - 466 - 233 - 700 - 350 - 175 - 526 - 263 - 790 - 395 - 1186 - 593 - 1780 - 890 - 445 - 1336 - 668 - 334 - 167 - 502 - 251 - 754 - 377 - 1132 - 566 - 283 - 850 - 425 - 1276 - 638 - 319 - 958 - 479 - 1438 - 719 - 2158 - 1079 - 3238 - 1619 - 4858 - 2429 - 7288 - 3644 - 1822 - 911 - 2734 - 1367 - 4102 - 2051 - 6154 - 3077 - 9232 - 4616 - 2308 - 1154 - 577 - 1732 - 866 - 433 - 1300 - 650 - 325 - 976 - 488 - 244 - 122 - 61 - 184 - 92 - 46 - 23 - 70 - 35 - 106 - 53 - 160 - 80 - 40 - 20 - 10 - 5 - 16 - 8 - 4 - 2 - 1
La durée du vol pour 97 est de 118 et son altitude est de 9232
C'est la même altitude maximale que pour 27 !
Nous pouvons remarquer que pour 99 nous obtenons une durée de vol beaucoup plus courte que 97 :
99 - 298 - 149 - 448 - 224 - 112 - 56 - 28 - 14 - 7 - 22 - 11 - 34 - 17 - 52 - 26 - 13 - 40 - 20 - 10 - 5 - 16 - 8 - 4 - 2 - 1
La durée du vol pour 99 est de 25 et son altitude est de 448
La suite de syracuse nous donne des résultats étonnants, qui sont impossibles à prévoir ! Essayez de trouver le plus long vol ou la plus haute altitude. Pour ma part je trouve 703 ou 871 intéressants.
Calculer le vol, la durée et l'altitude maximale d'un nombre
à vous de jouer... On ouvre un concours à celui qui trouvera la plus longue durée de vol ?
Pour des contraintes techniques le programme ci-dessous est limité à des nombres de 6 chiffres, afin de ne pas alourdir le serveur et surtout parce que au delà on atteint les limites des grands nombres employés par le langage de programmation, les approximations entraineraient des réponses erronées, sur la durée de vol.
Vous pouvez par exemple tester les nombres 703 et 871 qui sont, pour une valeur inferieure à 1000, les plus intéressants, l'un détient le record d'altitude et le second le record de durée, pour tous les nombres inferieurs à 1000.
Programmation algorithme de Syracuse
Après avoir rédiger cette page, l'envie m'est venue de voir ce que l'on pouvait faire en programmation, pour un simple mortel, c'est à dire :
- sans accès à du temps sur un très gros calculateur
- et sans avoir de bagage théorique permettant d’apprécier les dernières publications.
Mais c’est l’avantage de la conjecture, nous pouvons nous amuser et réussir quelques calculs sans travailler au Cnrs.
Les conditions étaient pour moi très réduites : un ordinateur portable, pas de logiciel qui me permettrait de compiler du C, j'étais donc réduit à monter un serveur web et de lancer une page web avec un programme de calcul rédiger en PHP. Le plus rapide et le simple, à mettre en œuvre, pour pouvoir tester des idées d'algorithmes.
Bref ! En reprenant les infos que l’on peut trouver sur la toile (enfin celle que les chercheurs veulent bien nous laisser) et en combinant cela avec les conditions particulières énoncées précédemment, voilà ce que j’ai pu obtenir en quelques jours de programmation et quelques heures de calcul.
Records d'altitude
| nombre | durée en altitude | durée | altitude |
|---|---|---|---|
| 27 | 96 | 111 | 9232 |
| 703 | 132 | 170 | 250 504 |
| 9663 | 88 | 184 | 27114424 |
| 77 671 | 171 | 231 | 1570824736 |
| 704 511 | 119 | 242 | 56991483520 |
| 6 631675 | 362 | 576 | 60342610919632 |
| 80 049391 | 396 | 572 | 2185143829170100 |
| 319 804831 | 427 | 592 | 1414236446719942480 |
| 1 410 123943 | 590 | 770 | 7125885122794452160 |
Récords de durée en altitude
| nombre | durée en altitude | durée | altitude |
|---|---|---|---|
| 703 | 132 | 170 | 250 504 |
| 10 087 | 171 | 223 | 2 484 916 |
| 35 655 | 220 | 323 | 41 163 712 |
| 626 331 | 287 | 508 | 7 222 283 188 |
| 1 126 015 | 365 | 527 | 90 239 155 648 |
| 8 088 063 | 401 | 566 | 16 155 154 672 |
| 63 728 127 | 613 | 949 | 966 616 035 460 |
| 217 740 015 | 644 | 793 | 2 516 021 527 120 |
| 2 788 008 987 | 729 | 944 | 81 887 769 175 732 |
| 1 200 991 791 | 649 | 873 | 35 681 506 677 556 |
| 1 827 397 567 | 706 | 928 | 118 736 698 851769012 |
| 2 788 008 987 | 729 | 944 | 81 887 769175732 |
| 12 235 060 455 | 892 | 1184 | 1 037 298 361093936 |
J'ai découvert que l'on pouvait compiler du C sur mon macbook ! Hé oui c'est livré avec le portable ! J'ai donc recompilé le tout en C, en améliorant l’algorithme, cette fois-ci tout va beaucoup plus vite, j'ai pu obtenir les records de vol en altitude ci-dessous en quelques centaines de secondes ! Malgré tout, après la suite de Syracuse avec comme premier terme 12 235 060455, le record suivant semble beaucoup mois abordable pour mon algorithme et ma machine, après une heure de calculs, j’obtiens un résultat surement faux car l’altitude dépasse les capacité des integer long long en C :/ Dommage ! J’ai bien tenté de créer une structure pour gérer les très grands entiers mais cela ralentit beaucoup les calculs.
Record de durée en altitude avec le programme en C
27 - 96 - 9232 - 0.000005 s
703 - 132 - 250504 - 0.000107 s
10087 - 171 - 2484916 - 0.000183 s
35655 - 220 - 41163712 - 0.000361 s
270271 - 267 - 24648077896 - 0.001860 s
362343 - 269 - 565335124 - 0.002447 s
381727 - 282 - 565335124 - 0.002578 s
626331 - 287 - 7222283188 - 0.004115 s
1027431 - 298 - 17808240724 - 0.006625 s
1126015 - 365 - 90239155648 - 0.007248 s
8088063 - 401 - 16155154672 - 0.051004 s
13421671 - 468 - 1591706254336 - 0.084490 s
20638335 - 476 - 89243211616 - 0.129836 s
26716671 - 486 - 3696858621088 - 0.167983 s
56924955 - 502 - 7209046267252 - 0.357630 s
63728127 - 613 - 966616035460 - 0.400345 s
217740015 - 644 - 2516021527120 - 1.366941 s
1200991791 - 649 - 35681506677556 - 7.537392 s
1827397567 - 706 - 118736698851769012 - 11.468214 s
2788008987 - 729 - 81887769175732 - 17.496869 s
12235060455 - 892 - 1037298361093936 - 76.827696 s