Дельта-компрессия

Дельта-компрессия

Дельта-кодирование (Delta encoding) — способ сохранения или передачи данных в форме разницы (дельты) между последовательными данными вместо самих данных. Это часто называется дельта-компрессия, потому что некоторые образцы кодирования могут получать кодированные данные в более коротком виде, чем исходные данные.

Пожалуй, наиболее простой пример заключается в сохранении значений байтов как различия (дельты) между последовательными значениями, в отличие от самих значений. Поэтому вместо 2, 4, 6, 9, 7, мы будем сохранять 2, 2, 2, 3, −2. Это не очень полезно в случае, когда используется само по себе, но может помочь в случае дальнейшей компрессии этих данных, в которых часто встречаются повторяющиеся значения. Например, звуковой формат IFF 8SVX применяет это кодирование к чистым звуковым данным перед тем, как применять к ним компрессию. К сожалению, только 8-битные звуковые сэмплы хорошо сжимаются в случае дельта-кодирования, а в случае 16-битных и выше сэмплов этот метод работает хуже. Поэтому, алгоритмы компрессии часто выбирают дельта-кодирование только тогда, когда сжатие с ним лучше, чем без него. Однако, в сжатии видео дельта-фреймы могут значительно уменьшать размер фрейма, и используются практически в каждом видео-кодеке.

Вариация дельта-кодирования, которая кодирует различия между префиксами или суффиксами строк, называется инкрементным кодированием. Оно в частности эффективно для отсортированных списков с малыми различиями между строками, такими, например, как список слов из словаря.

В дельта-кодированной передаче по сети, где только единичная копия файла доступна на каждом конце коммуникационного канала, используются специальные коды коррекции ошибок для обнаружения того, какие части файла изменились со времени предыдущей версии.

Природа данных, которые будут закодированы, влияет на эффективность частного алгоритма сжатия. Дельта-кодирование работает превосходно в том случае, когда данные имеют маленькую или постоянную вариацию; для неотсортированного набора данных сжатие с помощью этого метода может быть малым или вообще невозможным.

Следующий код на Си осуществляет простую форму дельта-кодирования и декодирования:

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

Другой случай использования дельта-кодирования — это стандарт RFC 3229, «Delta encoding in HTTP» (Дельта-кодирование в протоколе HTTP), который предполагает, что

См. также

Ссылки

  • RFC 3229 — Delta Encoding in HTTP
  • RFC 3284 — The VCDIFF Generic Differencing and Compression Data Format

Wikimedia Foundation. 2010.

Игры ⚽ Нужно сделать НИР?

Полезное


Смотреть что такое "Дельта-компрессия" в других словарях:

  • Subversion — У этого термина существуют и другие значения, см. Subversion (игра). Subversion Логотип Subversion Тип централизованная …   Википедия

  • SVN — Subversion Логотип Subversion Тип система управления версиями Разработчик CollabNet, Inc. Написана на C …   Википедия

  • SubVersion — Логотип Subversion Тип система управления версиями Разработчик CollabNet, Inc. Написана на C …   Википедия

  • Svn — Subversion Логотип Subversion Тип система управления версиями Разработчик CollabNet, Inc. Написана на C …   Википедия

  • ГОСТ 22670-77: Сеть связи цифровая интегральная. Термины и определения — Терминология ГОСТ 22670 77: Сеть связи цифровая интегральная. Термины и определения оригинал документа: 10. n ичный сигнал электросвязи n агу digital signal Цифровой сигнал электросвязи, имеющий п возможных состояний представляющего параметра,… …   Словарь-справочник терминов нормативно-технической документации

  • Сжатие с использованием вейвлет — Вейвлетное сжатие  общее название класса методов кодирования изображений, использующих двумерное вейвлет разложение кодируемого изображения или его частей. Обычно подразумевается сжатие с потерей качества. Существенную роль в алгоритмах… …   Википедия

  • Вейвлетное сжатие — Вейвлетное сжатие  общее название класса методов кодирования изображений, использующих двумерное вейвлет разложение кодируемого изображения или его частей. Обычно подразумевается сжатие с потерей качества. Существенную роль в алгоритмах… …   Википедия

  • Сжатие аудиоданных — В Википедии …   Википедия

  • Сжатие данных — Возможно, эта статья содержит оригинальное исследование. Добавьте ссылки на источники, в противном случае она может быть выставлена на удаление. Дополнительные сведения могут быть на странице обсуждения. (26 мая 2012) …   Википедия

  • Сжатие изображений — Сжатие изображений  применение алгоритмов сжатия данных к изображениям, хранящимся в цифровом виде. В результате сжатия уменьшается размер изображения, из за чего уменьшается время передачи изображения по сети и экономится пространство для… …   Википедия


Поделиться ссылкой на выделенное

Прямая ссылка:
Нажмите правой клавишей мыши и выберите «Копировать ссылку»