Kodowanie FFmpeg + NVENC: dziwny współczynnik kształtu

0

Moje źródłowe wideo to MPEG-2, 720x576, DAR = 16: 9. Za pomocą FFmpeg i kodera h264_nvenc przekonwertowałem go na H.264. Problem: AR wyjściowy jest dziwny / zły / niespójny. Wiersz poleceń:

>ffmpeg -i "d:\in.mpg" -aspect 16:9 -c:v h264_nvenc -c:a copy -t 15 "d:\out.mp4"
ffmpeg version N-83280-gcba4f0e Copyright (c) 2000-2017 the FFmpeg developers
  built with gcc 5.4.0 (GCC)
  configuration: --disable-static --enable-shared --enable-gpl --enable-version3 --enable-cuda --enable-cuvid --enable-d3d11va --enable-dxva2 --enable-libmfx --enable-nvenc --enable-avisynth --enable-bzlib --enable-fontconfig --enable-frei0r --enable-gnutls --enable-iconv --enable-libass --enable-libbluray --enable-libbs2b --enable-libcaca --enable-libfreetype --enable-libgme --enable-libgsm --enable-libilbc --enable-libmodplug --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libopenh264 --enable-libopenjpeg --enable-libopus --enable-librtmp --enable-libsnappy --enable-libsoxr --enable-libspeex --enable-libtheora --enable-libtwolame --enable-libvidstab --enable-libvo-amrwbenc --enable-libvorbis --enable-libvpx --enable-libwavpack --enable-libwebp --enable-libx264 --enable-libx265 --enable-libxavs --enable-libxvid --enable-libzimg --enable-lzma --enable-decklink --enable-zlib
  libavutil      55. 45.100 / 55. 45.100
  libavcodec     57. 75.100 / 57. 75.100
  libavformat    57. 65.100 / 57. 65.100
  libavdevice    57.  2.100 / 57.  2.100
  libavfilter     6. 71.100 /  6. 71.100
  libswscale      4.  3.101 /  4.  3.101
  libswresample   2.  4.100 /  2.  4.100
  libpostproc    54.  2.100 / 54.  2.100
[mpeg @ 000000000223ab20] start time for stream 0 is not set in estimate_timings_from_pts
Input #0, mpeg, from 'd:\in.mpg':
  Duration: 02:59:33.92, start: 0.500000, bitrate: 3401 kb/s
    Stream #0:0[0x1bf]: Data: dvd_nav_packet
    Stream #0:1[0x1c0]: Audio: mp2, 48000 Hz, stereo, s16p, 192 kb/s
    Stream #0:2[0x1e0]: Video: mpeg2video (Main), yuv420p(tv, top first), 720x576 [SAR 64:45 DAR 16:9], 25 fps, 25 tbr, 90k tbn, 50 tbc
File 'd:\out.mp4' already exists. Overwrite ? [y/N] y
Output #0, mp4, to 'd:\out.mp4':
  Metadata:
    encoder         : Lavf57.65.100
    Stream #0:0: Video: h264 (h264_nvenc) (Main) ([33][0][0][0] / 0x0021), yuv420p, 720x576 [SAR 64:45 DAR 16:9], q=-1--1, 2000 kb/s, 25 fps, 12800 tbn, 25 tbc
    Metadata:
      encoder         : Lavc57.75.100 h264_nvenc
    Side data:
      cpb: bitrate max/min/avg: 0/0/2000000 buffer size: 4000000 vbv_delay: -1
    Stream #0:1: Audio: mp2 (i[0][0][0] / 0x0069), 48000 Hz, stereo, s16p, 192 kb/s
Stream mapping:
  Stream #0:2 -> #0:0 (mpeg2video (native) -> h264 (h264_nvenc))
  Stream #0:1 -> #0:1 (copy)
Press [q] to stop, [?] for help
frame=  375 fps=0.0 q=22.0 Lsize=    4122kB time=00:00:14.97 bitrate=2254.9kbits/s dup=19 drop=0 speed=28.9x
video:3762kB audio:352kB subtitle:0kB other streams:0kB global headers:0kB muxing overhead: 0.208697%

W przypadku wyjściowego strumienia wideo napis „[SAR 64:45 DAR 16: 9]”, jednak jeśli przeanalizuję wynikowy plik out.mp4, powie:

Stream #0:0(und): Video: h264 (Main) (avc1 / 0x31637661), yuv420p, 720x576 [SAR 16:11 DAR 20:11], 2054 kb/s, SAR 64:45 DAR 16:9, 25 fps, 25 tbr, 12800 tbn, 50 tbc (default)

Wartości po nawiasach kwadratowych są prawidłowe, ale w nawiasach nie wiem, dlaczego używa tych wartości DAR / SAR. W zależności od tego, które wartości są używane przez odtwarzacz (kontener lub strumień AR) później, wynik może być nieprawidłowy. Nie ma znaczenia, czy użyto „-aspect 16: 9”, czy nie.

Jeśli użyję libx264 zamiast h264_nvenc, AR wyjściowy jest poprawny, więc myślę, że to problem z koderem. Korzystałem z najnowszej wersji, ale wcześniej korzystałem z oficjalnych wersji 3.2 i 3.2.2

Dziwi mnie, że nigdzie nie znalazłem tego samego problemu, więc przed zgłoszeniem tego błędu, chciałbym poprosić o opinię, czy robię coś źle. Dzięki.


źródło
Czy zachowanie różniło się od starszych wersji (takich jak wersje)?
llogan
Nie, dlatego wypróbowałem najnowszą wersję, aby sprawdzić, czy w międzyczasie mogła zostać naprawiona.
Jeśli dodasz -vf setdar=16:9, czy to pozwoli uniknąć problemu?
Gyan
Dzięki za podpowiedź. Nie, to nie zmienia wyniku. Nawet jeśli podam „-aspect 4: 3”, strumień DAR to 20: 11.Jednak jeśli podam „-vf setdar = 4: 3”, wynikowy strumień DAR to 15:11. Prawdopodobnie bierze pod uwagę wejściowy DAR, ale myślę, że 16: 9 jest wyraźnie docelowym DAR, nie może być odchylenia od niego.
Ciekawe: jeśli przygotuję filtr skali, zestaw AR jest ustawiany poprawnie. Ale działa to tylko wtedy, gdy naprawdę zmienię rozmiar, tj. Jeśli ustawię rozmiar docelowy równy rozmiarowi wejściowemu 720 x 576, ustawienie DAR nie ma wpływu.