Арифметическое кодирование: различия между версиями
w>NickShaforostoff м |
w>Thijs!bot м (robot Adding: nl:Aritmetische codering) |
||
Строка 12: | Строка 12: | ||
[[Категория:Теория кодирования]] | [[Категория:Теория кодирования]] | ||
+ | |||
[[de:Arithmetisches Kodieren]] | [[de:Arithmetisches Kodieren]] | ||
[[en:Arithmetic coding]] | [[en:Arithmetic coding]] | ||
[[ja:算術符号]] | [[ja:算術符号]] | ||
+ | [[nl:Aritmetische codering]] | ||
[[pl:Kodowanie arytmetyczne]] | [[pl:Kodowanie arytmetyczne]] | ||
[[pt:Codificação aritmética]] | [[pt:Codificação aritmética]] | ||
[[zh:算术编码]] | [[zh:算术编码]] |
Версия от 01:43, 25 декабря 2006
Характеристики
Обеспечивает лучшую степень сжатия чем алгоритм Хаффмана. На каждый символ требуется почти бит, где — информационная энтропия источника.
Принцип действия
Пусть у нас есть некий алфавит, а также данные о частотности использования символов (опционально). Тогда рассмотрим на координатной прямой отрезок о 0 до 1.
Назовём этот отрезок рабочим. Расположим на нём точки таким образом, что длины образованных отрезков будут равны частоте использования символа и каждый такой отрезок будет соответствовать одному символу.
Теперь возьмём символ из потока и найдём для него отрезок, среди только что сформированных, теперь отрезок для этого символа стал рабочим. Разобьём его таким же образом, как разбили отрезок от 0 до 1. Выполним эту операцию для некоторого числа последовательных символов. Затем выберем любое число из рабочего отрезка. Биты этого числа вместе с длиной его битовой записи и есть результат арифметического кодирования использованных символов потока.
de:Arithmetisches Kodieren en:Arithmetic coding ja:算術符号 nl:Aritmetische codering pl:Kodowanie arytmetyczne pt:Codificação aritmética zh:算术编码