L'objectif principal de ce travail était de générer une image RGB à partir de trois photos prises avec un filtre de couleur.
Chacune des photos est tirées de la collection Prokudin-Gorskii. Nous avions 2 types d'images : une série de jpg, peux volumineux, ainsi qu'une série de tiff, images très volumineuses.
Pour ce faire, j'ai transformé les images en une matrice de doubles. J'ai ensuite prélevé un échantillon au centre de l'image.
La position des images les unes par rapport aux autres à été déterminé par une mesure de corrélation croisée normalisée (CCN).
Une fois les images alignées, il suffit de les combinés pour qu'elles forment une seule et même image RGB.
Pour les images à hautes résolution, j'ai procédé avec une pyramide d'image. L'image entrante ést réduite par un facteur de 2, jusqu'à ce que l'image obtenue soit plus petite qu'une certaine limite.
L'image ainsi obtenue est envoyé à l'algorithme pour les images à basse résolution. Le meilleur déplacement calculé est appliqué 2 fois à l'image 2 fois plus grande, et on ajuste en calculant un nouveau déplacement sur une plus petite plage, grâce à notre algorithme de départ.
J'ai procédé ainsi de manière récursive jusqu'à l'obtention d'un déplacement pour l'image la plus grande.
Green Offset : x = 4, y = 1
Red Offset : x = 9, y = -1
Green Offset : x = 2, y = 3
Red Offset : x = 5, y = 5
Green Offset : x = 6, y = 1
Red Offset : x = 12, y = 0
Green Offset : x = 1, y = 2
Red Offset : x = 4, y = 3
Green Offset : x = 2, y = 0
Red Offset : x = 6, y = 0
Green Offset : x = 1, y = -1
Red Offset : x = 13, y = -1
Green Offset : x = 1, y = 1
Red Offset : x = 4, y = 2
Green Offset : x = 5, y = 1
Red Offset : x = 11, y = 1
Green Offset : x = 6, y = 2
Red Offset : x = 14, y = 4
Green Offset : x = 4, y = 0
Red Offset : x = 10, y = -1
Green Offset : x = 3, y = 2
Red Offset : x = 10, y = 2
Green Offset : x = 2, y = 1
Red Offset : x = 6, y = 3
Green Offset : x = 3, y = 1
Red Offset : x = 8, y = 4
Green Offset : x = 4, y = 1
Red Offset : x = 10, y = 1
Avec mes propres photos, l'algorithme n'a pas bien fonctionné. Je présente ici 3 exemples de fonctionnement. Dans la première image, l'algorithme n'a pas réussit à aligner les photos correctement. J'attribue cet échec à un taux trop élevé de blanc dans l'échantillon prélevé pour le CCN. La seconde photo montre ce qui ce passe lorsqu'une couleur (rouge sur cet exemple) prédomine sur les autres. Finalement, la dernière photo montre un exemple qui a fonctionné.
Green Offset : x = -2, y = 0
Red Offset : x = -8, y = 0
Green Offset : x = 4, y = 5
Red Offset : x = -40, y = 1
Green Offset : x = 0, y = 2
Red Offset : x = 0, y = 0
Afin d'éviter les erreurs dues à la prédominance d'une couleur dans une photo, j'ai essayé de passer l'image dans un filtre de canny avant de l'envoyer à l'algorithme. Les résultats sont très concluants et sont montrés sur les photos suivantes. On y voit une nette amélioration à côté des photos de la section précédante.
Green Offset : x = -1, y = -4
Red Offset : x = 0, y = 13
Green Offset : x = 4, y = 5
Red Offset : x = 3, y = 1