Changes in / [d47ad546:f7771c6]


Ignore:
Files:
10 deleted
13 edited

Legend:

Unmodified
Added
Removed
  • README.md

    rd47ad546 rf7771c6  
    55[![Appveyor build status](https://img.shields.io/appveyor/ci/piem/aubio/master.svg)](https://ci.appveyor.com/project/piem/aubio "Appveyor build status")
    66[![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")
    88
    99[![Documentation](https://readthedocs.org/projects/aubio/badge/?version=latest)](http://aubio.readthedocs.io/en/latest/?badge=latest "Latest documentation")
  • doc/statuslinks.rst

    rd47ad546 rf7771c6  
    1818   :alt: Documentation status
    1919
    20 .. image:: https://img.shields.io/github/commits-since/aubio/aubio/latest.svg
     20.. image:: https://img.shields.io/github/commits-since/aubio/aubio/0.4.6.svg?maxAge=2592000
    2121   :target: https://github.com/aubio/aubio
    2222   :alt: Commits since last release
  • examples/utils.h

    rd47ad546 rf7771c6  
    6767
    6868/** common process function */
    69 typedef void (*aubio_process_func_t) (fvec_t * input, fvec_t * output);
     69typedef int (*aubio_process_func_t) (fvec_t * input, fvec_t * output);
    7070
    7171void process_block (fvec_t *ibuf, fvec_t *obuf);
  • python/ext/aubiomodule.c

    rd47ad546 rf7771c6  
    243243  {"level_detection", Py_aubio_level_detection, METH_VARARGS, Py_aubio_level_detection_doc},
    244244  {"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},
    247245  {NULL, NULL, 0, NULL} /* Sentinel */
    248246};
  • python/ext/py-musicutils.c

    rd47ad546 rf7771c6  
    134134  return level_detection;
    135135}
    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  
    7272PyObject * Py_aubio_level_detection(PyObject *self, PyObject *args);
    7373
    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 
    10474#endif /* PY_AUBIO_MUSICUTILS_H */
  • python/lib/gen_code.py

    rd47ad546 rf7771c6  
    33    'buf_size': 'Py_default_vector_length',
    44    'win_s': 'Py_default_vector_length',
    5     'size': 'Py_default_vector_length',
    65    # and here too
    76    'hop_size': 'Py_default_vector_length / 2',
     
    8483        'filterbank': 'self->n_filters',
    8584        'tss': 'self->buf_size',
    86         'dct': 'self->size',
    8785        }
    8886
     
    179177        self.do_outputs = get_params_types_names(self.do_proto)[2:]
    180178        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_outputs
    185179        self.struct_outputs = ";\n    ".join(struct_output_str)
    186180
     
    197191            out += self.gen_del()
    198192            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')
    204193            out += self.gen_memberdef()
    205194            out += self.gen_set()
     
    382371        return out
    383372
    384     def gen_do(self, method = 'do'):
     373    def gen_do(self):
    385374        out = """
    386375// do {shortname}
    387376static PyObject*
    388 Pyaubio_{shortname}_{method}  (Py_{shortname} * self, PyObject * args)
    389 {{""".format(method = method, **self.__dict__)
     377Py_{shortname}_do  (Py_{shortname} * self, PyObject * args)
     378{{""".format(**self.__dict__)
    390379        input_params = self.do_inputs
    391380        output_params = self.do_outputs
     
    527516  {{"{shortname}", (PyCFunction) Py{name},
    528517    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)
    535518        out += """
    536519  {NULL} /* sentinel */
     
    558541  0,
    559542  0,
    560   (ternaryfunc)Pyaubio_{shortname}_do,
     543  (ternaryfunc)Py_{shortname}_do,
    561544  0,
    562545  0,
  • python/lib/gen_external.py

    rd47ad546 rf7771c6  
    182182            shortname = o[6:-2]  # without aubio_ prefix and _t suffix
    183183
    184         lib[shortname] = {'struct': [], 'new': [], 'del': [], 'do': [], 'rdo': [], 'get': [], 'set': [], 'other': []}
     184        lib[shortname] = {'struct': [], 'new': [], 'del': [], 'do': [], 'get': [], 'set': [], 'other': []}
    185185        lib[shortname]['longname'] = o
    186186        lib[shortname]['shortname'] = shortname
     
    196196                elif '_do' in fn:
    197197                    lib[shortname]['do'].append(fn)
    198                 elif '_rdo' in fn:
    199                     lib[shortname]['rdo'].append(fn)
    200198                elif 'new_' in fn:
    201199                    lib[shortname]['new'].append(fn)
  • scripts/get_waf.sh

    rd47ad546 rf7771c6  
    44set -x
    55
    6 WAFVERSION=2.0.11
     6WAFVERSION=2.0.1
    77WAFTARBALL=waf-$WAFVERSION.tar.bz2
    88WAFURL=https://waf.io/$WAFTARBALL
  • src/aubio.h

    rd47ad546 rf7771c6  
    183183#include "temporal/c_weighting.h"
    184184#include "spectral/fft.h"
    185 #include "spectral/dct.h"
    186185#include "spectral/phasevoc.h"
    187186#include "spectral/filterbank.h"
  • src/aubio_priv.h

    rd47ad546 rf7771c6  
    8686#define aubio_vDSP_mmov       vDSP_mmov
    8787#define aubio_vDSP_vmul       vDSP_vmul
    88 #define aubio_vDSP_vsmul      vDSP_vsmul
    89 #define aubio_vDSP_vsadd      vDSP_vsadd
    9088#define aubio_vDSP_vfill      vDSP_vfill
    9189#define aubio_vDSP_meanv      vDSP_meanv
     
    10098#define aubio_vDSP_mmov       vDSP_mmovD
    10199#define aubio_vDSP_vmul       vDSP_vmulD
    102 #define aubio_vDSP_vsmul      vDSP_vsmulD
    103 #define aubio_vDSP_vsadd      vDSP_vsaddD
    104100#define aubio_vDSP_vfill      vDSP_vfillD
    105101#define aubio_vDSP_meanv      vDSP_meanvD
  • src/io/source_avcodec.c

    rd47ad546 rf7771c6  
    144144  strncpy(s->path, path, strnlen(path, PATH_MAX) + 1);
    145145
    146 #if LIBAVFORMAT_VERSION_INT < AV_VERSION_INT(58,0,0)
    147146  // register all formats and codecs
    148147  av_register_all();
    149 #endif
    150148
    151149  if (aubio_source_avcodec_has_network_url(s)) {
  • src/spectral/mfcc.c

    rd47ad546 rf7771c6  
    2929#include "spectral/filterbank.h"
    3030#include "spectral/filterbank_mel.h"
    31 #include "spectral/dct.h"
    3231#include "spectral/mfcc.h"
    33 
    34 #undef HAVE_SLOW_DCT
    3532
    3633/** Internal structure for mfcc object */
     
    4441  aubio_filterbank_t *fb;   /** filter bank */
    4542  fvec_t *in_dct;           /** input buffer for dct * [fb->n_filters] */
    46 #if defined(HAVE_SLOW_DCT)
    4743  fmat_t *dct_coeffs;       /** DCT transform n_filters * n_coeffs */
    48 #else
    49   aubio_dct_t *dct;
    50   fvec_t *output;
    51 #endif
    5244};
    5345
     
    6052  /* allocate space for mfcc object */
    6153  aubio_mfcc_t *mfcc = AUBIO_NEW (aubio_mfcc_t);
    62 #if defined(HAVE_SLOW_DCT)
    6354  smpl_t scaling;
    6455
    6556  uint_t i, j;
    66 #endif
    6757
    6858  mfcc->win_s = win_s;
     
    7868  mfcc->in_dct = new_fvec (n_filters);
    7969
    80 #if defined(HAVE_SLOW_DCT)
    8170  mfcc->dct_coeffs = new_fmat (n_coefs, n_filters);
    8271
     
    9180    mfcc->dct_coeffs->data[0][i] *= SQRT (2.) / 2.;
    9281  }
    93 #else
    94   mfcc->dct = new_aubio_dct (n_filters);
    95   mfcc->output = new_fvec (n_filters);
    96 #endif
    9782
    9883  return mfcc;
     
    10893  /* delete buffers */
    10994  del_fvec (mf->in_dct);
    110 #if defined(HAVE_SLOW_DCT)
    11195  del_fmat (mf->dct_coeffs);
    112 #else
    113   del_aubio_dct (mf->dct);
    114   del_fvec (mf->output);
    115 #endif
    11696
    11797  /* delete mfcc object */
     
    123103aubio_mfcc_do (aubio_mfcc_t * mf, const cvec_t * in, fvec_t * out)
    124104{
    125 #ifndef HAVE_SLOW_DCT
    126   fvec_t tmp;
    127 #endif
    128105  /* compute filterbank */
    129106  aubio_filterbank_do (mf->fb, in, mf->in_dct);
     
    136113
    137114  /* compute mfccs */
    138 #if defined(HAVE_SLOW_DCT)
    139115  fmat_vecmul(mf->dct_coeffs, mf->in_dct, out);
    140 #else
    141   aubio_dct_do(mf->dct, mf->in_dct, mf->output);
    142   // copy only first n_coeffs elements
    143   // TODO assert mf->output->length == n_coeffs
    144   tmp.data = mf->output->data;
    145   tmp.length = out->length;
    146   fvec_copy(&tmp, out);
    147 #endif
    148116
    149117  return;
Note: See TracChangeset for help on using the changeset viewer.