WikiDer > MPEG-1
Расширение имени файла | .dat, .mpg, .mpeg, .mp1, .mp2, .mp3, .m1v, .m1a, .m2a, .mpa, .mpv |
---|---|
Тип интернет-СМИ | аудио / MPEG, видео / MPEG |
Разработан | MPEG (часть ISO / IEC JTC 1) |
изначальный выпуск | 1993 |
Тип формата | аудио, видео, контейнер |
Расширен с | JPEG, H.261 |
Расширен до | MPEG-2 |
Стандарт | ISO/IEC 11172 |
MPEG-1 это стандарт за с потерями сжатие видео и аудио. Он предназначен для сжатия VHS- качественное необработанное цифровое видео и CD-аудио примерно до 1,5 Мбит / с (степень сжатия 26: 1 и 6: 1 соответственно)[1] без излишней потери качества, делая видео компакт-диски, цифровой кабель/спутник ТВ и цифровое аудиовещание (DAB) возможно.[2][3]
Сегодня MPEG-1 стал наиболее широко совместимым аудио / видео форматом с потерями в мире и используется в большом количестве продуктов и технологий. Пожалуй, самая известная часть стандарта MPEG-1 - это первая версия MP3 аудиоформат, который он представил.
Стандарт MPEG-1 опубликован как ISO/IEC 11172 - Информационные технологии - кодирование движущихся изображений и связанного звука для цифровых носителей со скоростью примерно до 1,5 Мбит / с.
Стандарт состоит из следующих пяти Запчасти:[4][5][6][7][8]
- Системы (хранение и синхронизация видео, аудио и других данных вместе)
- Видео (сжатый видеоконтент)
- Аудио (сжатый аудиоконтент)
- Тестирование на соответствие (проверка правильности реализации стандарта)
- Справочное программное обеспечение (пример программного обеспечения, показывающий, как кодировать и декодировать в соответствии со стандартом)
История
Предшественником MPEG-1 для кодирования видео был H.261 стандарт, произведенный CCITT (теперь известный как ITU-T). Базовая архитектура, установленная в H.261, была с компенсацией движения DCT гибридная структура кодирования видео.[9][10] Оно использует макроблоки размером 16 × 16 с блочной оценка движения в кодировщике и компенсация движения с использованием выбранного кодировщиком векторы движения в декодере с кодированием остаточной разности с использованием дискретное косинусное преобразование (DCT) размера 8 × 8, скалярный квантование, и коды переменной длины (например, Коды Хаффмана) за энтропийное кодирование.[11] H.261 был первым практическим стандартом кодирования видео, и все его описанные элементы дизайна также использовались в MPEG-1.[12]
Создан на основе успешного совместного подхода и технологий сжатия, разработанных Объединенная группа экспертов в области фотографии и CCITTГруппа экспертов по телефонии (создатели JPEG стандарт сжатия изображений и стандарт H.261 для видео-конференция соответственно), Группа экспертов по киноискусству (MPEG) рабочая группа была создана в январе 1988 г. по инициативе Хироши Ясуда (Nippon Telegraph and Telephone) и Леонардо Кьяриглионе (CSELT).[13] MPEG был создан для удовлетворения потребности в стандарт видео и аудио форматы, а также на основе H.261 для получения лучшего качества за счет использования несколько более сложных методов кодирования (например, поддержки более высокой точности для векторов движения).[2][14][15]
Разработка стандарта MPEG-1 началась в мае 1988 года. Четырнадцать предложений видео и четырнадцать аудио кодеков были представлены отдельными компаниями и учреждениями для оценки. Кодеки были тщательно протестированы на вычислительная сложность и субъективный (воспринимаемое человеком) качество при скорости передачи данных 1,5 Мбит / с. Этот конкретный битрейт был выбран для передачи через Т-1/E-1 линий и как приблизительная скорость передачи данных аудио компакт-диски.[16] Кодеки, показавшие отличные результаты в этом тестировании, были использованы в качестве основы для стандарта и доработаны, с добавлением дополнительных функций и других улучшений, включенных в процесс.[17]
После 20 собраний полной группы в различных городах по всему миру и 4,5 лет разработки и тестирования окончательный стандарт (для частей 1–3) был одобрен в начале ноября 1992 г. и опубликован через несколько месяцев.[18] Сообщаемая дата завершения стандарта MPEG-1 сильно различается: в сентябре 1990 года был выпущен в значительной степени полный проект стандарта, и с этого момента были внесены лишь незначительные изменения.[2] Проект стандарта был публично доступен для покупки.[19] Стандарт был завершен на собрании 6 ноября 1992 года.[20] Группа мультимедийных исследований плато Беркли разработала декодер MPEG-1 в ноябре 1992 года.[21] В июле 1990 года, еще до того, как был написан первый проект стандарта MPEG-1, началась работа над вторым стандартом, MPEG-2,[22] предназначен для расширения технологии MPEG-1 для обеспечения видео полного вещательного качества (согласно CCIR 601) с высокими битрейтами (3–15 Мбит / с) и поддержкой переплетенный видео.[23] Частично из-за схожести между двумя кодеками, стандарт MPEG-2 включает полную обратную совместимость с видео MPEG-1, поэтому любой декодер MPEG-2 может воспроизводить видео MPEG-1.[24]
Примечательно, что стандарт MPEG-1 очень строго определяет битовый поток, и функция декодера, но не определяет, как должно выполняться кодирование MPEG-1, хотя эталонная реализация предоставляется в ISO / IEC-11172-5.[1] Это означает, что MPEG-1 эффективность кодирования могут сильно различаться в зависимости от используемого кодировщика и, как правило, означает, что новые кодировщики работают значительно лучше, чем их предшественники.[25] Первые три части (Системы, Видео и Аудио) ISO / IEC 11172 были опубликованы в августе 1993 года.[26]
Часть | Число | Дата первого публичного выпуска (Первое издание) | Последнее исправление | Заголовок | Описание |
---|---|---|---|---|---|
Часть 1 | ИСО / МЭК 11172-1 | 1993 | 1999[28] | Системы | |
Часть 2 | ИСО / МЭК 11172-2 | 1993 | 2006[29] | видео | |
Часть 3 | ИСО / МЭК 11172-3 | 1993 | 1996[30] | Аудио | |
Часть 4 | ИСО / МЭК 11172-4 | 1995 | 2007[31] | Тестирование на соответствие | |
Часть 5 | ISO / IEC TR 11172-5 | 1998 | 2007[32] | Программное моделирование |
Патенты
Из-за своего возраста MPEG-1 больше не защищен какими-либо существенными патентами и, таким образом, может использоваться без получения лицензии или уплаты каких-либо сборов.[33][34][35][36][37] В патентной базе данных ISO указан один патент на ISO 11172, US 4 472 747, срок действия которого истек в 2003 году.[38] Почти полный проект стандарта MPEG-1 был общедоступен как ISO CD 11172.[19] к 6 декабря 1991 г.[39] Ни статья Kuro5hin за июль 2008 г. «Патентный статус MPEG-1, H.261 и MPEG-2», ни[40] ни ветки августа 2008 года на gstreamer-devel[41] В списке рассылки был указан единственный еще не истекший патент на MPEG-1 Video и MPEG-1 Audio Layer I / II. В ходе обсуждения в списке рассылки whatwg в мае 2009 г. был упомянут патент США 5 214 678, который, возможно, распространяется на MPEG-1 Audio Layer II.[42] Срок действия этого патента, поданного в 1990 г. и опубликованного в 1993 г., истек.[43]
Полноценный декодер и кодировщик MPEG-1 с "звуком уровня III" не мог быть реализован без лицензионных отчислений, поскольку были компании, которые требовали патентных сборов для реализации MPEG-1 Audio Layer III, как обсуждается в MP3 статья. Срок действия всех патентов в мире, связанных с MP3, истек 30 декабря 2017 года, что делает этот формат полностью бесплатным для использования.[нужна цитата] 23 апреля 2017 г. Фраунгофера IIS прекратила взимать плату за лицензионную программу Technicolor MP3 для некоторых патентов и программного обеспечения, связанных с MP3.[44]
Бывшие патентообладатели
Следующие корпорации подали заявления в ISO о том, что они владеют патентами на формат видео MPEG-1 (ISO / IEC-11172-2), хотя с тех пор срок действия всех таких патентов истек.[45]
- BBC
- Daimler Benz AG
- Fujitsu
- IBM
- Matsushita Electric Industrial Co., Ltd.
- Mitsubishi Electric
- NEC
- NHK
- Philips
- Pioneer Corporation
- Qualcomm
- Ricoh
- Sony
- Инструменты Техаса
- Томсон Мультимедиа
- Печать Топпан
- Toshiba
- Виктор Компания Японии
Приложения
- Самый популярный программного обеспечения для воспроизведения видео включает декодирование MPEG-1 в дополнение к любым другим поддерживаемым форматам.
- Популярность MP3 аудио установило массивный установленная база оборудования, которое может воспроизводить аудио MPEG-1 (все три уровня).
- "Практически все цифровые аудиоустройства"может воспроизводить аудио в формате MPEG-1.[46] На сегодняшний день продано много миллионов.
- Перед MPEG-2 получил широкое распространение, многие службы цифрового спутникового / кабельного телевидения использовали исключительно MPEG-1.[15][25]
- Широкая популярность MPEG-2 среди вещательных компаний означает, что MPEG-1 можно воспроизводить через большинство цифровых кабельных и спутниковых каналов. телеприставки, а также цифровые проигрыватели дисков и кассет, благодаря обратной совместимости.
- MPEG-1 использовался для полноэкранного видео на Зеленая книга CD-i, и дальше Видео CD (VCD).
- В Супер Видео CD стандарт, основанный на VCD, использует исключительно аудио MPEG-1, а также видео MPEG-2.
- В DVD-видео формат использует в первую очередь видео MPEG-2, но поддержка MPEG-1 явно определена в стандарте.
- Стандарт DVD-Video изначально требовал MPEG-1 Audio Layer II для стран PAL, но был изменен, чтобы разрешить AC-3 /Dolby Digital-только диски. MPEG-1 Audio Layer II по-прежнему разрешен на DVD, хотя более новые расширения формата, такие как Многоканальный MPEG, поддерживаются редко.
- Большинство DVD-плееров также поддерживают Video CD и MP3 CD воспроизведение, использующее MPEG-1.
- Международный Цифровое видеовещание (DVB) в основном использует MPEG-1 Audio Layer II и видео MPEG-2.
- Международный Цифровое аудиовещание Стандарт (DAB) использует исключительно MPEG-1 Audio Layer II из-за его особенно высокого качества, скромных требований к производительности декодера и устойчивости к ошибкам.
- В Цифровая компакт-кассета использует PASC (точное адаптивное поддиапазонное кодирование) для кодирования звука. PASC - это ранняя версия MPEG-1 Audio Layer I с фиксированной скоростью передачи данных 384 килобита в секунду.
Часть 1: Системы
Часть 1 стандарта MPEG-1 охватывает системы, и определен в ISO / IEC-11172-1.
Системы MPEG-1 определяют логическую схему и методы, используемые для хранения закодированных аудио, видео и других данных в стандартном потоке битов, а также для поддержания синхронизации между различным содержимым. Этот формат файла специально разработан для хранения на носителях и передачи через каналы связи, которые считаются относительно надежными. Стандарт определяет только ограниченную защиту от ошибок, а небольшие ошибки в потоке битов могут вызвать заметные дефекты.
Позднее это сооружение было названо Программный поток MPEG: "Дизайн системы MPEG-1 по существу идентичен структуре программного потока MPEG-2".[47] Эта терминология более популярна, точна (отличает ее от Транспортный поток MPEG) и будет использоваться здесь.
Элементарные потоки, пакеты и ссылки на часы
- Элементарные потоки (ES) - это необработанные потоки битов аудио- и видеоданных в формате MPEG-1 (выводимые кодировщиком). Эти файлы могут распространяться сами по себе, как в случае с файлами MP3.
- Пакетированные элементарные потоки (PES) - это элементарные потоки упакованный на пакеты переменной длины, т. е. разделенные ES на независимые блоки, где циклическая проверка избыточности (CRC) контрольная сумма был добавлен к каждому пакету для обнаружения ошибок.
- Системная тактовая частота (SCR) - это значение синхронизации, хранимое в 33-битном заголовке каждого PES с частотой / точностью 90 кГц, с дополнительным 9-битным расширением, в котором хранятся дополнительные данные синхронизации с точностью до 27 МГц.[48][49] Они вставляются кодировщиком на основе часов системного времени (STC). Однако одновременно кодированные аудио- и видеопотоки не будут иметь одинаковых значений SCR из-за буферизации, кодирования, дрожания и других задержек.
Программные потоки
Программные потоки (PS) связаны с объединением нескольких пакетированных элементарных потоков (обычно только одного аудио и видео PES) в один поток, обеспечивая одновременную доставку и поддерживая синхронизацию. Структура PS известна как мультиплекс, или формат контейнера.
Отметки времени представления (PTS) существуют в PS для исправления неизбежного несоответствия между значениями SCR аудио и видео (коррекция временной развертки). Значения PTS 90 кГц в заголовке PS сообщают декодеру, какие значения SCR видео соответствуют каким значениям SCR аудио.[48] PTS определяет, когда отображать часть программы MPEG, а также используется декодером, чтобы определить, когда данные могут быть отброшены из буфер.[50] Либо видео, либо аудио будут задержаны декодером до тех пор, пока не прибудет соответствующий сегмент другого и не будет декодирован.
Обработка PTS может быть проблематичной. Декодеры должны принимать несколько программные потоки которые были соединены (соединены последовательно). Это приводит к сбросу значений PTS в середине видео до нуля, которые затем снова начинают увеличиваться. Такие несоответствия циклического переноса PTS могут вызвать проблемы синхронизации, которые должны быть специально обработаны декодером.
Метки времени декодирования (DTS), кроме того, требуются из-за B-кадров. С B-кадрами в видеопотоке смежные кадры должны кодироваться и декодироваться вне очереди (переупорядоченные кадры). DTS очень похож на PTS, но вместо того, чтобы просто обрабатывать последовательные кадры, он содержит правильные временные метки, чтобы сообщить декодеру, когда декодировать и отображать следующий B-кадр (типы кадров, описанные ниже), перед его привязкой (P - или I-) кадр. Без B-кадров в видео значения PTS и DTS идентичны.[51]
Мультиплексирование
Для генерации PS мультиплексор будет чередовать (два или более) пакетированных элементарных потоков. Это сделано для того, чтобы пакеты одновременных потоков могли передаваться по одному и тому же канал и гарантированно поступят в декодер в одно и то же время. Это случай мультиплексирование с временным разделением.
Определение того, сколько данных из каждого потока должно быть в каждом чередующемся сегменте (размер чередования) - сложное, но важное требование. Неправильное чередование приведет к опустошению или переполнению буфера, поскольку получатель получает больше одного потока, чем он может сохранить (например, аудио), прежде чем он получит достаточно данных для декодирования другого одновременного потока (например, видео). MPEG Верификатор буферизации видео (VBV) помогает определить, может ли мультиплексированный PS декодироваться устройством с заданной скоростью передачи данных и размером буфера.[52] Это обеспечивает обратную связь с мультиплексором и кодировщиком, чтобы они могли изменять размер мультиплексора или регулировать битрейт по мере необходимости для соответствия.
Часть 2: Видео
Часть 2 стандарта MPEG-1 касается видео и определена в ISO / IEC-11172-2. На дизайн сильно повлияли H.261.
MPEG-1 Video использует методы перцептивного сжатия для значительного снижения скорости передачи данных, необходимой для видеопотока. Он уменьшает или полностью отбрасывает информацию в определенных частотах и областях изображения, которые человеческий глаз имеет ограниченную способность полностью воспринимать. Он также использует временную (по времени) и пространственную (по изображению) избыточность, обычную для видео, для достижения лучшего сжатия данных, чем было бы возможно в противном случае. (Видеть: Сжатие видео)
Цветовое пространство
Перед кодированием видео в MPEG-1 цветовое пространство преобразуется в Y′CbCr (Y '= Яркость, Cb = Цветовой синий, Cr = Цветовой Красный). Luma (яркость, разрешение) хранится отдельно от цветность (цвет, оттенок, фаза) и даже разделены на красный и синий компоненты.
Цветность также преобразуется в 4:2:0, что означает, что разрешение уменьшается вдвое по вертикали и вдвое по горизонтали, то есть до одной четверти количества выборок, используемых для компонента яркости видео.[1] Это использование более высокого разрешения для некоторых цветовых компонентов аналогично концепции Фильтр Байера который обычно используется для датчика захвата изображения в цифровых цветных камерах. Поскольку человеческий глаз гораздо более чувствителен к небольшим изменениям яркости (компонент Y), чем к цвету (компоненты Cr и Cb), субдискретизация цветности - очень эффективный способ уменьшить объем видеоданных, которые необходимо сжать. Однако на видео с мелкой детализацией (высокий пространственная сложность) это может проявляться как цветность сглаживание артефакты. По сравнению с другими цифровыми артефакты сжатия, эта проблема, кажется, очень редко вызывает раздражение. Из-за субдискретизации видео Y′CbCr 4: 2: 0 обычно сохраняется с четными размерами (делимый на 2 по горизонтали и вертикали).
Цвет Y'CbCr часто неофициально называют YUV для упрощения обозначений, хотя этот термин более правильно относится к несколько иному цветовому формату. Точно так же условия яркость и цветность часто используются вместо (более точных) терминов яркость и цветность.
Разрешение / битрейт
MPEG-1 поддерживает разрешение до 4095 × 4095 (12 бит) и скорость передачи до 100 Мбит / с.[15]
Видео MPEG-1 чаще всего просматривается с использованием Исходный формат ввода (SIF) разрешение: 352 × 240, 352 × 288 или 320 × 240. Эти относительно низкие разрешения в сочетании с битрейтом менее 1,5 Мбит / с составляют то, что известно как поток битов с ограниченными параметрами (CPB), позже переименованный в профиль «Низкий уровень» (LL) в MPEG-2. Это минимальные требования к видео. декодер должен уметь обрабатывать, чтобы считаться MPEG-1 послушный. Это было выбрано, чтобы обеспечить хороший баланс между качеством и производительностью, позволяя использовать достаточно недорогое оборудование того времени.[2][15]
Типы кадров / изображений / блоков
MPEG-1 имеет несколько типов кадров / изображений, которые служат разным целям. Самый важный, но самый простой - это I-рамка.
I-кадры
"I-frame" - это сокращение от "Внутрикадровый", так называемые, потому что они могут быть декодированы независимо от любых других кадров. Их также могут называть I-изображениями или ключевыми кадрами из-за того, что они в некоторой степени аналогичны функциям ключевые кадры используется в анимации. I-кадры можно считать фактически идентичными базовым JPEG изображений.[15]
Высокоскоростной поиск по видео MPEG-1 возможен только до ближайшего I-кадра. При нарезке видео невозможно начать воспроизведение сегмента видео до первого I-кадра в сегменте (по крайней мере, без перекодирования, требующего интенсивных вычислений). По этой причине в приложениях для редактирования используются видео MPEG только с I-кадром.
Сжатие только I-кадра выполняется очень быстро, но дает файлы очень больших размеров: в 3 раза (или более) больше, чем обычно кодированное видео MPEG-1, в зависимости от того, насколько сложным во времени является конкретное видео.[2] Видео MPEG-1 только с I-кадром очень похоже на MJPEG видео. Настолько, что очень быстрое и теоретически без потерь (на самом деле есть ошибки округления) преобразование из одного формата в другой может быть выполнено при соблюдении нескольких ограничений (цветовое пространство и матрица квантования) при создании битовый поток.[53]
Длина между I-кадрами известна как группа картинок (GOP) размер. MPEG-1 чаще всего использует размер GOP 15-18. т.е. 1 I-кадр на каждые 14-17 не-I-кадров (некоторая комбинация P- и B-кадров). В более интеллектуальных кодировщиках размер GOP выбирается динамически до некоторого предварительно выбранного максимального предела.[15]
Ограничения накладываются на максимальное количество кадров между I-кадрами из-за сложности декодирования, размера буфера декодера, времени восстановления после ошибок данных, возможности поиска и накопления ошибок IDCT в реализациях с низкой точностью, наиболее распространенных в аппаратных декодерах (см.: IEEE-1180).
P-обрамления
«P-frame» - это сокращение от «Predicted-frame». Их также можно назвать кадрами с прогнозированием вперед или межкадровый (B-кадры также являются межкадровыми).
P-кадры существуют для улучшения сжатия за счет использования временный (через некоторое время) избыточность в видео. P-рамки хранят только разница в изображении из кадра (I-кадра или P-кадра), непосредственно предшествующего ему (этот опорный кадр также называется якорь Рамка).
Разница между P-кадром и его якорным кадром рассчитывается с использованием векторы движения на каждой макроблок кадра (см. ниже). Такие данные вектора движения будут встроены в P-кадр для использования декодером.
P-кадр может содержать любое количество блоков с внутренним кодированием в дополнение к любым блокам с прямым предсказанием.[54]
Если видео резко меняется от одного кадра к другому (например, резать), более эффективно кодировать его как I-кадр.
B-кадры
«B-кадр» означает «двунаправленный кадр» или «двунаправленный кадр». Они также могут быть известны как кадры с обратным предсказанием или B-изображения. B-кадры очень похожи на P-кадры, за исключением того, что они могут делать прогнозы, используя как предыдущие, так и будущие кадры (то есть два якорных кадра).
Следовательно, игроку необходимо сначала декодировать следующий I- или P-кадр привязки последовательно после B-кадра, прежде чем B-кадр может быть декодирован и отображен. Это означает, что декодирование B-кадров требует большего буферы данных и вызывает увеличенную задержку как при декодировании, так и во время кодирования. Это также требует функции декодирования временных меток (DTS) в контейнерном / системном потоке (см. Выше). Таким образом, B-кадры долгое время вызывали много споров, их часто избегают в видео, а иногда и не полностью поддерживают аппаратные декодеры.
Никакие другие кадры не предсказываются из B-кадра. Из-за этого при необходимости можно вставить B-кадр с очень низким битрейтом, чтобы помочь контролировать битрейт. Если бы это было сделано с P-кадром, будущие P-кадры предсказывались бы на его основе, что снизило бы качество всей последовательности. Однако, аналогично, будущий P-кадр должен по-прежнему кодировать все изменения между ним и предыдущим I- или P-якорным кадром. B-кадры также могут быть полезны в видеороликах, где фон за объектом раскрывается в течение нескольких кадров, или при переходах с постепенным исчезновением изображения, например при смене сцены.[2][15]
B-кадр может содержать любое количество блоков с внутренним кодированием и блоков с прямым предсказанием в дополнение к блокам с обратным или двунаправленным предсказанием.[15][54]
D-рамки
MPEG-1 имеет уникальный тип кадра, которого нет в более поздних стандартах видео. «D-кадры» или DC-изображения представляют собой независимо кодированные изображения (внутрикадровые), которые были закодированы с использованием только коэффициентов преобразования постоянного тока (коэффициенты переменного тока удаляются при кодировании D-кадров - см. DCT ниже) и, следовательно, имеют очень низкое качество. На D-кадры никогда не ссылаются I-, P- или B-кадры. D-кадры используются только для быстрого предварительного просмотра видео, например, при поиске видео на высокой скорости.[2]
При наличии оборудования для декодирования с умеренно более высокой производительностью быстрый предварительный просмотр может быть выполнен путем декодирования I-кадров вместо D-кадров. Это обеспечивает более качественный предварительный просмотр, поскольку I-кадры содержат коэффициенты переменного тока, а также коэффициенты постоянного тока. Если кодер может предположить, что в декодерах доступна возможность быстрого декодирования I-кадров, он может сэкономить биты, не посылая D-кадры (таким образом улучшая сжатие видеоконтента). По этой причине D-кадры редко используются при кодировании видео MPEG-1, а функция D-кадра не была включена ни в какие более поздние стандарты кодирования видео.
Макроблоки
MPEG-1 работает с видео в виде последовательности блоков 8 × 8 для квантования. Однако для уменьшения скорости передачи данных, необходимой для векторов движения, и поскольку цветность (цвет) субдискретизируется с коэффициентом 4, каждая пара (красный и синий) блоков цветности соответствует 4 различным блокам яркости. Этот набор из 6 блоков с разрешением 16 × 16 обрабатывается вместе и называется макроблок.
Макроблок - это наименьшая независимая единица (цветного) видео. Векторы движения (см. Ниже) действуют исключительно на уровне макроблока.
Если высота или ширина видео не точны кратные из 16 полные строки и полные столбцы макроблоков все равно должны кодироваться и декодироваться, чтобы заполнить изображение (хотя дополнительные декодированные пиксели не отображаются).
Векторы движения
Чтобы уменьшить степень временной избыточности в видео, обновляются только изменяющиеся блоки (до максимального размера GOP). Это называется условным пополнением. Однако само по себе это не очень эффективно. Движение объектов и / или камеры может приводить к необходимости обновления больших частей кадра, даже если изменилось только положение ранее закодированных объектов. Посредством оценки движения кодер может компенсировать это движение и удалить большой объем избыточной информации.
Кодер сравнивает текущий кадр с соседними частями видео от опорного кадра (предыдущий I- или P-кадр) в форме ромба, до (кодер-специфического) предопределенная радиус предел от области текущего макроблока. Если совпадение найдено, только направление и расстояние (т.е. вектор из движение) из предыдущей области видео в текущий макроблок необходимо закодировать в межкадровый (P- или B-кадр). Обратный процесс, выполняемый декодером для восстановления изображения, называется компенсация движения.
Однако предсказанный макроблок редко полностью соответствует текущему изображению. Различия между предполагаемой областью совпадения и реальным кадром / макроблоком называется ошибкой предсказания. Чем больше ошибка прогнозирования, тем больше данных необходимо дополнительно закодировать в кадре. Для эффективного сжатия видео очень важно, чтобы кодер мог эффективно и точно выполнять оценку движения.
Векторы движения регистрируют расстояние между двумя областями на экране в зависимости от количества пикселей (также называемых пикселями). Видео MPEG-1 использует точность вектора движения (MV), равную половине одного пикселя или полупикселя. Чем выше точность MV, тем точнее будет совпадение и тем эффективнее будет сжатие. Однако есть компромиссы для более высокой точности. Более высокая точность MV приводит к использованию большего количества данных для представления MV, поскольку большие числа должны храниться в кадре для каждого отдельного MV, повышенная сложность кодирования, поскольку возрастающие уровни интерполяции в макроблоке требуются как для кодера, так и для декодера, и убывающая отдача (минимальный выигрыш) с более высокой точностью MV. Половинная точность была выбрана как идеальный компромисс на тот момент времени. (Видеть: qpel)
Поскольку соседние макроблоки, вероятно, будут иметь очень похожие векторы движения, эту избыточную информацию можно довольно эффективно сжимать, сохраняя DPCM-кодировано. В конечном потоке битов необходимо сохранить только (меньшую) разницу между MV для каждого макроблока.
P-кадры имеют один вектор движения каждого макроблока, по отношению к предыдущему кадру якоря. Однако B-кадры могут использовать два вектора движения; один из предыдущего якорного кадра и один из будущего якорного кадра.[54]
Частичные макроблоки и закодированные в видео черные границы / полосы, которые не попадают точно на границу макроблока, вызывают хаос в прогнозировании движения. Информация о заполнении / границе блока предотвращает близкое совпадение макроблока с любой другой областью видео, и поэтому для каждого из нескольких десятков частичных макроблоков вдоль границы экрана необходимо кодировать значительно большую информацию об ошибке прогнозирования. Кодирование и квантование DCT (см. Ниже) также не так эффективно, когда в блоке есть большой / резкий контраст изображения.
Еще более серьезная проблема существует с макроблоками, которые содержат значимые, случайные, краевой шум, где изображение становится (обычно) черным. Все вышеперечисленные проблемы также относятся к краевому шуму. К тому же добавленную случайность просто невозможно значительно сжать. Все эти эффекты существенно снизят качество (или увеличат битрейт) видео.
DCT
Каждый блок 8 × 8 кодируется первым применением вперед дискретное косинусное преобразование (FDCT), а затем процесс квантования. Процесс FDCT (сам по себе) теоретически не имеет потерь и может быть отменен путем применения Обратный DCT (IDCT) для воспроизведения исходных значений (при отсутствии ошибок квантования и округления). В действительности, есть некоторые (иногда большие) ошибки округления, вносимые как квантованием в кодере (как описано в следующем разделе), так и ошибкой аппроксимации IDCT в декодере. Минимально допустимая точность аппроксимации IDCT декодера определяется ISO / IEC 23002-1. (До 2006 г. IEEE 1180-1990.)
Процесс FDCT преобразует блок 8 × 8 несжатых значений пикселей (значения яркости или цветового различия) в индексированный массив 8 × 8 частотный коэффициент значения. Одним из них является (статистически высокая дисперсия) «коэффициент постоянного тока», который представляет собой среднее значение всего блока 8 × 8. Остальные 63 коэффициента представляют собой статистически меньшие «коэффициенты переменного тока», которые имеют положительные или отрицательные значения, каждое из которых представляет синусоидальные отклонения от значения плоского блока, представленного коэффициентом постоянного тока.
Пример закодированного блока FDCT 8 × 8: