Enoncé de la conjecture - Idées de programmation - Calculer les termes de la suite de Syracuse en ligne - Records
Le problème 3x+1 ou la conjecture de Syracuse ou de Collatz (nom du mathématicien 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 pour cela que son énoncé reste une conjecture.
Cette conjecture est apparue vers 1930 et s'est répandue 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. Un problème qui reste entièrement ouvert encore aujourd'hui.
On choisit 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 :
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é établie à ce jour.
(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 .
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 pour 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.
Vous pouvez par exemple tester (par ex ici : test syracuse) 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.
Après avoir rédiger cette page, j’ai eu envie 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.
n° - terme - durée en alt - alt max 1 - 27 - 96 - 9232 2 - 447 - 65 - 39364 3 - 639 - 37 - 41524 4 - 703 - 132 - 250504 5 - 1819 - 99 - 1 276936 6 - 4255 - 114 - 6 810136 7 - 4591 - 106 - 8 153620 8 - 9663 - 88 - 27 114424 9 - 20895 - 117 - 50 143264 10 - 26623 - 106 - 106 358020 11 - 31911 - 96 - 121 012864 12 - 60975 - 207 - 593 279152 13 - 77671 - 171 - 1570 824736 14 - 113383 - 179 - 2482 111348 15 - 138367 - 96 - 2798 323360 16 - 159487 - 117 - 17202 377752 17 - 270271 - 267 - 24648 077896 18 - 665215 - 228 - 52483 285312 19 - 704511 - 119 - 56991 483520 20 - 1042431 - 277 - 90239 155648 21 - 1212415 - 171 - 139646 736808 22 - 1441407 - 243 - 151629 574372 23 - 1875711 - 158 - 155904 349696 24 - 1988859 - 220 - 156914 378224 25 - 2643183 - 298 - 190459 818484 26 - 2684647 - 161 - 352617 812944 27 - 3041127 - 161 - 622717 901620 28 - 3873535 - 202 - 858555 169576 29 - 4637979 - 254 - 1 318802 294932 30 - 5656191 - 326 - 2 412493 616608 31 - 6416623 - 228 - 4 799996 945368 32 - 6631675 - 362 - 60 342610 919632 33 - 19638399 - 430 - 306 296925 203752 34 - 38595583 - 295 - 474 637698 851092 35 - 80049391 - 396 - 2185 143829 170100 36 - 120080895 - 331 - 3277 901576 118580 37 - 210964383 - 388 - 6404 797161 121264 38 - 319804831 - 427 - 1 414236 446719 942480
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 ! Ensuite, 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 considérablement les calculs.
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