Aller au contenu

JPEG

Un article de Wikipédia, l'encyclopédie libre.
(Redirigé depuis Jpeg)
JPEG
Une photo de fleur compressée en JPEG, avec des compressions de plus en plus fortes sur chacun des pétales, à partir de midi dans le sens antihoraire.
Caractéristiques
Extensions
.jpg, .jpeg, .JPG, .JPEG, .jpe, .JPEVoir et modifier les données sur Wikidata
Type de format
Site web

JPEG (sigle de Joint Photographic Experts Group) est une norme qui définit le format d'enregistrement et l'algorithme de décodage pour une représentation numérique compressée d'une image fixe.

Les extensions de nom de fichiers les plus communes pour les fichiers employant la compression JPEG sont .jpg et .jpeg, cependant .jpe, .jfif et .jif furent aussi utilisées.

Introduction au JPEG

[modifier | modifier le code]

JPEG[1] est l’acronyme de Joint Photographic Experts Group. Il s'agit d'un comité d’experts qui édicte des normes de compression pour l’image fixe. La norme communément appelée JPEG, de son vrai nom ISO/CEI 10918-1 UIT-T Recommendation T.81, est le résultat de l’évolution de travaux qui ont débuté dans les années 1978 à 1980 avec les premiers essais en laboratoire de compression d'images.

Le groupe JPEG qui a réuni une trentaine d’experts internationaux, a spécifié la norme en 1991. La norme officielle et définitive a été adoptée en 1992. Dans la pratique, seule la partie concernant le codage arithmétique est brevetée, et par conséquent protégée par IBM, son concepteur.

JPEG normalise uniquement l’algorithme et le format de décodage. Le processus de codage quant à lui est laissé libre à la compétition des industriels et des universitaires. La seule contrainte est que l’image produite doit pouvoir être décodée par un décodeur respectant le standard. La norme propose un jeu de fichiers de tests appelés fichiers de conformité qui permettent de vérifier qu'un décodeur respecte bien la norme. Un décodeur est dit conforme s’il est capable de décoder tous les fichiers de conformité.

Un brevet concernant la norme JPEG a été déposé par l'entreprise Forgent[2], mais a été remis en cause par le bureau américain des brevets (USPTO), qui l'a invalidé le pour antériorité existante à la suite d'une plainte de la Public Patent Foundation[3]. Mais depuis le , la société Global Patent Holdings, filiale d'Acacia Research Corporation, a à son tour revendiqué la paternité de ce format.

JPEG définit deux classes de processus de compression :

  • avec pertes ou compression irréversible. C’est le JPEG « classique ». Il permet des taux de compression de 3 à 100[réf. nécessaire]
  • sans pertes ou compression réversible. Il n’y a pas de pertes d’information et il est donc possible de revenir aux valeurs originales de l’image. Les gains en termes de compression sont alors plus modestes, avec un taux de compression de l’ordre de 2 à 8[réf. nécessaire]. Cette partie fait l’objet d’une norme spécifique appelée JPEG-LS.

Cet algorithme est très populaire, en particulier sur Internet où la compression d'un fichier permet de réduire le coût en bande passante. Il est de plus possible d'enregistrer une image dans le format JPEG avec la majeure partie des appareils photo numériques et téléphones portables. Cependant, les pertes se produisant lors de la compression « classique » font qu'il est moins utilisé dans certains domaines comme l'imagerie médicale, où la restitution fidèle de l'image initiale est plus importante.

Le format JPEG/JFIF supporte une taille d'image maximale de 65 535 × 65 535 pixels soit 4 294 836 225 pixels.

Fichiers JPEG

[modifier | modifier le code]

Extensions de nom de fichiers JPEG

[modifier | modifier le code]

Les extensions de nom de fichiers les plus communes pour les fichiers employant la compression JPEG sont .jpg et .jpeg, cependant .jpe, .jfif et .jif furent aussi utilisées. Il est aussi possible pour les données JPEG d'être embarquées dans d'autres types de fichiers - les fichiers codés en format TIFF contiennent souvent une image miniature JPEG de l'image principale ; et les fichiers MP3 peuvent contenir une image JPEG d'une couverture, contenue dans le tag ID3v2.

L'extension JPG est apparue dans les années 1990 parce que certains systèmes d'exploitation de cette période (ex. : MS-DOS, Windows 95, 98, Me) ne permettaient pas d'utiliser d'extension de fichier de plus de 3 caractères.

La compression JPEG

[modifier | modifier le code]

Le processus de compression et de décompression JPEG irréversibles comporte six étapes principales représentées ci-dessous :

Organigramme de compression
Figure 1 : Organigramme de compression.

Transformation des couleurs

[modifier | modifier le code]

JPEG est capable de coder les couleurs sous n’importe quel format, toutefois les meilleurs taux de compression sont obtenus avec des codages de couleur de type luminance/chrominance car l’œil humain est assez sensible à la luminance (la luminosité) mais peu à la chrominance (la teinte) d'une image. Afin de pouvoir exploiter cette propriété, l'algorithme convertit l'image d'origine depuis son modèle colorimétrique initial (en général RVB) vers le modèle de type chrominance/luminance YCbCr. Dans ce modèle, Y est l'information de luminance, et Cb et Cr sont deux informations de chrominance, respectivement le bleu moins Y et le rouge moins Y.

Sous-échantillonnage de la chrominance

[modifier | modifier le code]
Illustration des différents types de sous-échantillonnage
Illustration des différents types de sous-échantillonnage

Pour exploiter cette faible sensibilité de l’œil humain à la chrominance, on peut procéder à un sous-échantillonnage de ses signaux. Le principe de l'opération est de réduire de la taille de plusieurs blocs de chrominance en un seul bloc. Un traitement identique est appliqué aux blocs Cb et aux blocs Cr, tandis que les blocs de luminance (blocs Y) ne sont pas modifiés. Le sous-échantillonnage peut être réalisé selon plusieurs modes différents. Le type de mode utilisé dans une opération de compression est spécifié par la notation « J:a:b ».

L’interprétation de la notation est la suivante :

J : représente la largeur de la plus petite matrice de pixels considérée (généralement 4)

a : le nombre de composantes de chrominance dans la première ligne

b : le nombre de composantes de chrominance supplémentaires dans la deuxième ligne

Ce cas correspond à l'absence d'application du sous-échantillonnage.

Ce cas correspond à un sous-échantillonnage qui conduit à une réduction d'un facteur 1/2 de la taille des blocs Cb/Cr. Pour cela, on calcule la valeur moyenne de chrominance de deux pixels voisins horizontalement.

La moyenne de la chrominance de quatre pixels voisins est calculée et stockée dans le bloc produit par le sous-échantillonnage. Les pixels voisins forment des blocs carrés de dimension 2 × 2 pixels. Le sous-échantillonnage 4:2:0 ajoute donc une réduction verticale à la réduction horizontale du mode 4:2:2. Il conduit à une division par 4 de la taille des blocs Cb/Cr.

Ce dernier cas est rare en compression JPEG, et est plutôt appliqué dans des applications vidéo tel que les formats NTSC DV, DVCAM, DVCPRO.

Ce type de sous-échantillonnage permet de réduire de manière importante la taille des images. Cependant, il conduit à une perte d'information qui ne peut être récupérée dans la phase de décodage de l'image ; il s'agit donc d'une opération de compression irréversible. À l'issue de cette phase, les données se présentent sous la forme de blocs de coefficients Y, Cb et Cr, le nombre de blocs Cb et Cr étant égal au quart, à la moitié ou à 100 % du nombre de blocs Y selon le mode sous-échantillonnage appliqué.

Découpage en blocs

[modifier | modifier le code]

L’image est découpée en blocs de 64 (8 × 8) sous-pixels. Les informations de luminance n’étant pas sous-échantillonnées, chaque bloc correspond à 8 × 8 pixels dans l’image d’origine. Les informations de chrominance, par contre, correspondent en fonction du sous-échantillonnage à 8 × 8, 16 × 8 ou 16 × 16 pixels dans l’image d’origine.

Transformée DCT

[modifier | modifier le code]

La transformée DCT (Discrete Cosine Transform, en français transformée en cosinus discrète), est une transformation numérique qui est appliquée à chaque bloc. Cette transformation est une variante de la transformée de Fourier. Elle décompose un bloc, considéré comme une fonction numérique à deux variables, en une somme de fonctions cosinus oscillant à des fréquences différentes. Chaque bloc est ainsi décrit en une carte de fréquences et en amplitudes plutôt qu'en pixels et coefficients de couleur. La valeur d’une fréquence reflète l’importance et la rapidité d’un changement, tandis que la valeur d’une amplitude correspond à l’écart associé à chaque changement de couleur.

À chaque bloc de pixels sont ainsi associées fréquences

La transformée DCT s’exprime mathématiquement par :

Équation 1 : Transformée DCT directe.

Et la transformée DCT inverse s’exprime par :

Équation 2 : Transformée DCT inverse.

Dans les deux cas, la constante vaut :

Équation 3 : Définition de la constante C.

Pour illustrer la compression, a été repris un exemple complet provenant de Digital Image Compression Techniques de Majid Rabbani et Paul W. Jones[4].

Matrice (bloc de pixels) de base :

Équation 4 : Matrice d’origine.

En effectuant la transformée DCT, on obtient la matrice des fréquences suivante :

Équation 5 : Matrice transformée DCT.

L'application de la DCT est une opération théoriquement sans perte d'informations ; les coefficients initiaux peuvent être retrouvés en appliquant la « DCT inverse » au résultat de la DCT. Dans la pratique, une certaine perte d'informations reste cependant possible en raison des erreurs d'arrondis introduites en cours de calcul.

Le calcul d’une DCT est l’étape qui coûte le plus de temps[Combien ?] et de ressources dans la compression et la décompression JPEG, mais c’est peut-être[pourquoi ?] la plus importante car elle permet de séparer les basses fréquences et les hautes fréquences présentes dans l’image.

La puissance de calcul disponible aujourd’hui, alliée à des algorithmes de type FFT très efficaces, permet de rendre le temps de calcul tout à fait acceptable pour l’utilisateur courant, voire imperceptible avec les machines les plus puissantes.

À la suite de cette étape, les basses et hautes fréquences sont distinguées. Les basses fréquences constituent les données majeures présentes dans une image, les hautes fréquences, quant à elles, caractérisent les zones à fort contraste, qui sont les changements brusques de couleur. Ces données étant moins visibles, c'est donc sur celles-ci que la compression s'effectuera.

Quantification

[modifier | modifier le code]

La quantification est l’étape de l'algorithme de compression JPEG au cours de laquelle se produit la majeure partie de la perte d'information (et donc de la qualité visuelle), mais c'est aussi celle qui permet de gagner le plus de place (contrairement à la DCT, qui ne compresse pas).

La DCT a retourné, pour chaque bloc, une matrice de 8 × 8 nombres (dans l’hypothèse que les blocs de l’image font 8 × 8 pixels). La quantification consiste à diviser cette matrice par une autre, appelée matrice de quantification, et qui contient 8 × 8 coefficients spécifiquement choisis par le codeur.

Le but est ici d’atténuer les hautes fréquences, c’est-à-dire celles auxquelles l’œil humain est très peu sensible. Ces fréquences ont des amplitudes faibles, et elles sont encore plus atténuées par la quantification ; certains coefficients sont même souvent ramenés à 0.

Le calcul permettant la quantification est le suivant :

entier le plus proche
Avec : entier directement inférieur à
Équation 6 : Calcul de la quantification.

Et pour la quantification inverse :

Équation 7 : Calcul de la quantification inverse.

Comme le montre l'exemple ci-dessous, la quantification ramène beaucoup de coefficients à 0 (surtout en bas à droite dans la matrice, là où se trouvent les hautes fréquences). Seules quelques informations essentielles (concentrées dans le coin en haut à gauche) sont gardées pour représenter le bloc. La redondance des données contenues dans le bloc augmente ainsi fortement, ce qui peut être exploité par un algorithme de compression : au moment de coder le résultat dans le fichier, la longue suite de zéros nécessitera très peu de place. Cependant, si la quantification est trop forte (= taux de compression trop élevé), il y aura trop peu de coefficients non nuls pour représenter fidèlement le bloc. Le problème apparaîtra lors du décodage nécessaire pour l'affichage de l'image : à l’écran la division en blocs deviendra visible, et l'image aura un aspect « pixellisé ».

Dans notre exemple, nous avons pris la matrice de quantification suivante :

Équation 8 : Matrice définissant le niveau de quantification.

Ce qui donne comme matrice des fréquences quantifiée :

Équation 9 : Matrice quantifiée.

Codage, compression RLE et Huffman

[modifier | modifier le code]

Le codage s’effectue en zigzag comme le montre la figure suivante et se termine par un caractère de fin :

Ordre de codage défini par la norme JPEG
Figure 2 : Ordre de codage défini par la norme JPEG.

Codage de notre exemple : .

Ce résultat est ensuite compressé selon un algorithme RLE basé sur la valeur 0 (le codage RLE intervient uniquement sur cette dernière), puis un codage entropique de type Huffman ou arithmétique.

Avec le schéma de codage très simplifié suivant, on remarque que le codage nous délivre deux tables (quatre pour une image couleur). Ces tables étant enregistrées dans le fichier final peuvent être choisies par le compresseur.

Schéma de codage simplifié
Figure 3 : Schéma de codage simplifié.

Décompression JPEG

[modifier | modifier le code]

Les étapes de la décompression s’effectuent dans l’ordre inverse de la compression suivant les méthodes définies précédemment (en même temps que la compression).

Voici dans notre exemple le résultat de la décompression :

Équation 10 : Résultat de la décompression.

Ainsi que la matrice d’erreur :

Équation 11 : Matrice des erreurs réalisées par les pertes.

Les erreurs sont au maximum de 5 et en moyenne 1,6 sur environ 150 ce qui nous donne une erreur moyenne d’environ 1 %, et tout cela pour un passage de 64 à 10 valeurs (avec le caractère de fin) ; à cela, il faut rajouter la matrice de quantification, mais comme généralement on compresse de gros fichiers, elle n’influence que peu.

JPEG, codage sans pertes

[modifier | modifier le code]

Ici, la précision p des échantillons varie de 2 à 16 bits. À la place de la DCT, le codage utilise un prédicteur P à trois échantillons.

Schéma de compression JPEG sans pertes
Figure 4 : Schéma de compression JPEG sans pertes.

Syntaxe et structure

[modifier | modifier le code]

JPEG peut désigner soit le codage d'une image, soit le format de fichier. En effet, différents formats de fichiers (TIFF, PDF, JPG…) peuvent contenir une image codée en JPEG. On parlera dans ce paragraphe du format de fichier (aussi appelé JFIF pour JPEG File Interchange Format).

Un fichier JPEG est constitué d'une séquence de segments commençant par un marqueur. Un marqueur se compose de la valeur 0xFF suivie d'un octet identifiant le type de marqueur. Certains marqueurs ne contiennent que ces deux octets ; d'autres sont suivis de deux octets spécifiant la taille en octets des données du segment. Cette taille inclut ces deux octets de taille mais pas ceux du marqueur.

Marqueurs JPEG courants[5]
Abréviation Valeur Contenu Nom Commentaires
SOI 0xFFD8 aucun Start Of Image Premiers mots du fichier
SOF0 0xFFC0 taille variable Start Of Frame (Baseline DCT) Indique une image codée par baseline DCT, et spécifie la largeur, la hauteur, le nombre de composantes et le sous-échantillonnage des composantes (par exemple 4:2:0).
SOF2 0xFFC2 taille variable Start Of Frame (Progressive DCT) Indique une image codée par progressive DCT, et spécifie la largeur, la hauteur, le nombre de composantes et le sous-échantillonnage des composantes (par exemple 4:2:0).
DHT 0xFFC4 taille variable Define Huffman Table(s) Spécifie une ou plusieurs tables d'Huffman.
DQT 0xFFDB taille variable Define Quantization Table(s) Spécifie une ou plusieurs tables de quantification.
DRI 0xFFDD deux octets Define Restart Interval Spécifie l'intervalle entre les marqueurs RSTn, en macroblocs. Ce marqueur est suivi de deux octets indiquant sa taille de sorte qu'il puisse être traité comme n'importe quel segment de taille variable.
SOS 0xFFDA taille variable Start Of Scan Commence un parcours de haut en bas de l'image. Dans les codages baseline DCT, il n'y a généralement qu'un seul parcours. Les images progressive DCT contiennent habituellement plusieurs parcours. Ce marqueur spécifie quelle tranche de données il contient. La taille n'est pas indiquée : il est immédiatement suivi par des données codées entropiquement. Les octets 0xFF sont suivis par un octet 0x00 pour ne pas être confondus avec des marqueurs.
RSTn 0xFFD0 … 0xFFD7 aucun Restart Insère tous les r macroblocs, où r est l'intervalle DRI (cf. marqueur DRI). Il n'est pas utilisé s'il n'y a pas de marqueur DRI. Les trois bits de poids faible du code de marqueur varient en boucle de 0 à 7.
APPn 0xFFEn taille variable Application-specific Ce marqueur permet d'inclure des informations qu'un programme de visualisation peut ignorer tout en restant capable de décoder l'image. Par exemple, un fichier JPEG Exif utilise un marqueur APP1 pour enregistrer des métadonnées, organisées selon une structure proche du formatage TIFF.
COM 0xFFFE taille variable Commentaire Contient un commentaire textuel.
EOI 0xFFD9 aucun End Of Image Derniers mot du fichier

Articles connexes

[modifier | modifier le code]

Notes et références

[modifier | modifier le code]
  1. « JPEG Docs », (consulté le )
  2. (en) Site de Asure Software - nouveau nom de Forgent depuis 2007
  3. (en)« Patent Asserted Against JPEG Standard Rejected by Patent Office as Result of PUBPAT Request », sur pubpat.org, (consulté le )
  4. (en) Majid Rabbani et Paul W Jones, Digital Image Compression Techniques, Bellingham, Spie Optical Engineering Press, , 240 p. (ISBN 0-8194-0648-1, OCLC 23142891, lire en ligne)
  5. « ISO/IEC 10918-1 : 1993(E) p.36 »