Изменения

Перейти к: навигация, поиск

Арифметическое кодирование

362 байта добавлено, 20:17, 17 июня 2016
Intro bugfix
'''Арифметическое кодирование''' (англ. ''Arithmetic coding'') {{---}} алгоритм сжатия информации без потерь, который при кодировании ставит в соответствие тексту вещественное число из отрезка <tex>[0; 1)</tex>.
Данный метод, как и [[Алгоритм Хаффмана|алгоритм Хаффмана]], является [[Энтропия случайного источника|энтропийным]], т.е. длина кода конкретного символа зависит от частоты встречаемости этого символа в тексте. Арифметическое кодирование показывает более высокие результаты сжатия, чем алгоритм Хаффмана, для данных с неравномерными распределениями вероятностей кодируемых символов. Кроме того, при арифметическом кодировании каждый символ кодируется нецелым числом бит, что эффективнее кода Хаффмана (теоретически, символу <tex>a</tex> с вероятностью появления <tex>p(a)</tex> допустимо ставить в соответствие код длины <tex>-\log_2 p(a)</tex>, следовательно, при кодировании алгоритмом Хаффмана это достигается только с вероятностями, равными обратным степеням двойки). К недостаткам Однако, несмотря на преимущества арифметического кодирования можно отнести несовершенство , существует проблема при его практическом применении из-за несовершенства представления чисел с плавающей точкой в памяти компьютера {{--- }} поскольку некоторые дробные числа не могут быть точно представлены в машинном слове двоичном коде, используемом современными процессорами (например, <tex>\fracdfrac{1}{3}</tex>), границы символов будут округлены, что может повлечь за собой неверную работу алгоритма при больших объёмах данных. В общем случае, алгоритм можно модифицировать так, чтобы результатом было дробное число.
== Принцип действия ==
48
правок

Навигация