WikiDer > Контекстно-адаптивное двоичное арифметическое кодирование
Контекстно-адаптивное двоичное арифметическое кодирование (CABAC) является формой энтропийное кодирование используется в H.264 / MPEG-4 AVC[1][2] и Высокоэффективное кодирование видео (HEVC) стандарты. Это сжатие без потерь метод, хотя стандарты кодирования видео, в которых он используется, обычно сжатие с потерями Приложения. CABAC отличается гораздо лучшими сжатие чем большинство других алгоритмов энтропийного кодирования, используемых при кодировании видео, и является одним из ключевых элементов, обеспечивающих схему кодирования H.264 / AVC с лучшей способностью сжатия, чем ее предшественники.
В H.264 / MPEG-4 AVC, CABAC поддерживается только в Main и выше профили (но не расширенный профиль) стандарта, так как он требует большего объема обработки для декодирования, чем более простая схема, известная как контекстно-адаптивное кодирование переменной длины (CAVLC), который используется в стандартном базовом профиле. CABAC также сложно распараллеливать и векторизовать, поэтому с его использованием могут быть связаны другие формы параллелизма (например, параллелизм пространственных областей). В HEVC CABAC используется во всех профилях стандарта.
Алгоритм
CABAC основан на арифметическое кодирование, с некоторыми нововведениями и изменениями для адаптации к требованиям стандартов кодирования видео:[3]
- Он кодирует двоичные символы, что снижает сложность и позволяет моделировать вероятность для более часто используемых битов любого символа.
- Вероятностные модели выбираются адаптивно на основе локального контекста, что позволяет лучше моделировать вероятности, поскольку режимы кодирования обычно локально хорошо коррелированы.
- Он использует деление диапазона без умножения за счет использования квантованный диапазоны вероятностей и вероятностные состояния.
CABAC имеет несколько вероятность режимы для разных контекстов. Сначала он преобразует все не-двоичный символы в двоичные. Затем для каждого бита кодер выбирает, какую модель вероятности использовать, а затем использует информацию из близлежащих элементов для оптимизации оценки вероятности. Арифметическое кодирование наконец применяется для сжатия данных.
Контекстное моделирование обеспечивает оценки условных вероятностей кодирующих символов. Используя подходящие контекстные модели, можно использовать данную межсимвольную избыточность, переключаясь между различными вероятностными моделями в соответствии с уже закодированными символами в окрестности текущего символа, который нужно кодировать. Контекстное моделирование обеспечивает примерно 10% -ную экономию CABAC в битрейт над CAVLC метод энтропийного кодирования.
Кодирование символа данных включает следующие этапы.
- Бинаризация: CABAC использует двоичное арифметическое кодирование, что означает, что кодируются только двоичные решения (1 или 0). Недвоичный символ (например, коэффициент преобразования или вектор движения) «бинаризуется» или преобразуется в двоичный код перед арифметическим кодированием. Этот процесс аналогичен процессу преобразования символа данных в код переменной длины, но двоичный код дополнительно кодируется (арифметическим кодером) перед передачей.
- Этапы повторяются для каждого бита (или «бина») двоичного символа.
- Выбор контекстной модели: «Контекстная модель» - это вероятностная модель для одного или нескольких бинов бинаризованного символа. Эта модель может быть выбрана из набора доступных моделей в зависимости от статистики недавно закодированных символов данных. Контекстная модель хранит вероятность того, что каждая ячейка будет равна «1» или «0».
- Арифметическое кодирование: арифметический кодер кодирует каждый интервал согласно выбранной вероятностной модели. Обратите внимание, что для каждого бина есть только два поддиапазона (соответствующие «0» и «1»).
- Обновление вероятности: выбранная контекстная модель обновляется на основе фактического кодированного значения (например, если значение интервала было «1», счетчик частоты «1» увеличивается).
пример
1. Бинаризуйте значение MVDx, разность векторов движения в Икс направление.
МВДИкс | Бинаризация |
---|---|
0 | 0 |
1 | 10 |
2 | 110 |
3 | 1110 |
4 | 11110 |
5 | 111110 |
6 | 1111110 |
7 | 11111110 |
8 | 111111110 |
Первый бит бинаризованного кодового слова - это ячейка 1; второй бит - это ячейка 2; и так далее.
2. Выберите контекстную модель для каждой корзины. Для бина 1 выбирается одна из 3 моделей на основе ранее закодированных значений MVD. Норма L1 двух ранее закодированных значений, ek, рассчитывается:
еk | Контекстная модель для корзины 1 |
---|---|
0 ≤ ek < 3 | Модель 0 |
3 ≤ ek < 33 | Модель 1 |
33 ≤ ek | Модель 2 |
Если еk мала, то велика вероятность, что действующее МВД будет иметь небольшую величину; наоборот, если ek велика, то более вероятно, что нынешняя МВД будет иметь большую величину. Соответственно выбираем таблицу вероятностей (контекстную модель). Остальные бины кодируются с использованием одной из 4 дополнительных контекстных моделей:
Корзина | Контекстная модель |
---|---|
1 | 0, 1 или 2 в зависимости от ek |
2 | 3 |
3 | 4 |
4 | 5 |
5 и выше | 6 |
3. Закодируйте каждую ячейку. Выбранная контекстная модель предоставляет две оценки вероятности: вероятность того, что ячейка содержит «1», и вероятность того, что ячейка содержит «0». Эти оценки определяют два поддиапазона, которые арифметический кодер использует для кодирования бина.
4. Обновите контекстные модели. Например, если контекстная модель 2 была выбрана для ячейки 1 и значение ячейки 1 было «0», счетчик частоты «0» увеличивается. Это означает, что в следующий раз, когда будет выбрана эта модель, вероятность получения «0» будет немного выше. Когда общее количество вхождений модели превышает пороговое значение, счетчики частоты для «0» и «1» будут уменьшены, что фактически дает более высокий приоритет последним наблюдениям.
Механизм арифметического декодирования
Арифметический декодер более подробно описан в Стандарте. Он имеет три различных свойства:
- Оценка вероятности выполняется посредством процесса перехода между 64 отдельными состояниями вероятности для «наименьшего вероятного символа» (LPS, наименее вероятное из двух двоичных решений «0» или «1»).
- Диапазон р Представление текущего состояния арифметического кодера квантуется до небольшого диапазона предварительно установленных значений перед вычислением нового диапазона на каждом шаге, что позволяет вычислить новый диапазон с использованием справочной таблицы (то есть без умножения).
- Упрощенный процесс кодирования и декодирования определяется для символов данных с почти равномерным распределением вероятностей.
Определение процесса декодирования предназначено для облегчения несложных реализаций арифметического кодирования и декодирования. В целом, CABAC обеспечивает повышенную эффективность кодирования по сравнению с кодированием на основе CAVLC за счет большей вычислительной сложности.
История
В 1986 г. IBM исследователи Коттаппурам М. А. Мохиуддин и Йорма Йоханнен Риссанен подали патент для алгоритма двоичного арифметического кодирования без умножения.[4][5] В 1988 году исследовательская группа IBM, в которую входили Р. Б. Арпс, Т. Чыонг, Д.Дж. Лу, В. Б. Пеннебейкер, Л. Митчелл и Г. Г. Лэнгдон представили алгоритм адаптивного двоичного арифметического кодирования (ABAC) под названием Q-Coder.[6][7]
Вышеупомянутые патенты и исследовательские работы, а также несколько других от IBM и Mitsubishi Electric, позже цитировались CCITT и Объединенная группа экспертов в области фотографии в качестве основы для JPEG сжатие изображений Адаптивный алгоритм двоичного арифметического кодирования формата в 1992 году.[4] Однако кодировщики и декодеры формата файлов JPEG, которые имеют параметры как для Кодирование Хаффмана и арифметическое кодирование, как правило, поддерживают только вариант кодирования Хаффмана, что изначально было связано с проблемами патентов, хотя патенты JPEG на арифметическое кодирование[8] срок действия истек из-за устаревания стандарта JPEG.[9]
В 1999 году Ёнджун Ю (Инструменты Техаса), Янг Гэп Квон и Антонио Ортега (Университет Южной Калифорнии) представила контекстно-адаптивную форму двоичного арифметического кодирования.[10] Современный алгоритм контекстно-адаптивного двоичного арифметического кодирования (CABAC) был коммерчески представлен с H.264 / MPEG-4 AVC формат в 2003 году.[11] Большинство патентов на формат AVC принадлежат Panasonic, Godo Kaisha IP Bridge и LG Electronics.[12]
Смотрите также
- Арифметическое кодирование
- Сжатие данных
- Сжатие без потерь
- Контекстно-адаптивное кодирование переменной длины (CAVLC)
Рекомендации
- ^ Ричардсон, Иэн Э. Г., Официальный документ H.264 / MPEG-4, часть 10, 17 октября 2002 г.
- ^ Ричардсон, Иэн Э. Г. (2003). Сжатие видео H.264 и MPEG-4: кодирование видео для мультимедиа следующего поколения. Чичестер: John Wiley & Sons Ltd.
- ^ Марпе Д., Шварц Х. и Виганд Т. Контекстно-ориентированное адаптивное двоичное арифметическое кодирование в стандарте сжатия видео H.264 / AVC, IEEE Trans. Схемы и системы для видеотехники, Vol. 13, No. 7, pp. 620–636, июль 2003 г.
- ^ а б «T.81 - ЦИФРОВОЕ СЖАТИЕ И КОДИРОВАНИЕ НЕПРЕРЫВНЫХ ТОНОВЫХ ИЗОБРАЖЕНИЙ - ТРЕБОВАНИЯ И РЕКОМЕНДАЦИИ» (PDF). CCITT. Сентябрь 1992 г.. Получено 12 июля 2019.
- ^ Патент США 4652856
- ^ Arps, R. B .; Truong, T. K .; Лу, Д. Дж .; Pasco, R.C .; Фридман, Т. Д. (ноябрь 1988 г.). «Многоцелевой чип СБИС для адаптивного сжатия данных двухуровневых изображений». Журнал исследований и разработок IBM. 32 (6): 775–795. Дои:10.1147 / rd.326.0775. ISSN 0018-8646.
- ^ Pennebaker, W. B .; Mitchell, J. L .; Langdon, G.G .; Арпс, Р. Б. (ноябрь 1988 г.). «Обзор основных принципов адаптивного двоичного арифметического кодера Q-Coder». Журнал исследований и разработок IBM. 32 (6): 717–726. Дои:10.1147 / rd.326.0717. ISSN 0018-8646.
- ^ "Рекомендация T.81 (1992) Исправление 1 (01/04)". Рекомендация T.81 (1992). Международный союз электросвязи. 9 ноября 2004 г.. Получено 3 февраля 2011.
- ^ Стандарт сжатия данных неподвижных изображений JPEG, В. Б. Пеннебейкер и Дж. Л. Митчелл, Kluwer Academic Press, 1992. ISBN 0-442-01272-1
- ^ Ортега, А. (октябрь 1999 г.). «Встроенное сжатие области изображений с использованием контекстных моделей». Труды Международной конференции по обработке изображений 1999 г. (кат. 99CH36348). 1: 477–481 т.1. Дои:10.1109 / ICIP.1999.821655.
- ^ «Контекстно-ориентированное адаптивное двоичное арифметическое кодирование (CABAC)». Институт Фраунгофера Генриха Герца. Получено 13 июля 2019.
- ^ «AVC / H.264 - Патентный список» (PDF). MPEG LA. Получено 6 июля 2019.