ref: db1eab722cb6b0858bb2ba99c573fbb4b859dc9f
dir: /python/demos/demo_beats_and_tempo.py/
#! /usr/bin/env python
import sys
from aubio import tempo, source
win_s = 512                 # fft size
hop_s = win_s / 2           # hop size
samplerate = 44100
if len(sys.argv) < 2:
    print "Usage: %s <filename>" % sys.argv[0]
    sys.exit(1)
filename = sys.argv[1]
beats = []
s = source(filename, samplerate, hop_s)
t = tempo("default", win_s, hop_s)
block_read = 0
while True:
    samples, read = s()
    isbeat = t(samples)
    if isbeat:
        thisbeat = (block_read * hop_s + isbeat[0]) / samplerate
        print "%.4f" % thisbeat
        beats.append (thisbeat)
    block_read += 1
    if read < hop_s: break
periods = [60./(b - a) for a,b in zip(beats[:-1],beats[1:])]
from numpy import mean, median
if len(periods):
    print 'mean period:', "%.2f" % mean(periods), 'bpm', 'median', "%.2f" % median(periods), 'bpm'
    if 0:
        from pylab import plot, show
        plot(beats[1:], periods)
        show()
else:
    print 'mean period:', "%.2f" % 0, 'bpm', 'median', "%.2f" % 0, 'bpm'