#4861 closed defect (fixed)
E-AC3 audio glitch : exponent out-of-range
Reported by: | Guillaume | Owned by: | |
---|---|---|---|
Priority: | normal | Component: | avcodec |
Version: | git-master | Keywords: | eac3 |
Cc: | Michael Niedermayer, eric@lapsus.org, cschieli@gmail.com | Blocked By: | |
Blocking: | Reproduced by developer: | yes | |
Analyzed by developer: | no |
Description (last modified by )
I'm trying to decode an AC3 file extracted from live French TV stream.
3 audio glitches can be heard in the sample file.
During conversion, error logs are returned.
$ ffmpeg -i audio_ac3_glitch.ac3 audio_test.wav ffmpeg version 2.7 Copyright (c) 2000-2015 the FFmpeg developers built with gcc 4.8 (Ubuntu 4.8.2-19ubuntu1) configuration: libavutil 54. 27.100 / 54. 27.100 libavcodec 56. 41.100 / 56. 41.100 libavformat 56. 36.100 / 56. 36.100 libavdevice 56. 4.100 / 56. 4.100 libavfilter 5. 16.101 / 5. 16.101 libswscale 3. 1.101 / 3. 1.101 libswresample 1. 2.100 / 1. 2.100 [eac3 @ 0xa387a00] Estimating duration from bitrate, this may be inaccurate Input #0, eac3, from 'audio_ac3_glitch.ac3': Duration: 00:00:45.57, start: 0.000000, bitrate: 127 kb/s Stream #0:0: Audio: eac3, 48000 Hz, stereo, fltp, 128 kb/s Output #0, wav, to 'audio_test.wav': Metadata: ISFT : Lavf56.36.100 Stream #0:0: Audio: pcm_s16le ([1][0][0][0] / 0x0001), 48000 Hz, stereo, s16, 1536 kb/s Metadata: encoder : Lavc56.41.100 pcm_s16le Stream mapping: Stream #0:0 -> #0:0 (eac3 (native) -> pcm_s16le (native)) Press [q] to stop, [?] for help [eac3 @ 0xa388be0] exponent out-of-range [eac3 @ 0xa388be0] error decoding the audio block [eac3 @ 0xa388be0] exponent out-of-range [eac3 @ 0xa388be0] error decoding the audio block [eac3 @ 0xa388be0] exponent out-of-range [eac3 @ 0xa388be0] error decoding the audio block [eac3 @ 0xa388be0] incomplete frame size= 8550kB time=00:00:45.60 bitrate=1536.0kbits/s video:0kB audio:8550kB subtitle:0kB other streams:0kB global headers:0kB muxing overhead: 0.000891%
Same errors occur when trying to stream this file using a GSTreamer pipeline :
gst-launch-1.0 -v --gst-debug-level=3 filesrc location=./audio_ac3_glitch.ac3 ! ac3parse ! avdec_eac3 ! audioconvert ! playsink
We can notice that the errors seem related to audio glitches heard.
I've tried to modify the code in file libavcodec/ac3dec.c in function ac3_decode_frame() where trying to decode the audio blocks generates the log "error decoding the audio block\n". Without success.
Attachments (1)
Change History (25)
by , 9 years ago
Attachment: | small-audio_ac3_glitch.ac3 added |
---|
comment:1 by , 9 years ago
Description: | modified (diff) |
---|---|
Keywords: | audio glitch removed |
Reproduced by developer: | set |
Status: | new → open |
comment:2 by , 9 years ago
Cc: | added |
---|
Is there a decoder that plays this without any errors/glitches ?
comment:4 by , 9 years ago
Keywords: | eac3 added; AC3 removed |
---|---|
Summary: | AC3 audio glitch : exponent out-of-range → E-AC3 audio glitch : exponent out-of-range |
No audible glitches with my hardware decoder.
comment:5 by , 9 years ago
Cc: | added |
---|
comment:7 by , 9 years ago
Cc: | added |
---|
comment:8 by , 9 years ago
This bug is very annoying and occurs more often in speech than music. On a talkshow, this can be several times per minute.
I observe it on each DVB-T recording and occasionally in other sources.
Conversion with ffmpeg shows an "exponent out-of-range" error for each glitch.
However, some errors reported are not audible.
The same DVB-T sample reads fine for me on two hardware players and with MPC-HC v1.3.1249.0 on a very old PC that received tons of codecs and upgrades over the years. On the same PC, the glitches occur with VideoLAN player.
On a new PC, I cannot read this sample with whatever I test. Probably because most players use ffmpeg... And yes, I tested with the latest version.
comment:9 by , 8 years ago
Same for me on french DVB channels with eac3.
This affected all channel and happens all the time. No problem before the france switch to the eac3.
Lots of glitch all time. I've spend lot's of hours with the official doc atsc.org with no success.
The sound attach here play very well and convert with no glitch on a mac (with afconvert)
When open the sound with audacity on linux we can see the 3 glitches.
On Mac with audacity ( he use the internal audio library) no artefact.
The file is not corrupt (no crc error ...)
I'll try to invalidate the frame. The artefact is minimized but still here. I'll try to invalidate the frame and next after but the artefact is still here. I'll try to see if it may be a parser problem but i don't think.
Can anybody help us on this bug ?
I've test with the last version of ffmpeg.
comment:10 by , 8 years ago
Priority: | normal → important |
---|
comment:11 by , 8 years ago
Priority: | important → normal |
---|
follow-up: 14 comment:13 by , 8 years ago
official doc atsc
Ive audit the decode_components function and it's same that the doc ...
Somme missing param in the eac3 parser but not affected by the file ac3 attached here ...
comment:14 by , 8 years ago
Replying to tesla_:
official doc atsc
debuging this from the doc is timeconsuming and assumes this is not a typo in the doc (which we cannot exclude really as a explanation at this point)
Is there some reference implementation that is open source ?
comment:15 by , 8 years ago
I've manually detect the frame that sucks. (Three )
The last is the 1298 frame
I've manually apply a gain of zero when apply scaling to coefficients. and the artefact disappears :)
Now must found write a good solution to apply to each time :)
I think the file have problems but doesn't matter is just one frame.
We just must invalidate all work already done on the bad frame. i think that is something that
comment:16 by , 8 years ago
Hi some news. I've try to make a statistic approch of the problem.
I've analyse the amount begin header of each frame and each block , the amount of consumption of data for each block and frame for 20/30 consequently and like i think it's very linear. With this approach i sucessfull find the function that sucks and doesn't consumme enough data. The data pointer is completely shifted for the seconde blk of the frame and the error is detect only when it's possible to detect.. AKA in decode_exponents and with a very lucky way...
Now next step why decode_transform_coeffs doesn't consumme the data she could :)
comment:18 by , 8 years ago
Hi,
I'm on ArchLinux, and I have this issue with VLC, Kaffeine, on my DVB-T tunner.
Same like this guy http://www.dvbviewer.tv/forum/topic/58061-unusual-audio-issue-on-dvb-t-france/
He uploaded a file with the glitche here : https://onedrive.live.com/redir?resid=801E6E4E512A1A8F!581990&authkey=!AJ4s8d9JG4w97KQ&ithint=video%2Cts
The audio glitch occurs near the end about 00:01:14 (there is only one audio stream)
This bug is really annoying when watching tv on my pc.
Do you think you can resolve it, cause I tried ffmpeg-git and it's the same, issue still here.
Tell me if you need some sample from my dvb-t tuner for analyze ?
Regards.
comment:19 by , 8 years ago
Same issue with my records since audio are in E-AC3 format. I have many audio glitch in my TS files if i play it with VLC, Audacity, etc... , but if i play these in my hardware players (Samsung TV, HPLC windows 10, or with paid logiciel as CyberLink power DVD, etc), the files work fine !
Thankx to fix this bug if possible.
comment:22 by , 8 years ago
Is this bug supposed to be fixed by commit 9351a156de724edb69ba6e1f05884fe806a13a21 ?
comment:23 by , 8 years ago
I can confirm that commit 9351a156de724edb69ba6e1f05884fe806a13a21 fixes the issue for my test cases.
Thanks !
comment:24 by , 7 years ago
Seems that the referenced commit became available as of ffmpeg 3.3.1.
I'm still experiencing a number of seemingly related errors decoding the audio block when remuxing .ts to .mkv on the 3.3.4 release:
[ac3 @ 0x55a891825b00] exponent -1 is out-of-range
[ac3 @ 0x55a891825b00] error decoding the audio block
[ac3 @ 0x55a891825b00] exponent -2 is out-of-range
[ac3 @ 0x55a891825b00] error decoding the audio block
Is this expected if the source audio has a dropout, or should this be handled in the current release?
bug 868 filename is audio_ac3_glitch.ac3
For future tickets: Please always test current FFmpeg git head before reporting issues.