summaryrefslogtreecommitdiff
path: root/readme.txt
blob: 1e4928ba1e4647104781ca65dd27cef68b02cc20 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
Sinusoidal Modelling - A Python Library (SiMPL)
Version 0.1
Copyright (c) 2009 John Glover, National University of Ireland, Maynooth
http://simplsound.sourceforge.net
john.c.glover@nuim.ie

-----------------------------------------------------------------------------------------
 
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.*)
- SCons (>= 1.2.0)
- 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
------------

To compile, in the root directory, run:
> scons

To install, run:
> sudo scons install

For a full list of options:
> scons --help


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:
- fix inaccuracy in the simplsndobj algorithms
- 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:
- test_partial_tracking fails with max_partials = max_peaks = 2
- test_synthesis fails when max_partials = max_peaks = num_frames = 10
- test_synthesis fails when max_peaks = 70, max_partials = 50. 
- test_synthesis: why does it occasionally not synthesise anything unless frame number is changed?
- test_synthesis: remove mag to db conversion
- can sms_scaleDet be moved to the harmonic analysis phase?
- improve synthesis accuracy beyond 3 decimal places
- include stochastic residual synthesis in SMSResidual

mq:
- window size should change depending on detected pitch. No pitch detection algorithm described in the
  original paper, so can use the SMS algorithm for now.