[linux-audio-dev] Algorithm for displaying waveforms

Alfons Adriaensen fons.adriaensen at alcatel.be
Mon Jun 6 10:04:16 UTC 2005


On Mon, Jun 06, 2005 at 09:17:54AM +0000, vanDongen/Gilcher wrote:

> As I recently found out, this can be very messy :)

Indeed :-)

> The basic algorithm is this:
> Each horizontal pixel represents n samples. Usually n is pretty big.
> Of those n samples you take the min and the max, and then you draw a vertical 
> line between them.
> Obviously this has to be scaled to your vertical resolution and vertically 
> translated to the right position  on your canvas. 
> If n<=1 you can choose to draw lines between the points, or just show the 
> points.

The most difficult situation is for n nearly equal to one.

But even this is not really correct if you want precision.

Consider an Fs/4 sine with samples -0.9 -0.9 +0.9 +0.9 -0.9 -0.9 +0.9 etc.
Now what is the (peak) amplitude of this sine ? Not 0.9, but something like
1.27. If you send this signal through a unity gain filter that produces 45
degrees of phase shift, you will get samples at +/- 1.27, and your DAC will
clip.

So even a simle digital peak meter requires interpolation of peaks to
be accurate. I don't know any in the linux world that do this.

-- 
FA







More information about the Linux-audio-dev mailing list