Changes in / [d47ad546:f7771c6]
- Files:
-
- 10 deleted
- 13 edited
Legend:
- Unmodified
- Added
- Removed
-
README.md
rd47ad546 rf7771c6 5 5 [![Appveyor build status](https://img.shields.io/appveyor/ci/piem/aubio/master.svg)](https://ci.appveyor.com/project/piem/aubio "Appveyor build status") 6 6 [![Landscape code health](https://landscape.io/github/aubio/aubio/master/landscape.svg?style=flat)](https://landscape.io/github/aubio/aubio/master "Landscape code health") 7 [![Commits since last release](https://img.shields.io/github/commits-since/aubio/aubio/ latest.svg)](https://github.com/aubio/aubio "Commits since last release")7 [![Commits since last release](https://img.shields.io/github/commits-since/aubio/aubio/0.4.6.svg)](https://github.com/aubio/aubio "Commits since last release") 8 8 9 9 [![Documentation](https://readthedocs.org/projects/aubio/badge/?version=latest)](http://aubio.readthedocs.io/en/latest/?badge=latest "Latest documentation") -
doc/statuslinks.rst
rd47ad546 rf7771c6 18 18 :alt: Documentation status 19 19 20 .. image:: https://img.shields.io/github/commits-since/aubio/aubio/ latest.svg20 .. image:: https://img.shields.io/github/commits-since/aubio/aubio/0.4.6.svg?maxAge=2592000 21 21 :target: https://github.com/aubio/aubio 22 22 :alt: Commits since last release -
examples/utils.h
rd47ad546 rf7771c6 67 67 68 68 /** common process function */ 69 typedef void(*aubio_process_func_t) (fvec_t * input, fvec_t * output);69 typedef int (*aubio_process_func_t) (fvec_t * input, fvec_t * output); 70 70 71 71 void process_block (fvec_t *ibuf, fvec_t *obuf); -
python/ext/aubiomodule.c
rd47ad546 rf7771c6 243 243 {"level_detection", Py_aubio_level_detection, METH_VARARGS, Py_aubio_level_detection_doc}, 244 244 {"window", Py_aubio_window, METH_VARARGS, Py_aubio_window_doc}, 245 {"shift", Py_aubio_shift, METH_VARARGS, Py_aubio_shift_doc},246 {"ishift", Py_aubio_ishift, METH_VARARGS, Py_aubio_ishift_doc},247 245 {NULL, NULL, 0, NULL} /* Sentinel */ 248 246 }; -
python/ext/py-musicutils.c
rd47ad546 rf7771c6 134 134 return level_detection; 135 135 } 136 137 PyObject *138 Py_aubio_shift(PyObject *self, PyObject *args)139 {140 PyObject *input;141 fvec_t vec;142 143 if (!PyArg_ParseTuple (args, "O:shift", &input)) {144 return NULL;145 }146 147 if (input == NULL) {148 return NULL;149 }150 151 if (!PyAubio_ArrayToCFvec(input, &vec)) {152 return NULL;153 }154 155 fvec_shift(&vec);156 157 //Py_RETURN_NONE;158 return (PyObject *) PyAubio_CFvecToArray(&vec);159 }160 161 PyObject *162 Py_aubio_ishift(PyObject *self, PyObject *args)163 {164 PyObject *input;165 fvec_t vec;166 167 if (!PyArg_ParseTuple (args, "O:shift", &input)) {168 return NULL;169 }170 171 if (input == NULL) {172 return NULL;173 }174 175 if (!PyAubio_ArrayToCFvec(input, &vec)) {176 return NULL;177 }178 179 fvec_ishift(&vec);180 181 //Py_RETURN_NONE;182 return (PyObject *) PyAubio_CFvecToArray(&vec);183 } -
python/ext/py-musicutils.h
rd47ad546 rf7771c6 72 72 PyObject * Py_aubio_level_detection(PyObject *self, PyObject *args); 73 73 74 static char Py_aubio_shift_doc[] = ""75 "Swap left and right partitions of a vector\n"76 "\n"77 "Returns the swapped vector. The input vector is also modified.\n"78 "\n"79 "For a vector of length N, the partition is split at index N - N//2.\n"80 "\n"81 "Example\n"82 "-------\n"83 "\n"84 ">>> import numpy\n"85 ">>> shift(numpy.arange(3, dtype=aubio.float_type))\n"86 "array([2., 0., 1.], dtype=" AUBIO_NPY_SMPL_STR ")";87 PyObject * Py_aubio_shift(PyObject *self, PyObject *args);88 89 static char Py_aubio_ishift_doc[] = ""90 "Swap right and left partitions of a vector\n"91 "\n"92 "Returns the swapped vector. The input vector is also modified.\n"93 "\n"94 "Unlike with shift(), the partition is split at index N//2.\n"95 "\n"96 "Example\n"97 "-------\n"98 "\n"99 ">>> import numpy\n"100 ">>> ishift(numpy.arange(3, dtype=aubio.float_type))\n"101 "array([1., 2., 0.], dtype=" AUBIO_NPY_SMPL_STR ")";102 PyObject * Py_aubio_ishift(PyObject *self, PyObject *args);103 104 74 #endif /* PY_AUBIO_MUSICUTILS_H */ -
python/lib/gen_code.py
rd47ad546 rf7771c6 3 3 'buf_size': 'Py_default_vector_length', 4 4 'win_s': 'Py_default_vector_length', 5 'size': 'Py_default_vector_length',6 5 # and here too 7 6 'hop_size': 'Py_default_vector_length / 2', … … 84 83 'filterbank': 'self->n_filters', 85 84 'tss': 'self->buf_size', 86 'dct': 'self->size',87 85 } 88 86 … … 179 177 self.do_outputs = get_params_types_names(self.do_proto)[2:] 180 178 struct_output_str = ["PyObject *{0[name]}; {1} c_{0[name]}".format(i, i['type'][:-1]) for i in self.do_outputs] 181 if len(self.prototypes['rdo']):182 rdo_outputs = get_params_types_names(prototypes['rdo'][0])[2:]183 struct_output_str += ["PyObject *{0[name]}; {1} c_{0[name]}".format(i, i['type'][:-1]) for i in rdo_outputs]184 self.outputs += rdo_outputs185 179 self.struct_outputs = ";\n ".join(struct_output_str) 186 180 … … 197 191 out += self.gen_del() 198 192 out += self.gen_do() 199 if len(self.prototypes['rdo']):200 self.do_proto = self.prototypes['rdo'][0]201 self.do_inputs = [get_params_types_names(self.do_proto)[1]]202 self.do_outputs = get_params_types_names(self.do_proto)[2:]203 out += self.gen_do(method='rdo')204 193 out += self.gen_memberdef() 205 194 out += self.gen_set() … … 382 371 return out 383 372 384 def gen_do(self , method = 'do'):373 def gen_do(self): 385 374 out = """ 386 375 // do {shortname} 387 376 static PyObject* 388 Py aubio_{shortname}_{method}(Py_{shortname} * self, PyObject * args)389 {{""".format( method = method,**self.__dict__)377 Py_{shortname}_do (Py_{shortname} * self, PyObject * args) 378 {{""".format(**self.__dict__) 390 379 input_params = self.do_inputs 391 380 output_params = self.do_outputs … … 527 516 {{"{shortname}", (PyCFunction) Py{name}, 528 517 METH_NOARGS, ""}},""".format(name = name, shortname = shortname) 529 for m in self.prototypes['rdo']:530 name = get_name(m)531 shortname = name.replace('aubio_%s_' % self.shortname, '')532 out += """533 {{"{shortname}", (PyCFunction) Py{name},534 METH_VARARGS, ""}},""".format(name = name, shortname = shortname)535 518 out += """ 536 519 {NULL} /* sentinel */ … … 558 541 0, 559 542 0, 560 (ternaryfunc)Py aubio_{shortname}_do,543 (ternaryfunc)Py_{shortname}_do, 561 544 0, 562 545 0, -
python/lib/gen_external.py
rd47ad546 rf7771c6 182 182 shortname = o[6:-2] # without aubio_ prefix and _t suffix 183 183 184 lib[shortname] = {'struct': [], 'new': [], 'del': [], 'do': [], ' rdo': [], 'get': [], 'set': [], 'other': []}184 lib[shortname] = {'struct': [], 'new': [], 'del': [], 'do': [], 'get': [], 'set': [], 'other': []} 185 185 lib[shortname]['longname'] = o 186 186 lib[shortname]['shortname'] = shortname … … 196 196 elif '_do' in fn: 197 197 lib[shortname]['do'].append(fn) 198 elif '_rdo' in fn:199 lib[shortname]['rdo'].append(fn)200 198 elif 'new_' in fn: 201 199 lib[shortname]['new'].append(fn) -
scripts/get_waf.sh
rd47ad546 rf7771c6 4 4 set -x 5 5 6 WAFVERSION=2.0.1 16 WAFVERSION=2.0.1 7 7 WAFTARBALL=waf-$WAFVERSION.tar.bz2 8 8 WAFURL=https://waf.io/$WAFTARBALL -
src/aubio.h
rd47ad546 rf7771c6 183 183 #include "temporal/c_weighting.h" 184 184 #include "spectral/fft.h" 185 #include "spectral/dct.h"186 185 #include "spectral/phasevoc.h" 187 186 #include "spectral/filterbank.h" -
src/aubio_priv.h
rd47ad546 rf7771c6 86 86 #define aubio_vDSP_mmov vDSP_mmov 87 87 #define aubio_vDSP_vmul vDSP_vmul 88 #define aubio_vDSP_vsmul vDSP_vsmul89 #define aubio_vDSP_vsadd vDSP_vsadd90 88 #define aubio_vDSP_vfill vDSP_vfill 91 89 #define aubio_vDSP_meanv vDSP_meanv … … 100 98 #define aubio_vDSP_mmov vDSP_mmovD 101 99 #define aubio_vDSP_vmul vDSP_vmulD 102 #define aubio_vDSP_vsmul vDSP_vsmulD103 #define aubio_vDSP_vsadd vDSP_vsaddD104 100 #define aubio_vDSP_vfill vDSP_vfillD 105 101 #define aubio_vDSP_meanv vDSP_meanvD -
src/io/source_avcodec.c
rd47ad546 rf7771c6 144 144 strncpy(s->path, path, strnlen(path, PATH_MAX) + 1); 145 145 146 #if LIBAVFORMAT_VERSION_INT < AV_VERSION_INT(58,0,0)147 146 // register all formats and codecs 148 147 av_register_all(); 149 #endif150 148 151 149 if (aubio_source_avcodec_has_network_url(s)) { -
src/spectral/mfcc.c
rd47ad546 rf7771c6 29 29 #include "spectral/filterbank.h" 30 30 #include "spectral/filterbank_mel.h" 31 #include "spectral/dct.h"32 31 #include "spectral/mfcc.h" 33 34 #undef HAVE_SLOW_DCT35 32 36 33 /** Internal structure for mfcc object */ … … 44 41 aubio_filterbank_t *fb; /** filter bank */ 45 42 fvec_t *in_dct; /** input buffer for dct * [fb->n_filters] */ 46 #if defined(HAVE_SLOW_DCT)47 43 fmat_t *dct_coeffs; /** DCT transform n_filters * n_coeffs */ 48 #else49 aubio_dct_t *dct;50 fvec_t *output;51 #endif52 44 }; 53 45 … … 60 52 /* allocate space for mfcc object */ 61 53 aubio_mfcc_t *mfcc = AUBIO_NEW (aubio_mfcc_t); 62 #if defined(HAVE_SLOW_DCT)63 54 smpl_t scaling; 64 55 65 56 uint_t i, j; 66 #endif67 57 68 58 mfcc->win_s = win_s; … … 78 68 mfcc->in_dct = new_fvec (n_filters); 79 69 80 #if defined(HAVE_SLOW_DCT)81 70 mfcc->dct_coeffs = new_fmat (n_coefs, n_filters); 82 71 … … 91 80 mfcc->dct_coeffs->data[0][i] *= SQRT (2.) / 2.; 92 81 } 93 #else94 mfcc->dct = new_aubio_dct (n_filters);95 mfcc->output = new_fvec (n_filters);96 #endif97 82 98 83 return mfcc; … … 108 93 /* delete buffers */ 109 94 del_fvec (mf->in_dct); 110 #if defined(HAVE_SLOW_DCT)111 95 del_fmat (mf->dct_coeffs); 112 #else113 del_aubio_dct (mf->dct);114 del_fvec (mf->output);115 #endif116 96 117 97 /* delete mfcc object */ … … 123 103 aubio_mfcc_do (aubio_mfcc_t * mf, const cvec_t * in, fvec_t * out) 124 104 { 125 #ifndef HAVE_SLOW_DCT126 fvec_t tmp;127 #endif128 105 /* compute filterbank */ 129 106 aubio_filterbank_do (mf->fb, in, mf->in_dct); … … 136 113 137 114 /* compute mfccs */ 138 #if defined(HAVE_SLOW_DCT)139 115 fmat_vecmul(mf->dct_coeffs, mf->in_dct, out); 140 #else141 aubio_dct_do(mf->dct, mf->in_dct, mf->output);142 // copy only first n_coeffs elements143 // TODO assert mf->output->length == n_coeffs144 tmp.data = mf->output->data;145 tmp.length = out->length;146 fvec_copy(&tmp, out);147 #endif148 116 149 117 return;
Note: See TracChangeset
for help on using the changeset viewer.