annotate test/test_collect.py @ 92:18b412a9c4d5

Tests for timestamp filling
author Chris Cannam
date Mon, 26 Jan 2015 12:28:30 +0000
parents 7228921e8425
children 4bed6bf67243
rev   line source
Chris@71 1
Chris@71 2 import vamp
Chris@71 3 import numpy as np
Chris@71 4
Chris@82 5 plugin_key = "vamp-test-plugin:vamp-test-plugin"
Chris@82 6 plugin_key_freq = "vamp-test-plugin:vamp-test-plugin-freq"
Chris@71 7
Chris@71 8 rate = 44100
Chris@71 9
Chris@71 10 # Throughout this file we have the assumption that the plugin gets run with a
Chris@71 11 # blocksize of 1024, and with a step of 1024 for the time-domain version or 512
Chris@71 12 # for the frequency-domain one. That is certainly expected to be the norm for a
Chris@71 13 # plugin like this that declares no preference, and the Python Vamp module is
Chris@71 14 # expected to follow the norm
Chris@71 15
Chris@71 16 blocksize = 1024
Chris@92 17 eps = 1e-6
Chris@71 18
Chris@71 19 def input_data(n):
Chris@71 20 # start at 1, not 0 so that all elts are non-zero
Chris@71 21 return np.arange(n) + 1
Chris@71 22
Chris@71 23 def test_collect_runs_at_all():
Chris@88 24 buf = input_data(blocksize * 10)
Chris@88 25 results = list(vamp.collect(buf, rate, plugin_key, "input-timestamp"))
Chris@88 26 assert results != []
Chris@88 27
Chris@88 28 def test_collect_one_sample_per_step():
Chris@88 29 buf = input_data(blocksize * 10)
Chris@88 30 results = list(vamp.collect(buf, rate, plugin_key, "input-timestamp"))
Chris@88 31 assert len(results) == 10
Chris@88 32 for r in results:
Chris@88 33 assert r["timestamp"] == vamp.vampyhost.frame_to_realtime(r["values"][0], rate)
Chris@88 34
Chris@92 35 def test_collect_fixed_sample_rate():
Chris@92 36 buf = input_data(blocksize * 10)
Chris@92 37 results = list(vamp.collect(buf, rate, plugin_key, "curve-fsr"))
Chris@92 38 assert len(results) == 10
Chris@92 39 i = 0
Chris@92 40 for r in results:
Chris@92 41 assert r["timestamp"] == vamp.vampyhost.RealTime('seconds', i * 0.4)
Chris@92 42 assert abs(r["values"][0] - i * 0.1) < eps
Chris@92 43 i = i + 1
Chris@92 44
Chris@92 45 def test_collect_fixed_sample_rate_2():
Chris@92 46 buf = input_data(blocksize * 10)
Chris@92 47 results = list(vamp.collect(buf, rate, plugin_key, "curve-fsr-timed"))
Chris@92 48 assert len(results) == 10
Chris@92 49 i = 0
Chris@92 50 for r in results:
Chris@92 51 assert r["timestamp"] == vamp.vampyhost.RealTime('seconds', i * 0.4)
Chris@92 52 assert abs(r["values"][0] - i * 0.1) < eps
Chris@92 53 i = i + 1
Chris@92 54
Chris@92 55 def test_collect_variable_sample_rate():
Chris@92 56 buf = input_data(blocksize * 10)
Chris@92 57 results = list(vamp.collect(buf, rate, plugin_key, "curve-vsr"))
Chris@92 58 assert len(results) == 10
Chris@92 59 i = 0
Chris@92 60 for r in results:
Chris@92 61 assert r["timestamp"] == vamp.vampyhost.RealTime('seconds', i * 0.75)
Chris@92 62 assert abs(r["values"][0] - i * 0.1) < eps
Chris@92 63 i = i + 1