Désolé, cette question est un peu ésotérique, mais je ne peux pas la sortir de ma tête!
Je regarde l'algorithme de fondu utilisé dans le jeu d'arcade DoDonPachi (ainsi que de nombreux autres jeux plus anciens):
J'ai écrit un script python pour sélectionner quelques pixels et les suivre pendant la durée du fondu. Voici un échantillon représentatif des résultats. La première ligne de chaque groupe est la valeur de couleur de départ, tandis que chaque ligne suivante est la différence entre la valeur de couleur de l'image actuelle et la valeur de couleur de l'image précédente.
Starting Value: (132, 66, 189)
Frame 1: [9, 9, 8]
Frame 2: [8, 8, 8]
Frame 3: [8, 8, 8]
Frame 4: [8, 8, 9]
Frame 5: [9, 9, 8]
Frame 6: [8, 8, 8]
Frame 7: [8, 8, 8]
Frame 8: [8, 8, 9]
Frame 9: [9, 0, 8]
Frame 10: [8, 0, 8]
Frame 11: [8, 0, 8]
Frame 12: [8, 0, 9]
Frame 13: [9, 0, 8]
Frame 14: [8, 0, 8]
Frame 15: [8, 0, 8]
Frame 16: [8, 0, 9]
Frame 17: [0, 0, 8]
Frame 18: [0, 0, 8]
Frame 19: [0, 0, 8]
Frame 20: [0, 0, 9]
Frame 21: [0, 0, 8]
Frame 22: [0, 0, 8]
Frame 23: [0, 0, 8]
Frame 24: [0, 0, 0]
Frame 25: [0, 0, 0]
Frame 26: [0, 0, 0]
Frame 27: [0, 0, 0]
Frame 28: [0, 0, 0]
Frame 29: [0, 0, 0]
Starting Value: (132, 0, 0)
Frame 1: [9, 0, 0]
Frame 2: [8, 0, 0]
Frame 3: [8, 0, 0]
Frame 4: [8, 0, 0]
Frame 5: [9, 0, 0]
Frame 6: [8, 0, 0]
Frame 7: [8, 0, 0]
Frame 8: [8, 0, 0]
Frame 9: [9, 0, 0]
Frame 10: [8, 0, 0]
Frame 11: [8, 0, 0]
Frame 12: [8, 0, 0]
Frame 13: [9, 0, 0]
Frame 14: [8, 0, 0]
Frame 15: [8, 0, 0]
Frame 16: [8, 0, 0]
Frame 17: [0, 0, 0]
Frame 18: [0, 0, 0]
Frame 19: [0, 0, 0]
Frame 20: [0, 0, 0]
Frame 21: [0, 0, 0]
Frame 22: [0, 0, 0]
Frame 23: [0, 0, 0]
Frame 24: [0, 0, 0]
Frame 25: [0, 0, 0]
Frame 26: [0, 0, 0]
Frame 27: [0, 0, 0]
Frame 28: [0, 0, 0]
Frame 29: [0, 0, 0]
Starting Value: (165, 156, 222)
Frame 1: [9, 8, 8]
Frame 2: [8, 8, 8]
Frame 3: [8, 8, 8]
Frame 4: [8, 9, 9]
Frame 5: [9, 8, 8]
Frame 6: [8, 8, 8]
Frame 7: [8, 8, 8]
Frame 8: [8, 9, 9]
Frame 9: [9, 8, 8]
Frame 10: [8, 8, 8]
Frame 11: [8, 8, 8]
Frame 12: [8, 9, 9]
Frame 13: [9, 8, 8]
Frame 14: [8, 8, 8]
Frame 15: [8, 8, 8]
Frame 16: [8, 9, 9]
Frame 17: [9, 8, 8]
Frame 18: [8, 8, 8]
Frame 19: [8, 8, 8]
Frame 20: [8, 0, 9]
Frame 21: [0, 0, 8]
Frame 22: [0, 0, 8]
Frame 23: [0, 0, 8]
Frame 24: [0, 0, 9]
Frame 25: [0, 0, 8]
Frame 26: [0, 0, 8]
Frame 27: [0, 0, 8]
Frame 28: [0, 0, 0]
Frame 29: [0, 0, 0]
Starting Value: (156, 90, 206)
Frame 1: [8, 8, 8]
Frame 2: [8, 8, 9]
Frame 3: [8, 8, 8]
Frame 4: [9, 9, 8]
Frame 5: [8, 8, 8]
Frame 6: [8, 8, 9]
Frame 7: [8, 8, 8]
Frame 8: [9, 9, 8]
Frame 9: [8, 8, 8]
Frame 10: [8, 8, 9]
Frame 11: [8, 8, 8]
Frame 12: [9, 0, 8]
Frame 13: [8, 0, 8]
Frame 14: [8, 0, 9]
Frame 15: [8, 0, 8]
Frame 16: [9, 0, 8]
Frame 17: [8, 0, 8]
Frame 18: [8, 0, 9]
Frame 19: [8, 0, 8]
Frame 20: [0, 0, 8]
Frame 21: [0, 0, 8]
Frame 22: [0, 0, 9]
Frame 23: [0, 0, 8]
Frame 24: [0, 0, 8]
Frame 25: [0, 0, 8]
Frame 26: [0, 0, 0]
Frame 27: [0, 0, 0]
Frame 28: [0, 0, 0]
Frame 29: [0, 0, 0]
Comme vous pouvez le voir, un 8 ou un 9 est soustrait de chaque composante de couleur dans chaque image. En outre, un 9 apparaît toujours trois images après un 8, même si la valeur soustraite de départ est différente pour chaque composante de couleur. Notez également que chaque composante de couleur atteint 0 (c'est-à-dire, le noir) avec une différence de 8 ou 9, pas un reste arbitraire. Cela signifie que le cycle de valeur soustrait de 8,8,8,9 n'est jamais rompu! (Cet algorithme a probablement été écrit pour garantir que la dernière image du fondu était aussi fluide que les autres.)
Maintenant, cela me laisse perplexe. Selon mes calculs, si vous inversez le processus - c'est-à-dire, prenez le cycle 8,8,8,9 et résumez-le pour trouver toutes les combinaisons possibles dans 29 images - vous n'obtenez que 52 nombres uniques. Mais en l'occurrence, chaque composant de couleur fait partie de cet ensemble! Cela signifie que les couleurs ont été choisies spécifiquement pour cet algorithme de fondu (peu probable) ou que l'algorithme de fondu a été conçu autour de la palette de couleurs du jeu. Mais comment diable quelqu'un aurait-il pu comprendre que si vous prenez 8,8,8,9, changez le cycle de manière appropriée et continuez à soustraire les nombres de chaque composante de couleur de votre palette, vous finirez par atteindre 0 pour chaque couleur? ! Il doit y avoir une astuce mathématique qui me manque. Qu'Est-ce que c'est?