ref: b03f1bf503d0efb09c34b0548d5de00782be0550
dir: /python/tests/test_onset.py/
#! /usr/bin/env python
from numpy.testing import TestCase, assert_equal, assert_almost_equal
from aubio import onset, fvec
class aubio_onset_default(TestCase):
def test_members(self):
o = onset()
assert_equal ([o.buf_size, o.hop_size, o.method, o.samplerate],
[1024,512,'default',44100])
class aubio_onset_params(TestCase):
samplerate = 44100
def setUp(self):
self.o = onset(samplerate = self.samplerate)
def test_get_delay(self):
self.assertGreater(self.o.get_delay(), 0)
def test_get_delay_s(self):
self.assertGreater(self.o.get_delay_s(), 0.)
def test_get_delay_ms(self):
self.assertGreater(self.o.get_delay_ms(), 0.)
def test_get_minioi(self):
self.assertGreater(self.o.get_minioi(), 0)
def test_get_minioi_s(self):
self.assertGreater(self.o.get_minioi_s(), 0.)
def test_get_minioi_ms(self):
self.assertGreater(self.o.get_minioi_ms(), 0.)
def test_get_threshold(self):
self.assertGreater(self.o.get_threshold(), 0.)
def test_set_delay(self):
val = 256
self.o.set_delay(val)
assert_equal (self.o.get_delay(), val)
def test_set_delay_s(self):
val = .05
self.o.set_delay_s(val)
assert_almost_equal (self.o.get_delay_s(), val)
def test_set_delay_ms(self):
val = 50.
self.o.set_delay_ms(val)
assert_almost_equal (self.o.get_delay_ms(), val)
def test_set_minioi(self):
val = 200
self.o.set_minioi(val)
assert_equal (self.o.get_minioi(), val)
def test_set_minioi_s(self):
val = 0.04
self.o.set_minioi_s(val)
assert_almost_equal (self.o.get_minioi_s(), val)
def test_set_minioi_ms(self):
val = 40.
self.o.set_minioi_ms(val)
assert_almost_equal (self.o.get_minioi_ms(), val)
def test_set_threshold(self):
val = 0.2
self.o.set_threshold(val)
assert_almost_equal (self.o.get_threshold(), val)
class aubio_onset_96000(aubio_onset_params):
samplerate = 96000
class aubio_onset_32000(aubio_onset_params):
samplerate = 32000
class aubio_onset_8000(aubio_onset_params):
samplerate = 8000
class aubio_onset_coverate(TestCase):
# extra tests to execute the C routines and improve coverage
def test_all_methods(self):
for method in ['default', 'energy', 'hfc', 'complexdomain', 'complex',
'phase', 'wphase', 'mkl', 'kl', 'specflux', 'specdiff',
'old_default']:
o = onset(method=method, buf_size=512, hop_size=256)
o(fvec(256))
def test_get_methods(self):
o = onset(method='default', buf_size=512, hop_size=256)
assert o.get_silence() == -70
o.set_silence(-20)
assert_almost_equal(o.get_silence(), -20)
assert o.get_compression() == 1
o.set_compression(.99)
assert_almost_equal(o.get_compression(), .99)
assert o.get_awhitening() == 0
o.set_awhitening(1)
assert o.get_awhitening() == 1
o.get_last()
o.get_last_ms()
o.get_last_s()
o.get_descriptor()
o.get_thresholded_descriptor()
if __name__ == '__main__':
from unittest import main
main()