Move-To-Front

Move-To-Front

Движение к началу (англ. move-to-front, MTF) — преобразование для кодирования данных (обычно потока байтов), разработанное для улучшения производительности энтропийного кодирования. При хорошей реализации, оно достаточно быстро для включения как дополнительный шаг в алгоритмах сжатия данных. Также может использоваться совместно с BWT, преобразованием Барроуза — Уилера.

Содержание

Алгоритм

Основной идеей преобразования является замена каждого входного символа его номером в специальном стеке недавно использованных символов. Последовательности идентичных символов, к примеру, будут заменены оригинальным алгоритмом (начиная со второго символа) на последовательность нулей. Если же символ долго не появлялся во входной последовательности, он будет заменен большим числом. Преобразование заменяет последовательность входных символов на последовательность целых чисел, если во входных данных было много локальных корреляций, то среди этих чисел будут преобладать небольшие, лучше сжимаемые энтропийным кодированием, чем исходные данные.

Алгоритм впервые описан в работе [1]. Изначально алгоритм назывался «стопка книг» («book stack»). История разработки алгоритма рассказана в [2].

Часто используется при преобразовании байтов. Изначально каждое возможное значение байта записывается в список, в ячейку с номером равным значению байта, т.е. (0, 1, 2, 3, …, 255). В процессе обработки данных этот список изменяется. Первый обработанный символ заменяется самим собой, после чего элемент, соответствующий этому символу перемещается в голову списка (сдвигая элементы с 0 по свое положение на 1 вправо). Последующие символы кодируются номером элемента, содержащего их значение. После кодирования каждого символа эти элементы также продвигаются к голове списка.

Пример

Рассмотрим работу алгоритма на алфавите из английских букв (пронумеруем их с нуля). Возьмем слово

bananaaa

b - записан в элементе с номером 1. После передвигания b в голову списка, b станет нулевым, а а - 1ым Оно будет преобразовано в

1,1,13,1,1,1,0,0

Алгоритмы, использующие MTF

Литература

  1. Ryabko, B. Ya. Data compression by means of a «book stack», Problems of Information Transmission, 1980, v. 16: (4), pp. 265—269.
  2. Ryabko, B. Ya.; Horspool, R. Nigel; Cormack, Gordon V. Comments to: «A locally adaptive data compression scheme» by J. L. Bentley, D. D. Sleator, R. E. Tarjan and V. K. Wei. Comm. ACM 30 (1987), no. 9, 792—794.



Wikimedia Foundation. 2010.

Игры ⚽ Нужен реферат?

Полезное


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

  • Move-To-Front — (englisch „Nach vorne verschieben“) ist ein Kodierungsverfahren, das sich gut eignet, um Daten, die aus der Burrows Wheeler Transformation stammen, weiterzuverarbeiten, um sie anschließend effektiver komprimieren zu können. Inhaltsverzeichnis 1… …   Deutsch Wikipedia

  • Move-to-Front — (englisch „Nach vorne verschieben“) ist ein Kodierungsverfahren, das sich gut eignet, um Daten, die aus der Burrows Wheeler Transformation stammen, weiterzuverarbeiten, um sie anschließend effektiver komprimieren zu können. Inhaltsverzeichnis 1… …   Deutsch Wikipedia

  • Move To Front — (englisch „Nach vorne verschieben“) ist ein Kodierungsverfahren, das sich gut eignet, um Daten, die aus der Burrows Wheeler Transformation stammen, weiterzuverarbeiten, um sie anschließend effektiver komprimieren zu können. Inhaltsverzeichnis 1… …   Deutsch Wikipedia

  • Move to front — (englisch „Nach vorne verschieben“, auch: Rotierende Kodierung) ist ein Kodierungsverfahren, das sich gut eignet, um Daten, die aus der Burrows Wheeler Transformation stammen, weiterzuverarbeiten, um sie anschließend effektiver komprimieren zu… …   Deutsch Wikipedia

  • Move-to-front — L algorithme MTF (pour Move to Front, déplacer vers l avant) est un système de transformation de flot utilisé notamment dans le domaine de la compression de données en informatique. Il consiste à remplacer chaque caractère par un indice, donné… …   Wikipédia en Français

  • Move to Front — L algorithme MTF (pour Move to Front, déplacer vers l avant) est un système de transformation de flot utilisé notamment dans le domaine de la compression de données en informatique. Il consiste à remplacer chaque caractère par un indice, donné… …   Wikipédia en Français

  • Move-To-Front — L algorithme MTF (pour Move to Front, déplacer vers l avant) est un système de transformation de flot utilisé notamment dans le domaine de la compression de données en informatique. Il consiste à remplacer chaque caractère par un indice, donné… …   Wikipédia en Français

  • Move-to-front transform — The move to front transform (or MTF) is an encoding of data (typically a stream of bytes) designed to improve the performance of entropy encoding techniques of compression. When efficiently implemented, it is fast enough that its benefits usually …   Wikipedia

  • Move-to-front heuristic — …   Википедия

  • Front loop — is the name given to a trick performed by a windsurfer (also known as a forward loop) whereby the rider performs a jump from a wave face and forces the sail, board and rider to perform a forward somersault in one motion. In its basic form, the… …   Wikipedia


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

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