[7175ed4] | 1 | #! /usr/bin/env python |
---|
[e4c2169] | 2 | |
---|
[f6892d4] | 3 | import numpy as np |
---|
| 4 | import aubio |
---|
[e4c2169] | 5 | |
---|
| 6 | def build_sinusoid(length, freqs, samplerate): |
---|
[f6892d4] | 7 | return np.sin( 2. * np.pi * np.arange(length) * freqs / samplerate).astype(aubio.float_type) |
---|
[e4c2169] | 8 | |
---|
| 9 | def run_pitch(p, input_vec): |
---|
[f6892d4] | 10 | cands = [] |
---|
| 11 | for vec_slice in input_vec.reshape((-1, p.hop_size)): |
---|
| 12 | a = p(vec_slice)[0] |
---|
| 13 | cands.append(a) |
---|
| 14 | return cands |
---|
[e4c2169] | 15 | |
---|
| 16 | methods = ['default', 'schmitt', 'fcomb', 'mcomb', 'yin', 'yinfft'] |
---|
| 17 | |
---|
| 18 | cands = {} |
---|
| 19 | buf_size = 2048 |
---|
| 20 | hop_size = 512 |
---|
| 21 | samplerate = 44100 |
---|
| 22 | sin_length = (samplerate * 10) % 512 * 512 |
---|
[f6892d4] | 23 | freqs = np.zeros(sin_length) |
---|
[e4c2169] | 24 | |
---|
| 25 | partition = sin_length / 8 |
---|
| 26 | pointer = 0 |
---|
| 27 | |
---|
| 28 | pointer += partition |
---|
| 29 | freqs[pointer: pointer + partition] = 440 |
---|
| 30 | |
---|
| 31 | pointer += partition |
---|
| 32 | pointer += partition |
---|
| 33 | freqs[ pointer : pointer + partition ] = 740 |
---|
| 34 | |
---|
| 35 | pointer += partition |
---|
| 36 | freqs[ pointer : pointer + partition ] = 1480 |
---|
| 37 | |
---|
| 38 | pointer += partition |
---|
| 39 | pointer += partition |
---|
[f6892d4] | 40 | freqs[ pointer : pointer + partition ] = 400 + 5 * np.random.random(sin_length/8) |
---|
[e4c2169] | 41 | |
---|
| 42 | a = build_sinusoid(sin_length, freqs, samplerate) |
---|
| 43 | |
---|
| 44 | for method in methods: |
---|
[f6892d4] | 45 | p = aubio.pitch(method, buf_size, hop_size, samplerate) |
---|
| 46 | cands[method] = run_pitch(p, a) |
---|
| 47 | print cands[method] |
---|
[e4c2169] | 48 | |
---|
| 49 | print "done computing" |
---|
| 50 | |
---|
| 51 | if 1: |
---|
[f6892d4] | 52 | import matplotlib.pyplot as plt |
---|
[e4c2169] | 53 | |
---|
[f6892d4] | 54 | # times |
---|
| 55 | ramp = np.arange(0, sin_length / hop_size).astype('float') * hop_size / samplerate |
---|
[e4c2169] | 56 | |
---|
[f6892d4] | 57 | # plot each result |
---|
| 58 | for method in methods: |
---|
| 59 | plt.plot(ramp, cands[method], '.-', label=method) |
---|
[e4c2169] | 60 | |
---|
[f6892d4] | 61 | # plot ground truth |
---|
| 62 | ramp = np.arange(0, sin_length).astype('float') / samplerate |
---|
| 63 | plt.plot(ramp, freqs, ':', label = 'ground truth') |
---|
| 64 | |
---|
| 65 | plt.legend(loc='upper left') |
---|
| 66 | |
---|
| 67 | plt.xlabel('time (s)') |
---|
| 68 | plt.ylabel('frequency (Hz)') |
---|
| 69 | plt.ylim([0,2000]) |
---|
| 70 | plt.show() |
---|