используйте FFmpeg для установки строгого значения GOP

Вопрос или проблема

Я прочитал множество документов и статей, но все же не получил ожидаемого результата. У меня есть файл с переменной значением GOP, потому что в видео есть некоторые вспышки. Поэтому я использую следующую команду, чтобы получить необходимое значение GOP.

ffmpeg -i Input.MXF -pix_fmt yuv420p -flags +ildct+ilme -vcodec mpeg2video -top 1 -dc 10 -intra_vlc 1 -qmin 1 -lmin 1*QP2LAMBDA -vtag xd5c -x264opts scenecut:nal-hrd=cbr:open-gop=0:pic-struct:aud:force-cfr:keyint=15:keyint_min=15 -bf 2 -rc_max_vbv_use 1 -rc_min_vbv_use 1 -b:v 35000k -bufsize 35000k -minrate 35000k -maxrate 35000k -aspect 16:9 -r 29.97 -acodec copy -f mxf -y Output.MXF
ffmpeg версия 4.3.3-0+deb11u1 Copyright (c) 2000-2021 разработчики FFmpeg
  создано с помощью gcc 10 (Debian 10.2.1-6)
  конфигурация: --prefix=/usr --extra-version=0+deb11u1 --toolchain=hardened --libdir=/usr/lib/x86_64-linux-gnu --incdir=/usr/include/x86_64-linux-gnu --arch=amd64 --enable-gpl --disable-stripping --enable-avresample --disable-filter=resample --enable-gnutls --enable-ladspa --enable-libaom --enable-libass --enable-libbluray --enable-libbs2b --enable-libcaca --enable-libcdio --enable-libcodec2 --enable-libdav1d --enable-libflite --enable-libfontconfig --enable-libfreetype --enable-libfribidi --enable-libgme --enable-libgsm --enable-libjack --enable-libmp3lame --enable-libmysofa --enable-libopenjpeg --enable-libopenmpt --enable-libopus --enable-libpulse --enable-librabbitmq --enable-librsvg --enable-librubberband --enable-libshine --enable-libsnappy --enable-libsoxr --enable-libspeex --enable-libsrt --enable-libssh --enable-libtheora --enable-libtwolame --enable-libvidstab --enable-libvorbis --enable-libvpx --enable-libwavpack --enable-libwebp --enable-libx265 --enable-libxml2 --enable-libxvid --enable-libzmq --enable-libzvbi --enable-lv2 --enable-omx --enable-openal --enable-opencl --enable-opengl --enable-sdl2 --enable-pocketsphinx --enable-libmfx --enable-libdc1394 --enable-libdrm --enable-libiec61883 --enable-chromaprint --enable-frei0r --enable-libx264 --enable-shared
  libavutil      56. 51.100 / 56. 51.100
  libavcodec     58. 91.100 / 58. 91.100
  libavformat    58. 45.100 / 58. 45.100
  libavdevice    58. 10.100 / 58. 10.100
  libavfilter     7. 85.100 /  7. 85.100
  libavresample   4.  0.  0 /  4.  0.  0
  libswscale      5.  7.100 /  5.  7.100
  libswresample   3.  7.100 /  3.  7.100
  libpostproc    55.  7.100 / 55.  7.100
Угадан макет канала для входного потока #0.1 : стерео
Вход #0, mxf, из 'Input.MXF':
  Метаданные:
    operational_pattern_ul: 060e2b34.04010101.0d010201.01010900
    uid             : adab4424-2f25-4dc7-92ff-29bd000c0000
    generation_uid  : adab4424-2f25-4dc7-92ff-29bd000c0001
    company_name    : FFmpeg
    product_name    : OP1a Muxer
    product_version : 56.15.102
    product_uid     : adab4424-2f25-4dc7-92ff-29bd000c0002
    material_package_umid: 0x060A2B340101010501010D00132A51BF52947134FB2A51BF0052947134FB2A00
    timecode        : 00:00:00:00
  Длительность: 00:00:09.21, начало: 0.000000, битрейт: 37152 kb/s
    Поток #0:0: Видео: mpeg2video (Main), yuv420p(tv, top first), 1920x1080 [SAR 1:1 DAR 16:9], 29.97 fps, 29.97 tbr, 29.97 tbn, 59.94 tbc
    Метаданные:
      file_package_umid: 0x060A2B340101010501010D00132A51BF52947134FB2A51BF0052947134FB2A01
    Данные на стороне:
      cpb: битрейт макс/мин/сред: 35000000/0/0 размер буфера: 35012608 vbv_delay: N/A
    Поток #0:1: Аудио: pcm_s24le, 48000 Hz, стерео, s32 (24 бит), 2304 kb/s
    Метаданные:
      file_package_umid: 0x060A2B340101010501010D00132A51BF52947134FB2A51BF0052947134FB2A01
Отображение потоков:
  Поток #0:0 -> #0:0 (mpeg2video (native) -> mpeg2video (native))
  Поток #0:1 -> #0:1 (копия)
Нажмите [q] для остановки, [?] для помощи
[mpeg2video @ 0x5619674fb1c0] Предупреждение: vbv_delay будет установлен на 0xFFFF (=VBR), так как указанный vbv buffer слишком велик для данного битрейта!
Выход #0, mxf, на 'Output.MXF':
  Метаданные:
    operational_pattern_ul: 060e2b34.04010101.0d010201.01010900
    uid             : adab4424-2f25-4dc7-92ff-29bd000c0000
    generation_uid  : adab4424-2f25-4dc7-92ff-29bd000c0001
    company_name    : FFmpeg
    product_name    : OP1a Muxer
    product_version : 56.15.102
    product_uid     : adab4424-2f25-4dc7-92ff-29bd000c0002
    material_package_umid: 0x060A2B340101010501010D00132A51BF52947134FB2A51BF0052947134FB2A00
    timecode        : 00:00:00:00
    энкодер         : Lavf58.45.100
    Поток #0:0: Видео: mpeg2video (Main) (xd5c / 0x63356478), yuv420p(top first), 1920x1080 [SAR 1:1 DAR 16:9], q=1-31, 35000 kb/s, 29.97 fps, 29.97 tbn, 29.97 tbc
    Метаданные:
      file_package_umid: 0x060A2B340101010501010D00132A51BF52947134FB2A51BF0052947134FB2A01
      энкодер         : Lavc58.91.100 mpeg2video
    Данные на стороне:
      cpb: битрейт макс/мин/сред: 35000000/35000000/35000000 размер буфера: 35000000 vbv_delay: N/A
    Поток #0:1: Аудио: pcm_s24le, 48000 Hz, стерео, s32 (24 бит), 2304 kb/s
    Метаданные:
      file_package_umid: 0x060A2B340101010501010D00132A51BF52947134FB2A51BF0052947134FB2A01
frame=  276 fps= 85 q=1.3 Lsize=   41682kB time=00:00:09.17 bitrate=37212.9kbits/s speed=2.83x
видео:38832kB аудио:2590kB субтитры:0kB другие потоки:0kB глобальные заголовки:0kB накладные расходы на мультиплексирование: 0.628826%

Тем не менее, значение GOP результата не N=3, M=15, а равно N=3, M=12.

Ниже приведено время кода I-кадров файла.

pkt_pts_time=0.000000
pkt_pts_time=0.500500
pkt_pts_time=1.001000
pkt_pts_time=1.501500
pkt_pts_time=2.002000
pkt_pts_time=2.502500
pkt_pts_time=2.702700
pkt_pts_time=2.802800
pkt_pts_time=2.902900
pkt_pts_time=3.403400
pkt_pts_time=3.903900
pkt_pts_time=4.404400
pkt_pts_time=4.904900
pkt_pts_time=5.405400
pkt_pts_time=5.905900
pkt_pts_time=6.406400
pkt_pts_time=6.906900
pkt_pts_time=7.407400
pkt_pts_time=7.907900
pkt_pts_time=8.408400
pkt_pts_time=8.908900

и это время кода I-кадра результата.

pkt_pts_time=0.000000
pkt_pts_time=0.400400
pkt_pts_time=0.800800
pkt_pts_time=1.201200
pkt_pts_time=1.601600
pkt_pts_time=2.002000
pkt_pts_time=2.402400
pkt_pts_time=2.702700
pkt_pts_time=2.902900
pkt_pts_time=3.303300
pkt_pts_time=3.703700
pkt_pts_time=4.104100
pkt_pts_time=4.504500
pkt_pts_time=4.904900
pkt_pts_time=5.305300
pkt_pts_time=5.705700
pkt_pts_time=6.106100
pkt_pts_time=6.506500
pkt_pts_time=6.906900
pkt_pts_time=7.307300
pkt_pts_time=7.707700
pkt_pts_time=8.108100
pkt_pts_time=8.508500
pkt_pts_time=8.908900

Есть ли предложения по команде FFmpeg для принудительной установки GOP на N=3, M=15?

Удалите опцию -x264opts. Добавьте -g 15 -sc_threshold 1G -flags +cgop.

Ответ или решение

Когда вы работаете с FFmpeg, чтобы установить строгое значение GOP (Group of Pictures), необходимо корректно настроить параметры кодирования для достижения нужного результата. Исходя из информации, предоставленной вами, вы пытаетесь сформировать GOP с параметрами N=3 и M=15, однако ваши текущие настройки приводят к значению N=3 и M=12. Это может происходить из-за конфликтующих параметров в вашей команде.

Для достижения желаемого результата, я бы порекомендовал следующие действия:

  1. Удалите конфликты с параметрами: Ваша текущая команда использует -x264opts, что может противоречить установке GOP для кодека mpeg2video. Вместо этого, манипулируйте параметрами, специализированными для mpeg2.

  2. Откорректируйте параметры GOP:

    • Используйте -g 15, чтобы задать максимальную длину GOP.
    • Используйте -sc_threshold 1000000000 (или любое другое большое значение), чтобы минимизировать влияние обнаружения сцен на ваш GOP.
    • Убедитесь, что выставлен флаг для закрытого GOP: -flags +cgop (если ваш контекст действительно требует закрытого GOP).
  3. Обратите внимание на vbv буфер: Убедитесь, что параметры vbv (Video Buffering Verifier) согласованы. Сообщение о предупреждении указывает, что заданный буфер vbv слишком велик для указанного битрейта, что может вызывать непредвиденные изменения в I-кадрах и, следовательно, в GOP.

Также важно убедиться, что ваши комплексные значения битрейта правильны и соответствуют вашим ожиданиям о параметрах кадрирования:

ffmpeg -i Input.MXF -pix_fmt yuv420p -flags +ildct+ilme -vcodec mpeg2video -top 1 -dc 10 -intra_vlc 1 -qmin 1 -lmin 1*QP2LAMBDA -vtag xd5c -bf 2 -g 15 -sc_threshold 1000000000 -flags +cgop -rc_max_vbv_use 1 -rc_min_vbv_use 1 -b:v 35000k -bufsize 35000k -minrate 35000k -maxrate 35000k -aspect 16:9 -r 29.97 -acodec copy -f mxf -y Output.MXF

Заключение: Эти изменения должны помочь вам достичь более предсказуемой структуры GOP. Убедитесь, что подобранные вами параметры тестируются на небольшом сегменте видео, чтобы быстро получать обратную связь о влиянии изменений. При необходимости экспериментируйте с параметрами, чтобы соответствовать специфическим потребностям вашего видео.

Оцените материал
Добавить комментарий

Капча загружается...