1 #define PY_AUBIO_MODULE_MAIN
2 #include "aubio-types.h"
3 #include "aubio-generated.h"
5 extern void add_generated_objects ( PyObject *m );
6 extern void add_ufuncs ( PyObject *m );
7 extern int generated_types_ready(void);
9 static char Py_alpha_norm_doc[] = "compute alpha normalisation factor";
12 Py_alpha_norm (PyObject * self, PyObject * args)
19 if (!PyArg_ParseTuple (args, "Of:alpha_norm", &input, &alpha)) {
27 vec = PyAubio_ArrayToCFvec (input);
33 // compute the function
34 result = Py_BuildValue ("f", fvec_alpha_norm (vec, alpha));
42 static char Py_bintomidi_doc[] = "convert bin to midi";
45 Py_bintomidi (PyObject * self, PyObject * args)
47 smpl_t input, samplerate, fftsize;
50 if (!PyArg_ParseTuple (args, "|fff", &input, &samplerate, &fftsize)) {
54 output = aubio_bintomidi (input, samplerate, fftsize);
56 return (PyObject *)PyFloat_FromDouble (output);
59 static char Py_miditobin_doc[] = "convert midi to bin";
62 Py_miditobin (PyObject * self, PyObject * args)
64 smpl_t input, samplerate, fftsize;
67 if (!PyArg_ParseTuple (args, "|fff", &input, &samplerate, &fftsize)) {
71 output = aubio_miditobin (input, samplerate, fftsize);
73 return (PyObject *)PyFloat_FromDouble (output);
76 static char Py_bintofreq_doc[] = "convert bin to freq";
79 Py_bintofreq (PyObject * self, PyObject * args)
81 smpl_t input, samplerate, fftsize;
84 if (!PyArg_ParseTuple (args, "|fff", &input, &samplerate, &fftsize)) {
88 output = aubio_bintofreq (input, samplerate, fftsize);
90 return (PyObject *)PyFloat_FromDouble (output);
93 static char Py_freqtobin_doc[] = "convert freq to bin";
96 Py_freqtobin (PyObject * self, PyObject * args)
98 smpl_t input, samplerate, fftsize;
101 if (!PyArg_ParseTuple (args, "|fff", &input, &samplerate, &fftsize)) {
105 output = aubio_freqtobin (input, samplerate, fftsize);
107 return (PyObject *)PyFloat_FromDouble (output);
110 static char Py_zero_crossing_rate_doc[] = "compute zero crossing rate";
113 Py_zero_crossing_rate (PyObject * self, PyObject * args)
119 if (!PyArg_ParseTuple (args, "O:zero_crossing_rate", &input)) {
127 vec = PyAubio_ArrayToCFvec (input);
133 // compute the function
134 result = Py_BuildValue ("f", aubio_zero_crossing_rate (vec));
135 if (result == NULL) {
142 static char Py_min_removal_doc[] = "compute zero crossing rate";
145 Py_min_removal(PyObject * self, PyObject * args)
150 if (!PyArg_ParseTuple (args, "O:min_removal", &input)) {
158 vec = PyAubio_ArrayToCFvec (input);
164 // compute the function
165 fvec_min_removal (vec);
167 // since this function does not return, we could return None
169 // however it is convenient to return the modified vector
170 return (PyObject *) PyAubio_CFvecToArray(vec);
171 // or even without converting it back to an array
173 //return (PyObject *)vec;
176 static PyMethodDef aubio_methods[] = {
177 {"bintomidi", Py_bintomidi, METH_VARARGS, Py_bintomidi_doc},
178 {"miditobin", Py_miditobin, METH_VARARGS, Py_miditobin_doc},
179 {"bintofreq", Py_bintofreq, METH_VARARGS, Py_bintofreq_doc},
180 {"freqtobin", Py_freqtobin, METH_VARARGS, Py_freqtobin_doc},
181 {"alpha_norm", Py_alpha_norm, METH_VARARGS, Py_alpha_norm_doc},
182 {"zero_crossing_rate", Py_zero_crossing_rate, METH_VARARGS, Py_zero_crossing_rate_doc},
183 {"min_removal", Py_min_removal, METH_VARARGS, Py_min_removal_doc},
184 {NULL, NULL} /* Sentinel */
187 static char aubio_module_doc[] = "Python module for the aubio library";
195 // fvec is defined in __init__.py
196 if ( (PyType_Ready (&Py_cvecType) < 0)
197 || (PyType_Ready (&Py_filterType) < 0)
198 || (PyType_Ready (&Py_filterbankType) < 0)
199 || (PyType_Ready (&Py_fftType) < 0)
200 || (PyType_Ready (&Py_pvocType) < 0)
201 || (PyType_Ready (&Py_sourceType) < 0)
203 || (generated_types_ready() < 0 )
208 m = Py_InitModule3 ("_aubio", aubio_methods, aubio_module_doc);
214 err = _import_array ();
217 "Unable to import Numpy array from aubio module (error %d)\n", err);
220 Py_INCREF (&Py_cvecType);
221 PyModule_AddObject (m, "cvec", (PyObject *) & Py_cvecType);
222 Py_INCREF (&Py_filterType);
223 PyModule_AddObject (m, "digital_filter", (PyObject *) & Py_filterType);
224 Py_INCREF (&Py_filterbankType);
225 PyModule_AddObject (m, "filterbank", (PyObject *) & Py_filterbankType);
226 Py_INCREF (&Py_fftType);
227 PyModule_AddObject (m, "fft", (PyObject *) & Py_fftType);
228 Py_INCREF (&Py_pvocType);
229 PyModule_AddObject (m, "pvoc", (PyObject *) & Py_pvocType);
230 Py_INCREF (&Py_sourceType);
231 PyModule_AddObject (m, "source", (PyObject *) & Py_sourceType);
233 // add generated objects
234 add_generated_objects(m);