Вопрос или проблема
Я прочитал множество документов и статей, но все же не получил ожидаемого результата. У меня есть файл с переменной значением 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. Это может происходить из-за конфликтующих параметров в вашей команде.
Для достижения желаемого результата, я бы порекомендовал следующие действия:
-
Удалите конфликты с параметрами: Ваша текущая команда использует
-x264opts
, что может противоречить установке GOP для кодека mpeg2video. Вместо этого, манипулируйте параметрами, специализированными для mpeg2. -
Откорректируйте параметры GOP:
- Используйте
-g 15
, чтобы задать максимальную длину GOP. - Используйте
-sc_threshold 1000000000
(или любое другое большое значение), чтобы минимизировать влияние обнаружения сцен на ваш GOP. - Убедитесь, что выставлен флаг для закрытого GOP:
-flags +cgop
(если ваш контекст действительно требует закрытого GOP).
- Используйте
-
Обратите внимание на 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. Убедитесь, что подобранные вами параметры тестируются на небольшом сегменте видео, чтобы быстро получать обратную связь о влиянии изменений. При необходимости экспериментируйте с параметрами, чтобы соответствовать специфическим потребностям вашего видео.