ref: bc4e1758ccf961afbaae7c9664a222958c8ff3d7
dir: /tests/python/src/temporal/zero_crossing_rate.py/
import unittest from aubio.aubiowrapper import * buf_size = 2048 channels = 1 class zero_crossing_rate_unit(unittest.TestCase): def setUp(self): self.vector = new_fvec(buf_size, channels) def tearDown(self): del_fvec(self.vector) def test(self): """ create and delete fvec """ pass def test_zeroes(self): """ check zero crossing rate on a buffer of 0. """ self.assertEqual(0., aubio_zero_crossing_rate(self.vector)) def test_ones(self): """ check zero crossing rate on a buffer of 1. """ for index in range(buf_size): for channel in range(channels): fvec_write_sample(self.vector, 1., channel, index) self.assertEqual(0., aubio_zero_crossing_rate(self.vector)) def test_impulse(self): """ check zero crossing rate on a buffer with an impulse """ fvec_write_sample(self.vector, 1., 0, buf_size / 2) self.assertEqual(0., aubio_zero_crossing_rate(self.vector)) def test_negative_impulse(self): """ check zero crossing rate on a buffer with a negative impulse """ fvec_write_sample(self.vector, -1., 0, buf_size / 2) self.assertEqual(2./buf_size, aubio_zero_crossing_rate(self.vector)) def test_single(self): """ check zero crossing rate on single crossing """ fvec_write_sample(self.vector, +1., 0, buf_size / 2 - 1) fvec_write_sample(self.vector, -1., 0, buf_size / 2) self.assertEqual(2./buf_size, aubio_zero_crossing_rate(self.vector)) def test_single_with_gap(self): """ check zero crossing rate on single crossing with a gap""" fvec_write_sample(self.vector, +1., 0, buf_size / 2 - 2) fvec_write_sample(self.vector, -1., 0, buf_size / 2) self.assertEqual(2./buf_size, aubio_zero_crossing_rate(self.vector)) if __name__ == '__main__': unittest.main()