[FFmpeg-user] Dolby E decoder
Paul B Mahol
onemda at gmail.com
Sun Sep 10 11:13:51 EEST 2017
On 9/10/17, Mike Brown <brown at mrvideo.vidiot.com> wrote:
> On Sat, Sep 09, 2017 at 05:24:24PM +0300, foo86 wrote:
>> On Fri, Sep 08, 2017 at 05:08:54PM -0500, Mike Brown wrote:
>> > On Fri, Sep 08, 2017 at 03:55:35PM +0200, Paul B Mahol wrote:
>> > > You need to override input decoder so S302 is not used.
>> >
>> > Any update on how I override the s302 decoder?
>>
>> You don't want to override s302m decoder, it has to be used to process
>> non-PCM data in TS to obtain s337m compliant stream that FFmpeg will
>> recognize as such and decode as Dolby E.
>>
>> -non_pcm_mode copy parameter has to be passed to s302m decoder since by
>> default it drops non-PCM.
>>
>> Correct command line for your case (extract and decode 20-bit Dolby E)
>> would be:
>>
>> ffmpeg -non_pcm_mode copy -i input_test.ts -map 0:1 -c:a pcm_s24le -f
>> s24le out.dat
>> ffmpeg -i out.dat out.wav
>
> Here is the result:
>
> ffmpeg -non_pcm_mode copy -i input_test.ts -map 0:1 -c:a pcm_s24le -f s24le
> out.dat
> ffmpeg version N-87196-g6cadbb1 Copyright (c) 2000-2017 the FFmpeg
> developers
> built with gcc 7.1.0 (GCC)
> configuration: --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-zlib
> libavutil 55. 74.100 / 55. 74.100
> libavcodec 57.105.100 / 57.105.100
> libavformat 57. 81.100 / 57. 81.100
> libavdevice 57. 8.100 / 57. 8.100
> libavfilter 6.101.100 / 6.101.100
> libswscale 4. 7.103 / 4. 7.103
> libswresample 2. 8.100 / 2. 8.100
> libpostproc 54. 6.100 / 54. 6.100
> [s302m @ 000000000049d560] S302 non PCM mode with data type 28 not supported
> Last message repeated 1 times
> [mpeg2video @ 000000000049c4e0] Invalid frame dimensions 0x0.
> [s302m @ 000000000049d560] S302 non PCM mode with data type 28 not supported
> [mpeg2video @ 000000000049c4e0] Invalid frame dimensions 0x0.
> [s302m @ 000000000049d560] S302 non PCM mode with data type 28 not supported
> [mpeg2video @ 000000000049c4e0] Invalid frame dimensions 0x0.
> [s302m @ 000000000049d560] S302 non PCM mode with data type 28 not supported
> [mpeg2video @ 000000000049c4e0] Invalid frame dimensions 0x0.
> [s302m @ 000000000049d560] S302 non PCM mode with data type 28 not supported
> [mpeg2video @ 000000000049c4e0] Invalid frame dimensions 0x0.
> [s302m @ 000000000049d560] S302 non PCM mode with data type 28 not supported
> [mpeg2video @ 000000000049c4e0] Invalid frame dimensions 0x0.
> [s302m @ 000000000049d560] S302 non PCM mode with data type 28 not supported
> [mpeg2video @ 000000000049c4e0] Invalid frame dimensions 0x0.
> [s302m @ 000000000049d560] S302 non PCM mode with data type 28 not supported
> [mpeg2video @ 000000000049c4e0] Invalid frame dimensions 0x0.
> [s302m @ 000000000049d560] S302 non PCM mode with data type 28 not supported
> [mpeg2video @ 000000000049c4e0] Invalid frame dimensions 0x0.
> [s302m @ 000000000049d560] S302 non PCM mode with data type 28 not supported
> Last message repeated 18 times
> [mpegts @ 00000000005670e0] decoding for stream 1 failed
> [mpegts @ 00000000005670e0] PES packet size mismatch
> Last message repeated 2 times
> [mpegts @ 00000000005670e0] Could not find codec parameters for stream 1
> (Audio: s302m (BSSD / 0x44535342), stereo, s32 (20 bit), 2304 kb/s):
> unspecified sample rate
> Consider increasing the value for the 'analyzeduration' and 'probesize'
> options
> Input #0, mpegts, from 'input_test.ts':
> Duration: 00:00:19.19, start: 94349.992444, bitrate: 43715 kb/s
> Program 1
> Stream #0:0[0x31]: Video: mpeg2video (Main) ([2][0][0][0] / 0x0002),
> yuv420p(tv, bt709, top first), 1920x1080 [SAR 1:1 DAR 16:9], Closed
> Captions, 40266 kb/s, 29.97 fps, 29.97 tbr, 90k tbn, 59.94 tbc
> Stream #0:1[0x33](eng): Audio: s302m (BSSD / 0x44535342), stereo, s32
> (20 bit), 2304 kb/s
> Stream #0:2[0x34](eng): Audio: mp2 ([3][0][0][0] / 0x0003), 48000 Hz,
> stereo, s16p, 256 kb/s
> Stream #0:3[0x35](eng): Audio: mp2 ([3][0][0][0] / 0x0003), 48000 Hz,
> stereo, s16p, 256 kb/s
> Stream #0:4[0x3b]: Data: bin_data (LU-A / 0x412D554C)
> Stream mapping:
> Stream #0:1 -> #0:0 (s302m (native) -> pcm_s24le (native))
> Press [q] to stop, [?] for help
> Output #0, s24le, to 'out.dat':
> Metadata:
> encoder : Lavf57.81.100
> Stream #0:0(eng): Audio: pcm_s24le, 48000 Hz, stereo, s32 (20 bit), 2304
> kb/s
> Metadata:
> encoder : Lavc57.105.100 pcm_s24le
> [mpegts @ 00000000005670e0] PES packet size mismatch
> [s302m @ 00000000022924e0] frame has invalid header
> Error while decoding stream #0:1: Invalid data found when processing input
> size= 5330kB time=00:00:18.95 bitrate=2304.0kbits/s speed= 202x
> video:0kB audio:5330kB subtitle:0kB other streams:0kB global headers:0kB
> muxing overhead: 0.000000%
>
>
> ffmpeg -i out.dat out.wav
> ffmpeg version N-87196-g6cadbb1 Copyright (c) 2000-2017 the FFmpeg
> developers
> built with gcc 7.1.0 (GCC)
> configuration: --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-zlib
> libavutil 55. 74.100 / 55. 74.100
> libavcodec 57.105.100 / 57.105.100
> libavformat 57. 81.100 / 57. 81.100
> libavdevice 57. 8.100 / 57. 8.100
> libavfilter 6.101.100 / 6.101.100
> libswscale 4. 7.103 / 4. 7.103
> libswresample 2. 8.100 / 2. 8.100
> libpostproc 54. 6.100 / 54. 6.100
> [dolby_e @ 000000000034ba60] Stream has 2 programs (configuration 0),
> channels will be output in native order.
> Input #0, s337m, from 'out.dat':
> Duration: N/A, bitrate: N/A
> Stream #0:0: Audio: dolby_e, 53706 Hz, 7.1, fltp
> Stream mapping:
> Stream #0:0 -> #0:0 (dolby_e (native) -> pcm_s16le (native))
> Press [q] to stop, [?] for help
> [dolby_e @ 00000000003ef760] Stream has 2 programs (configuration 0),
> channels will be output in native order.
> Output #0, wav, to 'out.wav':
> Metadata:
> ISFT : Lavf57.81.100
> Stream #0:0: Audio: pcm_s16le ([1][0][0][0] / 0x0001), 53706 Hz, 7.1,
> s16, 6874 kb/s
> Metadata:
> encoder : Lavc57.105.100 pcm_s16le
> size= 15876kB time=00:00:18.91 bitrate=6874.6kbits/s speed= 126x
> video:0kB audio:15876kB subtitle:0kB other streams:0kB global headers:0kB
> muxing overhead: 0.000627%
>
>
> ffmpeg -drc_scale 0 -i out.wav -c:a ac3 -ab 640k -center_mixlev 0.707
> output_test.ac3
> ffmpeg version N-87196-g6cadbb1 Copyright (c) 2000-2017 the FFmpeg
> developers
> built with gcc 7.1.0 (GCC)
> configuration: --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-zlib
> libavutil 55. 74.100 / 55. 74.100
> libavcodec 57.105.100 / 57.105.100
> libavformat 57. 81.100 / 57. 81.100
> libavdevice 57. 8.100 / 57. 8.100
> libavfilter 6.101.100 / 6.101.100
> libswscale 4. 7.103 / 4. 7.103
> libswresample 2. 8.100 / 2. 8.100
> libpostproc 54. 6.100 / 54. 6.100
> Input #0, wav, from 'out.wav':
> Metadata:
> encoder : Lavf57.81.100
> Duration: 00:00:18.92, bitrate: 6874 kb/s
> Stream #0:0: Audio: pcm_s16le ([1][0][0][0] / 0x0001), 53706 Hz, 7.1,
> s16, 6874 kb/s
> Codec AVOption drc_scale (percentage of dynamic range compression to apply)
> specified for input file #0 (out.wav) has not been used for any stream. The
> most likely reason is either wrong type (e.g. a video option with no video
> streams) or that it is a private option of some decoder which was not
> actually used for any stream.
> Stream mapping:
> Stream #0:0 -> #0:0 (pcm_s16le (native) -> ac3 (native))
> Press [q] to stop, [?] for help
> [ac3 @ 000000000044eee0] invalid sample rate
Looks like you need to resample audio to sample rate ac3 supports.
More information about the ffmpeg-user
mailing list