summaryrefslogtreecommitdiff
path: root/README.md
diff options
context:
space:
mode:
Diffstat (limited to 'README.md')
-rw-r--r--README.md110
1 files changed, 110 insertions, 0 deletions
diff --git a/README.md b/README.md
new file mode 100644
index 0000000..452f8e7
--- /dev/null
+++ b/README.md
@@ -0,0 +1,110 @@
+Sinusoidal Modelling - A Python Library (SiMPL)
+===============================================
+
+Version 0.3
+
+Copyright (c) 2011 John Glover, National University of Ireland, Maynooth
+http://simplsound.sourceforge.net
+j@johnglover.net
+
+
+License
+-------
+
+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
+
+
+Introduction
+------------
+
+Simpl is an open source library for sinusoidal modelling written in C/C++ and Python,
+and making use of Scientific Python (SciPy). The aim of this
+project is to tie together many of the existing sinusoidal modelling implementations
+into a single unified system with a consistent API, as well as providing implementations
+of some recently published sinusoidal modelling algorithms, many of which have yet
+to be released in software. Simpl is primarily intended as a tool for other researchers
+in the field, allowing them to easily combine, compare and contrast many of the published
+analysis/synthesis algorithms.
+
+
+Dependencies
+------------
+
+* C/C++ compiler
+* Python (>= 2.6.*)
+* NumPy
+* SciPy
+* Developers who wish to run the unit tests also need the original open source libraries:
+ * sndobj: http://sndobj.sourceforge.net/
+ * libsms: http://mtg.upf.edu/static/libsms/
+
+
+Installation
+------------
+
+First build the extension module (so that the SWIG wrapper files are created) by running
+the following command in the root folder:
+
+ $ python setup.py build
+
+Then to install the module in your Python site-packages directory:
+
+ $ python setup.py install
+
+
+Usage
+-----
+
+See the scripts in the examples folder.
+
+
+Credits
+-------
+
+The SndObj library is by Dr. Victor Lazzarini (National University of Ireland, Maynooth) and others.
+See the main project page at http://sndobj.sourceforge.net/ for more information.
+
+Libsms is an implementation of SMS by Rich Eakin, based on code by Dr. Xavier Serra (MTG,
+Universitat Pompeu Fabra, Barcelona, Spain)
+See the main project page at http://mtg.upf.edu/static/libsms for more information.
+
+The MQ algorithm is based on the following paper:
+R. McAulay, T. Quatieri, "Speech Analysis/Synthesis Based on a Sinusoidal Representation",
+IEEE Transaction on Acoustics, Speech and Signal Processing, vol. 34, no. 4, pp. 744-754, 1986.
+
+
+To Do
+-----
+
+general:
+
+* include new RT Audio code
+* tidy up code for HMM/LP partial tracking and Loris integration
+* include binaries for Mac OS X and Windows so compilation from source is not needed
+* performance issues: MQ, LP and HMM algorithms need to be coded in C/C++ really,
+ Python is just too slow, particularly for real-time use. The pure Python implementations
+ are useful for testing though.
+
+sndobj:
+
+* create exception objects
+* add a set_synthesis_type property to SndObjSynthesis
+* create properties for threshold and num_bins in SndObjPartialTracking class
+* make sndobjs use self.sampling_rate
+* make peak detection use the new window_size property
+
+sms:
+
+* move sms_scaleDet to the harmonic analysis phase