adamstark@38: #include adamstark@38: #include adamstark@38: #include "../src/OnsetDetectionFunction.h" adamstark@38: #include "../src/BTrack.h" adamstark@38: #include adamstark@38: adamstark@38: static PyObject * btrack_onsetdf(PyObject *dummy, PyObject *args) adamstark@38: { adamstark@38: PyObject *arg1=NULL; adamstark@38: PyObject *arr1=NULL; adamstark@38: adamstark@38: if (!PyArg_ParseTuple(args, "O", &arg1)) adamstark@38: { adamstark@38: return NULL; adamstark@38: } adamstark@38: adamstark@38: arr1 = PyArray_FROM_OTF(arg1, NPY_DOUBLE, NPY_IN_ARRAY); adamstark@38: if (arr1 == NULL) adamstark@38: { adamstark@38: return NULL; adamstark@38: } adamstark@38: adamstark@38: adamstark@38: adamstark@38: ////////// GET INPUT DATA /////////////////// adamstark@38: adamstark@38: // get data as array adamstark@38: double* data = (double*) PyArray_DATA(arr1); adamstark@38: adamstark@38: // get array size adamstark@38: int signal_length = PyArray_Size((PyObject*)arr1); adamstark@38: //int k = (int) theSize; adamstark@38: adamstark@38: // get data type adamstark@38: char type = PyArray_DESCR(arr1)->type; adamstark@38: adamstark@38: ////////// BEGIN PROCESS /////////////////// adamstark@38: int hsize = 512; adamstark@38: int fsize = 1024; adamstark@38: int df_type = 6; adamstark@38: int numframes; adamstark@38: double buffer[hsize]; // buffer to hold one hopsize worth of audio samples adamstark@38: adamstark@38: adamstark@38: // get number of audio frames, given the hop size and signal length adamstark@38: numframes = (int) floor(((double) signal_length) / ((double) hsize)); adamstark@38: adamstark@38: OnsetDetectionFunction onset(hsize,fsize,df_type,1); adamstark@38: adamstark@38: double df[numframes]; adamstark@38: adamstark@38: adamstark@38: adamstark@38: /////////////////////////////////////////// adamstark@38: //////// Begin Processing Loop //////////// adamstark@38: adamstark@38: for (int i=0;i < numframes;i++) adamstark@38: { adamstark@38: // add new samples to frame adamstark@38: for (int n = 0;n < hsize;n++) adamstark@38: { adamstark@38: buffer[n] = data[(i*hsize)+n]; adamstark@38: } adamstark@38: adamstark@38: df[i] = onset.getDFsample(buffer); adamstark@38: adamstark@38: } adamstark@38: adamstark@38: ///////// End Processing Loop ///////////// adamstark@38: /////////////////////////////////////////// adamstark@38: adamstark@38: adamstark@38: ////////// END PROCESS /////////////////// adamstark@38: adamstark@38: adamstark@38: adamstark@38: ////////// CREATE ARRAY AND RETURN IT /////////////////// adamstark@38: int nd=1; adamstark@38: npy_intp m= numframes; adamstark@38: //double fArray[5] = {0,1,2,3,4}; adamstark@38: adamstark@38: PyObject* c=PyArray_SimpleNew(nd, &m, NPY_DOUBLE); adamstark@38: adamstark@38: void *arr_data = PyArray_DATA((PyArrayObject*)c); adamstark@38: adamstark@38: memcpy(arr_data, df, PyArray_ITEMSIZE((PyArrayObject*) c) * m); adamstark@38: adamstark@38: adamstark@38: Py_DECREF(arr1); adamstark@38: Py_INCREF(Py_None); adamstark@38: //return Py_None; adamstark@38: adamstark@38: return (PyObject *)c; adamstark@38: adamstark@38: //return Py_BuildValue("c", type); adamstark@38: //return Py_BuildValue("d", sum); adamstark@38: //return Py_BuildValue("i", k); adamstark@38: /* adamstark@38: fail: adamstark@38: Py_XDECREF(arr1); adamstark@38: Py_XDECREF(arr2); adamstark@38: PyArray_XDECREF_ERR(oarr); adamstark@38: return NULL;*/ adamstark@38: } adamstark@38: adamstark@38: adamstark@38: static PyObject * btrack_btrack(PyObject *dummy, PyObject *args) adamstark@38: { adamstark@38: PyObject *arg1=NULL; adamstark@38: PyObject *arr1=NULL; adamstark@38: adamstark@38: if (!PyArg_ParseTuple(args, "O", &arg1)) adamstark@38: { adamstark@38: return NULL; adamstark@38: } adamstark@38: adamstark@38: arr1 = PyArray_FROM_OTF(arg1, NPY_DOUBLE, NPY_IN_ARRAY); adamstark@38: if (arr1 == NULL) adamstark@38: { adamstark@38: return NULL; adamstark@38: } adamstark@38: adamstark@38: adamstark@38: adamstark@38: ////////// GET INPUT DATA /////////////////// adamstark@38: adamstark@38: // get data as array adamstark@38: double* data = (double*) PyArray_DATA(arr1); adamstark@38: adamstark@38: // get array size adamstark@38: int signal_length = PyArray_Size((PyObject*)arr1); adamstark@38: //int k = (int) theSize; adamstark@38: adamstark@38: // get data type adamstark@38: char type = PyArray_DESCR(arr1)->type; adamstark@38: adamstark@38: ////////// BEGIN PROCESS /////////////////// adamstark@38: int hsize = 512; adamstark@38: int fsize = 1024; adamstark@38: int df_type = 6; adamstark@38: int numframes; adamstark@38: double buffer[hsize]; // buffer to hold one hopsize worth of audio samples adamstark@38: adamstark@38: adamstark@38: // get number of audio frames, given the hop size and signal length adamstark@38: numframes = (int) floor(((double) signal_length) / ((double) hsize)); adamstark@38: adamstark@38: OnsetDetectionFunction onset(hsize,fsize,df_type,1); adamstark@38: BTrack b; adamstark@38: adamstark@38: b.initialise((int) hsize); // initialise beat tracker adamstark@38: adamstark@38: // set parameters adamstark@38: //b.setparams(0.9,5); adamstark@38: adamstark@38: double df[numframes]; adamstark@38: double beats[5000]; adamstark@38: int beatnum = 0; adamstark@38: float df_val; adamstark@38: adamstark@38: /////////////////////////////////////////// adamstark@38: //////// Begin Processing Loop //////////// adamstark@38: adamstark@38: for (int i=0;i < numframes;i++) adamstark@38: { adamstark@38: // add new samples to frame adamstark@38: for (int n = 0;n < hsize;n++) adamstark@38: { adamstark@38: buffer[n] = data[(i*hsize)+n]; adamstark@38: } adamstark@38: adamstark@38: df[i] = onset.getDFsample(buffer); adamstark@38: adamstark@38: df_val = (float) (df[i] + 0.0001); adamstark@38: adamstark@38: b.process(df_val); // process df sample in beat tracker adamstark@38: adamstark@38: if (b.playbeat == 1) adamstark@38: { adamstark@38: beats[beatnum] = (((double) hsize) / 44100) * ((double) i); adamstark@38: beatnum = beatnum + 1; adamstark@38: } adamstark@38: adamstark@38: } adamstark@38: adamstark@38: ///////// End Processing Loop ///////////// adamstark@38: /////////////////////////////////////////// adamstark@38: adamstark@38: adamstark@38: ////////// END PROCESS /////////////////// adamstark@38: adamstark@38: double beats_out[beatnum]; // create output array adamstark@38: adamstark@38: // copy beats into output array adamstark@38: for (int i = 0;i < beatnum;i++) adamstark@38: { adamstark@38: beats_out[i] = beats[i]; adamstark@38: } adamstark@38: adamstark@38: adamstark@38: adamstark@38: ////////// CREATE ARRAY AND RETURN IT /////////////////// adamstark@38: int nd=1; adamstark@38: npy_intp m= beatnum; adamstark@38: //double fArray[5] = {0,1,2,3,4}; adamstark@38: adamstark@38: PyObject* c=PyArray_SimpleNew(nd, &m, NPY_DOUBLE); adamstark@38: adamstark@38: void *arr_data = PyArray_DATA((PyArrayObject*)c); adamstark@38: adamstark@38: memcpy(arr_data, beats_out, PyArray_ITEMSIZE((PyArrayObject*) c) * m); adamstark@38: adamstark@38: adamstark@38: Py_DECREF(arr1); adamstark@38: Py_INCREF(Py_None); adamstark@38: //return Py_None; adamstark@38: adamstark@38: return (PyObject *)c; adamstark@38: adamstark@38: //return Py_BuildValue("c", type); adamstark@38: //return Py_BuildValue("d", sum); adamstark@38: //return Py_BuildValue("i", k); adamstark@38: /* adamstark@38: fail: adamstark@38: Py_XDECREF(arr1); adamstark@38: Py_XDECREF(arr2); adamstark@38: PyArray_XDECREF_ERR(oarr); adamstark@38: return NULL;*/ adamstark@38: } adamstark@38: adamstark@38: static PyObject * btrack_btrack_df(PyObject *dummy, PyObject *args) adamstark@38: { adamstark@38: PyObject *arg1=NULL; adamstark@38: PyObject *arr1=NULL; adamstark@38: adamstark@38: if (!PyArg_ParseTuple(args, "O", &arg1)) adamstark@38: { adamstark@38: return NULL; adamstark@38: } adamstark@38: adamstark@38: arr1 = PyArray_FROM_OTF(arg1, NPY_DOUBLE, NPY_IN_ARRAY); adamstark@38: if (arr1 == NULL) adamstark@38: { adamstark@38: return NULL; adamstark@38: } adamstark@38: adamstark@38: adamstark@38: adamstark@38: ////////// GET INPUT DATA /////////////////// adamstark@38: adamstark@38: // get data as array adamstark@38: double* data = (double*) PyArray_DATA(arr1); adamstark@38: adamstark@38: // get array size adamstark@38: int numframes = PyArray_Size((PyObject*)arr1); adamstark@38: //int k = (int) theSize; adamstark@38: adamstark@38: // get data type adamstark@38: char type = PyArray_DESCR(arr1)->type; adamstark@38: adamstark@38: ////////// BEGIN PROCESS /////////////////// adamstark@38: int hsize = 512; adamstark@38: adamstark@38: BTrack b; adamstark@38: adamstark@38: b.initialise((int) hsize); // initialise beat tracker adamstark@38: adamstark@38: // set parameters adamstark@38: //b.setparams(0.9,5); adamstark@38: adamstark@38: double beats[5000]; adamstark@38: int beatnum = 0; adamstark@38: float df_val; adamstark@38: adamstark@38: /////////////////////////////////////////// adamstark@38: //////// Begin Processing Loop //////////// adamstark@38: adamstark@38: for (int i=0;i < numframes;i++) adamstark@38: { adamstark@38: df_val = (float) (data[i] + 0.0001); adamstark@38: adamstark@38: b.process(df_val); // process df sample in beat tracker adamstark@38: adamstark@38: if (b.playbeat == 1) adamstark@38: { adamstark@38: beats[beatnum] = (((double) hsize) / 44100) * ((double) i); adamstark@38: beatnum = beatnum + 1; adamstark@38: } adamstark@38: adamstark@38: } adamstark@38: adamstark@38: ///////// End Processing Loop ///////////// adamstark@38: /////////////////////////////////////////// adamstark@38: adamstark@38: adamstark@38: ////////// END PROCESS /////////////////// adamstark@38: adamstark@38: double beats_out[beatnum]; // create output array adamstark@38: adamstark@38: adamstark@38: // copy beats into output array adamstark@38: for (int i = 0;i < beatnum;i++) adamstark@38: { adamstark@38: beats_out[i] = beats[i]; adamstark@38: } adamstark@38: adamstark@38: adamstark@38: ////////// CREATE ARRAY AND RETURN IT /////////////////// adamstark@38: int nd=1; adamstark@38: npy_intp m= beatnum; adamstark@38: //double fArray[5] = {0,1,2,3,4}; adamstark@38: adamstark@38: PyObject* c=PyArray_SimpleNew(nd, &m, NPY_DOUBLE); adamstark@38: adamstark@38: void *arr_data = PyArray_DATA((PyArrayObject*)c); adamstark@38: adamstark@38: memcpy(arr_data, beats_out, PyArray_ITEMSIZE((PyArrayObject*) c) * m); adamstark@38: adamstark@38: adamstark@38: Py_DECREF(arr1); adamstark@38: Py_INCREF(Py_None); adamstark@38: //return Py_None; adamstark@38: adamstark@38: return (PyObject *)c; adamstark@38: adamstark@38: //return Py_BuildValue("c", type); adamstark@38: //return Py_BuildValue("d", sum); adamstark@38: //return Py_BuildValue("i", k); adamstark@38: /* adamstark@38: fail: adamstark@38: Py_XDECREF(arr1); adamstark@38: Py_XDECREF(arr2); adamstark@38: PyArray_XDECREF_ERR(oarr); adamstark@38: return NULL;*/ adamstark@38: } adamstark@38: adamstark@38: adamstark@38: adamstark@38: static PyMethodDef btrack_methods[] = { adamstark@38: { "onsetdf",btrack_onsetdf,METH_VARARGS,"onset detection function"}, adamstark@38: { "btrack",btrack_btrack,METH_VARARGS,"beat tracker"}, adamstark@38: { "btrack_df",btrack_btrack_df,METH_VARARGS,"beat tracker with detection function input"}, adamstark@38: {NULL, NULL, 0, NULL} /* Sentinel */ adamstark@38: }; adamstark@38: adamstark@38: PyMODINIT_FUNC initbtrack(void) adamstark@38: { adamstark@38: (void)Py_InitModule("btrack", btrack_methods); adamstark@38: import_array(); adamstark@38: } adamstark@38: adamstark@38: int main(int argc, char *argv[]) adamstark@38: { adamstark@38: /* Pass argv[0] to the Python interpreter */ adamstark@38: Py_SetProgramName(argv[0]); adamstark@38: adamstark@38: /* Initialize the Python interpreter. Required. */ adamstark@38: Py_Initialize(); adamstark@38: adamstark@38: /* Add a static module */ adamstark@38: initbtrack(); adamstark@38: }