John's Blog

Still working on finding a site template I like, but I don't want that to stop me from writing.

Synthesizing audio with a stupidly low bit-depth, part 1

January 23, 2022

Prerequsites: sampling, quantization, and fourier bullshit.

It's pretty well known that your audio is going to sound bad if it's sampled at a bit-depth that's too low. The waveforms for most recorded music are very spectrally dense, so unless it's massive, the quantization noise ends up being pretty random.

If you're trying to synthesize a wave, though, quantization noise can lead to some surprising artifacts! This blog post explores what happens when you synthesize a sine wave at a very low bit depth.

For my business card, I needed to synthesize audio using the onboard TCC PWM generator. These days, audio codec chips with 32 bits of depth can be had for under a dollar, so why use the microcontroller's onboard PWM generator? Well...

I needed to synthesize audio with only 4 bits of depth. Because this isn't the early 70's, having an audio synth with only 4 bits of depth seems totally crazy!

TODO: an interactive demo of the freq vs. sampling freq vs. quantization noise would be awesome.

TODO: the graph containing a non-integer number of sine cycles makes the visualization more confusing.

TODO: make it so that they can hear the sounds

Sine frequency
Sample rate

samples per sine period: 110.250

Bit Depth

Wave

Quantization noise

Fourier Transform

key takeaway: unless you're synthesizing a wave with a period that's a multiple of the sampling period, you'll get extra tones in your quantization noise