Какой кодек, чтобы избежать Recompression в YouTube и Vimeo
Какой кодек использовать для сжатия видео, которые youtube и vimeo не сжимают? чтобы избежать потери качества рекомпрессии
@Chris позвольте мне сделать это более конкретным (я опубликовал общий вопрос, чтобы другие могли извлечь из этого пользу). Я использую Sony Vegas и кодек Sony AVC/mvc @1920x1080 30 кадр / с с кодировкой CABAC @12 Мбит, но YouTube повторно сжимает видео, и когда я выбираю его для просмотра с тем же разрешением (1080p), видео становится более размытым. Я попробую webM и посмотрю, что произойдет, я еще не загрузил на vimeo то же видео @ 1080p
[править] Существует ли верхний предел пропускной способности (т. е. 15 Мбит) для YouTube и Vimeo?
2 ответа
На avp.stackexchange.com есть отличный ответ для YouTube-кодеков и не только
Немного общей информации об используемых форматах: YouTube использует 4 контейнерных формата и 3 различных кодека. От популярности видео зависит, какие кодеки используются для вашего видео (см. Ниже, почему). Как правило, каждое загруженное вами видео будет закодировано в h.264 и будет мультиплексировано в контейнеры.flv и.mp4. Это стандарт, и это будет происходить для каждого видео. Хотя.flv будет использоваться только для разрешений ниже 720p. Это означает, что в контейнере.flv будут только 360p и 480p. Хотя каждое видео ниже 720p также будет иметь версию mp4 для максимально возможного разрешения: 360p или 480p. Для 240p YouTube использует 3gp, который является довольно старым кодеком, предназначенным для мобильных устройств (задолго до эры смартфонов), он также поставляется в формате.3gp.
Другой используемый кодек - это VP8, который поставляется в формате контейнера WebM. WebM - это формат, разработанный Google и задуманный как стандартный видеокодек для HTML5, хотя его поддержка не очень велика. Даже на YouTube очень мало видео кодируется в WebM, WebM был представлен в HTML5-версии YouTube. YouTube только кодирует некоторые видео в WebM после того, как они были загружены, и в основном это только популярные видео (по тем видео, которые я видел, закодированные в WebM), поэтому нет уверенности, что ваше видео будет присутствовать в WebM.
Что касается вашего связанного вопроса (может быть, они должны быть объединены?)
Какой кодек / контейнер вы должны использовать для загрузки?
Это зависит, если вы ограничены / обеспокоены скоростью загрузки, тогда используйте h.264 Level 3.1/4.1 с Основным профилем для SD или Высоким профилем для HD и аудио AAC. YouTube прекрасно это воспримет и будет выглядеть хорошо после того, как закодирован серверами YouTube. Но имейте в виду, что YouTube ВСЕГДА будет кодировать ваше видео после его загрузки, независимо от того, какой кодек и настройки вы используете. Поэтому, если вы хотите получить теоретически лучшее качество для своих загрузок, выберите кодек без потерь для загрузки или, по крайней мере, визуально без потерь. Посмотрите на YouTube как на конечный результат в формате доставки / потребителя, а загрузка на YouTube - последний шаг в производстве, и в процессе производства вы хотите остаться без потерь. Но, пожалуйста, обратите внимание, что это всего лишь теоретическая вещь, на практике я бы сказал, что это действительно не имеет значения, поскольку мы говорим о YouTube, а не о телевизионном вещании или кино.
Но если вы действительно хотите сделать это "идеальным" способом, используйте производственный кодек, а не потребительский кодек, такой как h.264. MJPEG будет хорошим кодеком для этого, YouTube определенно поддерживает его в контейнере.avi или.mov. MJPEG - это кодек с потерями, но визуальное качество будет таким же, как и у источника (если вы выбрали достаточно высокое значение качества, это практически JPEG в качестве видеокодека). Переход на настоящий кодек без потерь, по моему мнению, был бы пустой тратой дискового пространства и пропускной способности.
Но если вы хотите загрузить видео без потерь и не беспокоиться о времени загрузки, я рекомендую использовать стандартный кодек QuickTime, поскольку они почти все должны поддерживаться YouTube (обратите внимание, что не все из них без потерь, h264 также стандартный кодек QuickTime). Хотя YouTube не сообщает, какие кодеки QuickTime поддерживаются, к сожалению. Я думаю, анимация или JPEG2000 должны работать. Оба кодека могут быть на 100% без потерь.
Для аудио используйте PCM, если вы хотите остаться без потерь с аудио, но опять же, это действительно просто теоретическое улучшение качества. AAC будет выполнять ту же работу по качеству и будет меньше. Я рекомендую битрейт не менее 192 кбит / с для AAC. YouTube преобразует это в ~24 Кбит / с (Mobile aka 3gp) ~64 Кбит / с (240p), ~128 Кбит / с (360p/480p) и ~192 Кбит / с (720p+).
Что касается частоты кадров, если вы можете выбрать, а затем использовать 25FPS во время записи / анимации, YouTube нравится это больше всего (частота кадров, используемая для каждого видео), но если ваши кадры уже поступают с другой частотой кадров, то придерживайтесь этого и не t интерполировать вверх или вниз до 25 кадров в секунду. YouTube будет обрабатывать конверсию для вас и обычно делает это лучше, чем ваш кодировщик. Им приходится иметь дело со всеми типами кадровых скоростей каждый день, и они решили эту (на самом деле очень сложную) проблему очень хорошо
Для Vimeo вы должны взглянуть на Vimeo-рекомендации. Вы должны использовать H.264-кодек. Потому что тогда им не нужно его распаковывать
Методические рекомендации:
Кодек: H.264
Кодек - это формат, в котором будет закодировано ваше видео. Vimeo принимает большинство основных видеокодеков, но для достижения наилучших результатов мы рекомендуем использовать H.264. Если вы загружаете видео высокой четкости (HD), выберите настройку Высокий профиль H.264 вместо основного профиля. Расширенные настройки H.264. Чтобы сделать загрузку более плавной, выберите следующие расширенные настройки, когда это возможно.
- Закрытая Республиканская партия
- CABAC (чтобы уменьшить размер файла)
Вы не можете избежать повторного сжатия входного видео YouTube или другими лицами. Они никогда не примут все как есть. Это подтвердили исследователи YouTube. Цитата из исследовательской статьи YouTube:*
[Мы] нормализуем файлы перед транскодированием, создавая мезонин с высоким битрейтом и постоянной частотой кадров.
На это есть несколько причин:
Видеокодеки/форматы могут быть странными (из-за отсутствия лучшего слова). Существует множество различных кодеров, и они могут создавать потоки битов со специальными атрибутами, которые могут поддерживаться не всеми компонентами архитектуры потоковой передачи. Например, декодирование может работать неправильно, могут быть неправильные временные метки или, возможно, пользователь пытался загрузить вредоносный файл, пытаясь использовать ошибки в программном обеспечении. Вы не хотите с этим иметь дело. Вам нужен единый тип видеоформата («промежуточный формат» или «мезонин»), при котором вы знаете, что он не нарушит существующую инфраструктуру. Таким образом, вы преобразуете входящее видео в этот формат, и дальнейшая обработка будет проще.
Оптимизация качества: YouTube и другие компании лучше всех знают, как им нужно сжимать видео, чтобы на выходе было хорошее качество и низкий битрейт. Они тратят огромное количество процессорного времени и человеческих усилий на оптимизацию этого аспекта. Они не будут просто воспринимать ваше видео как есть.
Адаптивная потоковая передача HTTP в том виде, в котором она используется в наши дни, требует создания разных наборов видео для разных типов клиентов (например, потоковая передача 4K в современный браузер на настольном компьютере отличается от потоковой передачи видео с низким разрешением на устаревшее устройство Android). Таким образом, даже если бы у вас был хорошо сжатый входной файл, YouTube все равно пришлось бы генерировать десятки альтернативных масштабированных версий.
* Ковелл и др. 2016, Оптимизация целевых показателей качества транскодера с использованием нейронной сети со встроенной моделью битрейта.