Diffusion d'erreur

{{#ifeq:||Un article de Ziki, l'encyclopédie libre.|Une page de Ziki, l'encyclopédie libre.}}

Modèle:À sourcer La diffusion d'erreur est une technique d'amélioration du rendu des images infographiques en cas de diminution du nombre de codes de couleurs. Elle se combine à l'anticrénelage. Elle sert dans les systèmes informatiques capables d'afficher seulement un petit nombre de couleurs, et dans les imprimantes, pour lesquelles les pixels n'ont que deux valeurs, avec du toner ou sans.

Elle consiste à répartir sur les pixels voisins les erreurs de quantification issues de l'assimilation de la couleur d'un pixel à une couleur prise dans une gamme réduite.

Elle limite l'apparition de motifs tels que le banding (rendu graduel de la luminosité ou de la teinte) dans les images au prix d'une augmentation du bruitModèle:Refsou.

En audio, la réduction du bruit de quantification se fait par application d'un signal aléatoire appelé dither, anglicisme officiellement traduit par vibration et tremblement<ref>Modèle:Ouvrage.</ref> ou signal de superposition<ref>Modèle:Lien web.</ref>. Le même terme s'applique parfois à la diffusion d'erreurs en raison d'une histoire commune. Le tramage utilisé en similigravure a aussi servi de modèle, et son nom est aussi quelquefois employé pour les techniques de quantification de la couleur en informatique.

Principe

Fichier:Fusion optique.png
Mélange optique des couleurs. Plus le pixel est petit, plus la zone semble d'une couleur unie intermédiaire entre les couleurs des éléments.

La diffusion d'erreur sert en infographie à donner l'illusion d'une profondeur de couleur supérieure en utilisant d'une palette couleurs limitée (quantification de couleur). On approche les couleurs non disponibles de la palette en faisant en sorte que la couleur moyenne d'un groupe de pixels soit celle de l'aire correspondante de l'original. L'œil humain perçoit la juxtaposition de petits éléments colorés comme un mélange de couleurs. Les écrans informatique ou de télévision utilisent cette propriété de fusion des couleurs pour afficher une image en couleurs avec des luminophores de seulement trois couleurs. Pour réaliser simplement ce procédé, l'algorithme de diffusion d'erreur enregistre pour chaque pixel la différence entre le code de couleur le plus proche dans la palette de sortie et celui d'origine, et ajoute cette différence aux pixels voisins, avant de rechercher la couleur la plus proche.

Le processus de réduire les couleurs disponibles à une palette couleurs est une quantification. La perte d'une certaine quantité d'informations cause des erreurs d'arrondi. En répartissant ces erreurs, l'algorithme les rend moins évidentes.

Photographie numérique et traitement d'images

Des images réduites à un petit nombre de couleurs par diffusion d'erreur peuvent souvent être distinguées par leur grain ou leur apparence mouchetéeModèle:Refsou.

La diffusion d'erreurs étant un procédé qui nécessite Modèle:Quoi de calculs, plusieurs constructeurs avaient développé, à une époque, des gestionnaires qui n'utilisaient que des couleurs unies, avec une incidence sur la qualité. Ainsi en fonction des applications, la qualité de l'image pouvait beaucoup varierModèle:Refnec.

Historiquement, le procédé de diffusion d'erreur a été mis en œuvre dans les logiciels de retouche d'image pour un affichage en 16 millions de couleurs alors que Modèle:Quoi n'en proposait que 256. Chaque nuance manquante était simulée par la juxtaposition de plusieurs points diversement colorésModèle:Refnec.

Certains constructeurs de cartes graphiques avaient mis en œuvre une « power palette » qui permettait de remplacer la teinte manquante par la couleur de la palette la plus approchante. Dans cette technologie, l'affichage était plus rapide, car de fait la diffusion d'erreur dynamique disparaît, mais le rendu des couleurs était nettement moins bonModèle:Refnec.

Exemple

Réduire la profondeur de couleur d'une image peut souvent avoir d'importants effets secondaires. Si l'original est une photographie, elle a probablement des milliers ou même des millions de codes de couleur distinctsModèle:Refsou.

Plusieurs facteurs peuvent affecter la qualité d'une image dont le nombre de couleurs a été réduit. Peut-être le plus important est la palette couleurs qui sera utilisée pour une image réduite. Par exemple, une image originale (figure 1) peut être réduite aux 216 couleurs de la palette couleurs garantie pour le Web (Web-safe). Si les couleurs des pixels originaux sont simplement traduites par les couleurs disponibles les plus proches dans la palette, aucune diffusion d'erreur n'est effectuée (figure 2). Typiquement, cette approche se traduit dans des zones planes (sans profondeur de couleurs) par une perte de détails, pouvant produire des taches dont les couleurs sont différentes de l'image originale. Les zones ombragées ou de dégradé peuvent apparaître sous la forme de bandes de couleur, pouvant être dérangeantes. L'utilisation de la diffusion d'erreur peut contribuer à minimiser ces artéfacts visuels, et se traduit généralement par un résultat de meilleure qualité (figure 3). Il permet de réduire les bandes de couleur et le manque de profondeurModèle:Refsou.

La sélection de couleurs d'une palette fixe contient souvent une quantité de nuances inutiles ; par exemple, les nuances de vert ou bien les couleurs vives ne servent pas pour une image qui n'en contient pas. Les couleurs d'une palette optimisée sont choisies sur la base de leur fréquence d'utilisation dans l'image originale servant de source. Si la réduction de l'image est réalisée sur la base d'une palette optimisée, le résultat est souvent bien plus proche de l'original (figure 4)Modèle:Refsou.

Le nombre de couleurs disponibles dans la palette est aussi un facteur contributif. Avec une palette limitée à 16 couleurs, l'image traitée peut perdre des détails, et avoir des problèmes encore plus visibles liés à leur manque de profondeur et de graduation (figure 5). Une fois de plus, la diffusion d'erreur peut aider à réduire de tels artefacts (figure 6).

Applications

Les appareils graphiques, incluant les premières cartes graphiques d'ordinateur et de nombreux afficheurs LCD utilisés dans les téléphones portables et les appareils photo numérique d'entrée de gamme, offrent une profondeur de couleurs plus faible que sur ceux plus récentsModèle:Refsou. Une application courante de la diffusion d'erreur est d'afficher plus précisément des graphiques contenant un nombre de couleurs plus grand que l'appareil n'est capable d'en afficher. Elle peut être utilisée afin d'afficher une image photographique contenant potentiellement un million de couleurs avec des cartes graphiques qui ne sont capables d'en restituer que 256 à la fois. Ces 256 couleurs sont utilisées pour créer une approximation de l'image originale. Sans cela, les couleurs de l'image originale seraient simplement approchées par les couleurs les plus proches disponibles, donnant comme résultat une nouvelle image qui serait une médiocre représentation du modèle. La diffusion d'erreur utilise la tendance de l'œil humain à "mélanger" deux couleurs proches l'une de l'autre.

Un tel procédé, pour lequel le matériel d'affichage informatique est la principale limite de la profondeur des couleurs, est habituellement employé dans les logiciels comme les navigateurs web. Puisqu'un navigateur peut afficher des images provenant d'une source externe, il peut lui être nécessaire d'effectuer une réduction sur celles ayant trop de couleurs par rapport à celles disponibles sur la palette. C'est pour éviter les problèmes liés au calcul de diffusion d'erreur qu'une palette couleurs appelée Web-safe color a été définie, ne permettant de sélectionner que celles qui ne soient pas tramées sur les moniteurs ne permettant d'en afficher que 256.

Toutefois, même quand le nombre total de couleurs disponibles du matériel d'affichage est suffisamment élevé pour le rendu des photos numériques en couleur comme celles de 15 et 16 bits RVB Hicolor offrant entre 32 768 et 65 536 couleurs, des bandes peuvent être visibles pour l'œil, en particulier dans les grandes zones de dégradé des ombres (bien qu'elles n'apparaissent pas sur le fichier de l'image d'origine). Réduit à un niveau de 32 ou 64 bits RVB, le rendu donnera une bonne approximation d'un affichage pseudo truecolor, que l'œil n'interprétera pas comme granuleux. De plus, une image affichée sur du matériel supportant le 24-bits RVB (8 bits par couleur primaire) peut être réduite pour simuler une profondeur de couleurs un peu plus grande et/ou pour minimiser la perte de teintes disponibles après une correction gamma.

Une autre utilisation utile de la diffusion d'erreur est pour les cas dans lesquels le format graphique des fichiers est le facteur limitant. En particulier, le format GIF d'usage courant est restreint à l'utilisation de 256 couleurs ou moins dans de nombreux programmes d'édition graphique. Des images dans d'autres formats de fichier, tel que le PNG, peut également avoir de telles restrictions imposées en vue de la réduction de la taille des fichiers. De telles images ont une palette couleurs fixée définissant toutes les couleurs que l'image peut utiliser. Dans ces situations, les éditeurs d'image matricielle peuvent prendre en charge la réduction du nombre de couleurs des images avant de les enregistrer dans ces formats restrictifs.

Algorithmes

Plusieurs algorithmes permettent de réaliser la réduction du nombre de couleurs.

Seuillage

Modèle:Article détaillé La méthode la plus simple pour réduire le nombre de couleurs est l'assimilation à la couleur la plus proche, parmi celles disponibles.

En noir et blanc, on opère la réduction par moyenne<ref>{{#invoke:Langue|indicationDeLangue}} Aristófanes Correia Silva, Lucena Paula Salgado, Figuerola Wilfredo Blanco, Average Dithering, Visgraf Lab, Image Based Artistic Dithering, 13/12/2000 consulté le 10/09/2007 Modèle:Lire en ligne</ref> ou seuillage (thresholding) qui compare chaque valeur de couleur de pixel à un seuil fixé.

Il s'agit peut-être de l'algorithme de réduction du nombre de couleurs le plus simple, mais il cause une grande perte de détails et de contours<ref name="dhalf" />. La méthode d'Otsu permet de déterminer le seuil adéquat par analyse de l'histogramme des valeurs de l'image

Dithering

Modèle:Article détaillé Le tremblotement (dithering) est une méthode classique en audionumérique. Goodal l'appliqua dès 1951, sous le nom de Modèle:Lang pour remédier aux inconvénients du seuillage pour l'image Modèle:Harv. Il compare la valeur de chaque pixel à un seuil aléatoire. Bien que cette méthode très rapide ne génère pas d'artefacts répétitifs, le bruit tend à déborder sur les détails de l'image. La méthode a un rendu analogue à la manière noire utilisée dans la gravure<ref name="dhalf" />.

Tramage

Modèle:Article détaillé Le tramage applique le principe de la trame d'imprimerie qui combine les pixels dans une forme répétitive. Il permet de reproduire le nombre de couleurs de la palette, multiplié par le nombre de pixels du motif répété. La couleur résultante est la moyenne des couleurs affichées dans le motif. La résolution est réduite à celle du motif.

Différents motifs peuvent créer des effets de tramage complètement différents :

  • le tramage en demi-teinte (halftone, halftoning) qui ressemble à l'impression dite en demi-teinte ou en similigravureModèle:Sfn (traduit en halftone en anglais) des journaux. Il s'agit d'une forme de tramage par grappes, dans lesquels les points tendent à être regroupés. Cela permet de masquer les effets secondaires de pixels flous affichés sur d'ancien périphériques d'affichageModèle:Refsou ;
  • le tramage ordonné ou tramage de Bayer génère un motif de hachures. Il s'agit d'une forme de tramage dispersé. Parce que les points ne sont pas regroupés en grappes, le résultat obtenu est beaucoup moins granuleuxModèle:Refsou.
(Original) Seuillage Aléatoire (Dither) Demi-teinte ou similigravure (Halftone) Ordonné
Fichier:Michelangelo's David - 63 grijswaarden.png Fichier:Michelangelo's David - drempel.png Fichier:Michelangelo's David - ruis.png Fichier:Michelangelo's David - halftoon.png Fichier:Michelangelo's David - Bayer.png

Diffusion d'erreurs

L'algorithme de Floyd-Steinberg, développé en 1975, est le plus connu et un des tout premiers algorithmes de diffusion d'erreur. Il calcule la différence algébrique entre la couleur demandée pour un pixel et la couleur disponible la plus proche, et ajoute cette différence pondérée par une matrice aux quatre pixels voisins non encore traités.

Tout en restant simple, cet algorithme minimise les artefacts visuels ; les algorithmes de diffusion d'erreur produisent des images plus proches de l'originale que des algorithmes plus simples<ref name="dhalf">Modèle:Ouvrage, consulté le 27 février 2015.</ref>.

D'autres algorithmes procèdent de façon similaire :

  • l’algorithme Jarvis, Judice & Ninke diffuse les erreurs aux pixels un peu plus éloignés. Ce procédé génère moins d'artefacts visuels, au prix d'une réduction du détail. Il est plus lent que le précédent parce qu'il distribue les erreurs jusqu'aux douzièmes pixels au lieu des quatrièmes pour le Floyd–Steinberg ;
  • l’algorithme Stucki qui est basé sur le Jarvis, Judiec & Ninke mais est un peu plus rapide. Son résultat tend à être propre et précis ;
  • l’algorithme Burkes est une forme simplifiée du Stucki plus rapide mais moins propre ;
  • l’algorithme Scolorq est un algorithme expérimental de quantification de couleur spatiale qui combine la quantification de couleur et la diffusion d'erreurs pour produire une image optimale. À cause de sa nature, l'image d'exemple ci-dessous n'est pas strictement en noir & blanc, mais à deux tons de gris<ref>{{#invoke:Langue|indicationDeLangue}} scolorq : A Spatial Color Quantization Utility, cs.berkeley.edu, consulté le 26/04/2010 Modèle:Lire en ligne</ref> ;
Floyd–Steinberg Jarvis, Judice & Ninke Stucki Burkes
Fichier:Michelangelo's David - Floyd-Steinberg.png Fichier:Michelangelo's David - Jarvis, Judice & Ninke.png Fichier:Michelangelo's David - Stucki.png Fichier:Michelangelo's David - Burkes.png
  • l’algorithme Sierra est basé sur celui de Jarvis, Judice & Ninke, il est plus rapide tout en rendant des résultats similaires.
  • l’algorithme Two-row Sierra est une variante du Sierra par son auteur pour améliorer sa rapidité.
  • l’algorithme Filter Lite est un algorithme créé par Sierra qui est plus simple et plus rapide que le Floyd–Steinberg, bien que donnant des résultats similaires.
  • l’algorithme Atkinson ressemble au tramage Jarvis, Judice & Ninke et Sierra mais est plus rapide. Une autre différence est qu'il ne diffuse pas intégralement l'erreur de quantification, mais seulement les trois-quarts. Il tend à bien préserver les détails, mais les zones très claires ou très sombres peuvent apparaître comme soufflées.
  • l’algorithme Hilbert–Peano est une variante<ref>{{#invoke:Langue|indicationDeLangue}} Error Correction Dithering, imagemagick.org, consulté le 28/04/2010 Modèle:Lire en ligne</ref> du tramage Riemersma et est utilisé par Imagemagick<ref>Voir le lien suivant montrant le code sourde d'Imagemagick, le fichier magick/quantize.c, et le manuel d'utilisation en ligne qui mentionne le nom de la méthode de tramage : {{#invoke:Langue|indicationDeLangue}} command-line-options, imagemagick.org, consulté le 28/04/2010 Modèle:Lire en ligne</ref>.
Sierra Two-row Sierra Filter Lite Atkinson
Fichier:Michelangelo's David - Sierra.png Fichier:Michelangelo's David - tweerijig Sierra.png Fichier:Michelangelo's David - Sierra's Filter Lite.png Fichier:Michelangelo's David - Atkinson.png

.


Annexes

Bibliographie

Articles connexes

Notes et références

Modèle:Références

Modèle:Portail