Giter Site home page Giter Site logo

Comments (6)

DylanMeeus avatar DylanMeeus commented on June 23, 2024 1

Hi @ryjose1

That's a good catch, I had no idea!
I'll take a look at this, thank you for linking a wave file for testing.

from goaudio.

DylanMeeus avatar DylanMeeus commented on June 23, 2024

@ryjose1

Do you mind trying against the latest master? Should have a fix in place!

from goaudio.

ryjose1 avatar ryjose1 commented on June 23, 2024

Sorry for the delay, life got a little busy. It looks like this file is weird because it also has 24 bits per sample; I'm no longer crashing when reading in the file, but it looks like I'm erroring out when writing the file back to disk for testing.

For context, I'm taking the file and putting it through the following flow:

file -> 
wav, err := wave.ReadWaveFile(file) -> 
batches := wave.BatchSamples(wav, 1.0) -> 
wave.WriteFrames(batch, waveFmt, "file_pt1.wav")

where

batch comes from
for _, batch := range batches{}

waveFmt := wave.NewWaveFmt(1, 2, 44100, 24, []byte{})

from goaudio.

DylanMeeus avatar DylanMeeus commented on June 23, 2024

No worries about the delay, thanks for testing! I will look into writing the 24 bit files soonish.

from goaudio.

DylanMeeus avatar DylanMeeus commented on June 23, 2024

So this file is pretty odd.. in the "Fmt" part, it is larger than the expected size, but it doesn't report that..

// FMT starts here (6d66 2074)
00002d0 0000 6d66 2074 0028 0000 0001 0002 bb80
00002e0 0000 6500 0004 0006 0018 0000 0000 0000
00002f0 0000 0000 0000 0000 0000 0000 0000 0000
0000300 0000 696d 666e 0010 0000 a1c0 b21a 92bf
0000310 01d2 0002 0000 0000 0000 6c65 316d 00d6
0000320 0000 0000 0000 0000 0000 0000 0000 0000

That is the entire content of the Fmt Block. Per default, it should be 16b wide, unless it reports more. The bits that are supposed to report "more data" are set to 0 - yet it does have more than 16b.

Very strange file indeed - I'll have to look a bit more into how I can handle such cases gracefully.

from goaudio.

ryjose1 avatar ryjose1 commented on June 23, 2024

For some context, this file isn't a blocker for me, though it's just my luck that the arbitrary test file I picked has so many quirks. Thanks for your help so far/going forward!

from goaudio.

Related Issues (10)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.