Codage différentiel

Un article de Wikipédia, l'encyclopédie libre.

Le codage différentiel (appelé aussi compression delta) est une techniques de compression de données sans perte consistant à transformer des données par la série des différences entre données successives. Ce type de codage est particulièrement efficace lorsque les données sont stockées avec leur historique, comme le font les logiciels de gestion de versions.

Implémentation en C[modifier | modifier le code]

Le code ci-dessous, en langage C, est une implémentation « naïve » de la compression (et décompression) delta:

void
delta_encode (char *buffer, const unsigned int length)
{
 char delta = 0;
 char original;
 unsigned int i;
 for (i = 0; i < length; ++i)
 {
 original = buffer[i];
 buffer[i] -= delta;
 delta = original;
 }
}

void
delta_decode (char *buffer, const unsigned int length)
{
 char delta = 0;
 unsigned int i;
 for (i = 0; i < length; ++i)
 {
 buffer[i] += delta;
 delta = buffer[i];
 }
}

Exemples d'applications[modifier | modifier le code]

Le codage différentiel en HTTP[modifier | modifier le code]

Un exemple d'utilisation du codage différentiel est la RFC 3229[1], « Delta Encoding in HTTP » (littéralement « Codage différentiel en HTTP »), qui suggère que les serveurs HTTP devraient être capable de transmettre les mises à jour des pages Web sous forme de différences entre les versions (deltas), dans le but de réduire le trafic Internet généré, étant donné que la plupart des pages n'évoluent que très lentement, et ne sont pas totalement modifiées à chaque mise à jour.

VCDIFF[modifier | modifier le code]

VCDIFF est un format standard de codage différentiel, décrit dans la RFC 3284[2]. Xdelta et open-vcdiff sont des exemples de logiciels libres implémentant ce format.

GDIFF[modifier | modifier le code]

Le Generic Diff Format (GDIFF) est un autre format de codage différentiel. Il a été proposé au W3C en 1997[3]. Dans ce nombreux cas, VCDIFF produit un meilleur taux de compression que GDIFF.

Diff[modifier | modifier le code]

Diff est un outil de comparaison de fichiers principalement utilisé pour les fichiers texte.

Voir aussi[modifier | modifier le code]

Articles connexes[modifier | modifier le code]

Liens externes[modifier | modifier le code]

  • RFC 3229[1] – Delta Encoding in HTTP

Références[modifier | modifier le code]