summaryrefslogtreecommitdiff
path: root/python/README.md
blob: 7ee0fa4c054d74abb61eb5c50e83782227aedc4b (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
Python aubio module
===================

This module wraps the aubio library for Python using the numpy module.

Using the Python aubio module
-----------------------------

After installing python-aubio, you will be able to import the aubio module:

    $ python
    [...]
    >>> import aubio
    >>> help(aubio.miditofreq)

Finding some inspiration
------------------------

Some examples are available in the `python/demos` directory. These scripts are
small programs written in python and using python-aubio.

For instance, `demo_source.py` reads a media file.

    $ ./python/demos/demo_source.py /path/to/sound/sample.wav

and `demo_timestretch_online.py` stretches the original file into a new one:

    $ ./python/demo/demo_timestretch_online.py loop.wav stretched_loop.wav 0.92`

Note: you might need to install additional modules to run some of the demos.
Some demos use [matplotlib](http://matplotlib.org/) to draw plots, others use
[PySoundCard](https://github.com/bastibe/PySoundCard) to play and record
sounds.

Testing the Python module
-------------------------

To run the all the python tests, use the script:

    $ ./python/tests/run_all_tests

Each test script can also be called one at a time. For instance:

    $ ./python/tests/test_note2midi.py -v

Install in a virtualenv
-----------------------

You should be able to install python-aubio directly from the top source
directory of aubio.

First, create a virtualenv to hold the required python module:

    $ virtualenv pyaubio
    $ source pyaubio/bin/activate

Now install and build the python extension using:

    $ pip install .

Install requirements
--------------------

Before compiling this module, you must have compiled libaubio.

A simple way to do this is with pip:

    $ pip install -r requirements.txt

For more information about how this module works, please refer to the [Python/C
API Reference Manual] (http://docs.python.org/c-api/index.html) and the
[Numpy/C API Reference](http://docs.scipy.org/doc/numpy/reference/c-api.html).

Compiling python aubio
----------------------

To build the aubio Python module, run the following command from the top source
directory of aubio:

    $ ./setup.py build

Note: if libaubio was previously built using waf, the script will use it.
Otherwise, the entire library will be built inside the python extension.

To find out more about `setup.py` options:

    $ ./setup.py --help

Installing
----------

To install the Python module:

    $ ./setup.py install

Alternatively, you may want to use the Python module without installing it by
setting your PYTHONPATH, for instance as follows:

    $ export PYTHONPATH=$PYTHONPATH:$PWD/`ls -rtd build/lib.* | head -1`:$PWD/tests