summaryrefslogtreecommitdiff
path: root/tests/lp.py
diff options
context:
space:
mode:
Diffstat (limited to 'tests/lp.py')
-rw-r--r--tests/lp.py54
1 files changed, 54 insertions, 0 deletions
diff --git a/tests/lp.py b/tests/lp.py
new file mode 100644
index 0000000..c6051dd
--- /dev/null
+++ b/tests/lp.py
@@ -0,0 +1,54 @@
+# Copyright (c) 2010 John Glover, National University of Ireland, Maynooth
+#
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+
+import simpl
+from simpl import lp
+import numpy as np
+import matplotlib.pyplot as plt
+import unittest
+
+audio, sampling_rate = simpl.read_wav("audio/flute.wav")
+
+# take just the first few frames
+audio = audio_in[0:4096]
+# Peak detection and partial tracking using SMS
+pd = simpl.SndObjPeakDetection()
+pd.max_peaks = 60
+peaks = pd.find_peaks(audio)
+pt = simpl.MQPartialTracking()
+pt.max_partials = 60
+partials = pt.find_partials(peaks)
+simpl.plot.plot_partials(partials)
+plt.show()
+
+exit()
+
+
+class TestLP(unittest.TestCase):
+ FLOAT_PRECISION = 3 # number of decimal places to check for accuracy
+
+ def test_predict(self):
+ """test_predict"""
+ coefs = np.array([1,2,3,4,5])
+ test_signal = np.ones(5)
+ predictions = lp.predict(test_signal, coefs, 2)
+ self.assertEquals(predictions[0], -sum(coefs))
+ self.assertEquals(predictions[1], -sum(coefs[1:])-predictions[0])
+
+suite = unittest.TestSuite()
+suite.addTest(TestLP('test_predict'))
+unittest.TextTestRunner().run(suite)
+