FLAC decoder testbench
ktmf01 opened this issue · 7 comments
I just found your FLAC decoding library, and tested it through flac2wav with this FLAC decoder testbench. I got quite a lot of messages like these
The flac library test cases do not yet include any audio files with xxx. If possible please consider contributing this audio sample to improve the reliability of the test cases.
For this I recommend the FLAC decoder testbench I just linked.
Besides the messages, flac2wav fails to decode the following files:
- 16 - partition order 8 containing escaped partitions
- 22 - 12 bit per sample
- 32 - high resolution audio, partition order 8 containing escaped partitions
- 37 - 20 bit per sample
Also, decoding of 23 - 8 bit per sample seems to be non-lossless.
I hope this information helps you to even further improve this library.
Thanks @ktmf01! That's definitely helpful. Having reference FLAC files will help us understand how these corner cases should be implemented.
Also, decoding of 23 - 8 bit per sample seems to be non-lossless.
Hmm, strange. I don't know where we would be introducing loss of the original PCM. Do you have any more info, e.g. what subframes were lossily decoded? (and what encoding was used for those subframes?)
Cheers,
Henry & Robin
Hmm, strange. I don't know where we would be introducing loss of the original PCM. Do you have any more info, e.g. what subframes were lossily decoded? (and what encoding was used for those subframes?)
The whole file sound extremely distorted.
The upper two channels are original, the bottom two are the decoded WAV. The problem does not seem to involve the FLAC decoding itself, but instead the writing of the output to WAV. Programs seem to read the output wavefile as unsigned, while flac2wav seems to write signed output.
Now, obviously the writing to WAV part isn't the focus of your project, so you could just ignore this part.
edit: See page 59 - 60 of http://www-mmsp.ece.mcgill.ca/Documents/AudioFormats/WAVE/Docs/riffmci.pdf, WAV files with 8 bit-per-sample are stored with unsigned values, WAV files with more than 8 bit-per-sample are stored as signed values.
Programs seem to read the output wavefile as unsigned, while flac2wav seems to write signed output.
Interesting, this may indeed be the underlying issue.
Now, obviously the writing to WAV part isn't the focus of your project, so you could just ignore this part.
Yeah, you're right. The flac2wav
is just an example tool to show how to use the FLAC library. I think we may ignore this, but would welcome a PR if there is an easy fix :)
As for the test cases, thanks once more! They will be a good reference for further testing the corner cases of the library. As for when those corner cases are implemented, I don't know :) My brother @karlek and I work on this project as a hobby so we do it when the mood strikes. We are really happy it has been useful to other people in the Go community, even if there are still corner cases left to handle.
Cheers,
Robin
Now, obviously the writing to WAV part isn't the focus of your project, so you could just ignore this part.
edit: See page 59 - 60 of http://www-mmsp.ece.mcgill.ca/Documents/AudioFormats/WAVE/Docs/riffmci.pdf, WAV files with 8 bit-per-sample are stored with unsigned values, WAV files with more than 8 bit-per-sample are stored as signed values.
@ktmf01, would you mind testing PR #52 and see if this resolves the encoding issue of the 8-bps test case?
Issues related to FLAC stream decoding and audio sample decoding were tracked by #54 and #60, respectively, and are now resolved.
Before we decide to close this issue, we should try to assess whether there are any metadata blocks of the IETF test cases that mewkiz/flac/meta
fails to parse. If so, new test cases can be added to mewkiz/flac/meta/meta_test.go
.
- check if
mewkiz/flac/meta
fails to parse any of the metadata of the IETF test case files.
To the best of my knowledge the IETF test cases are now passing for FLAC stream decoding, audio sample decoding and metadata decoding.
If any discrepancies are detected, feel free to re-open this issue or open a new one.
Thanks @ktmf01 for driving this validation effort. You are part of something incredible <3