|
|
@@ -0,0 +1,1255 @@
|
|
|
+/* ----------------------------------------------------------------------
|
|
|
+ * Project: CMSIS DSP Python Wrapper
|
|
|
+ * Title: cmsismodule.h
|
|
|
+ * Description: C code for the CMSIS-DSP Python wrapper
|
|
|
+ *
|
|
|
+ * $Date: 15 December 2022
|
|
|
+ * $Revision: v1.15.0
|
|
|
+ *
|
|
|
+ * Target Processor: Cortex-M cores
|
|
|
+ * -------------------------------------------------------------------- */
|
|
|
+/*
|
|
|
+ * Copyright (C) 2010-2022 ARM Limited or its affiliates. All rights reserved.
|
|
|
+ *
|
|
|
+ * SPDX-License-Identifier: Apache-2.0
|
|
|
+ *
|
|
|
+ * Licensed under the Apache License, Version 2.0 (the License); you may
|
|
|
+ * not use this file except in compliance with the License.
|
|
|
+ * You may obtain a copy of the License at
|
|
|
+ *
|
|
|
+ * www.apache.org/licenses/LICENSE-2.0
|
|
|
+ *
|
|
|
+ * Unless required by applicable law or agreed to in writing, software
|
|
|
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
|
|
|
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
+ * See the License for the specific language governing permissions and
|
|
|
+ * limitations under the License.
|
|
|
+ */
|
|
|
+
|
|
|
+#define MODNAME "cmsisdsp_window"
|
|
|
+#define MODINITNAME cmsisdsp_window
|
|
|
+
|
|
|
+#include "cmsisdsp_module.h"
|
|
|
+
|
|
|
+
|
|
|
+NUMPYVECTORFROMBUFFER(f32,float32_t,NPY_FLOAT);
|
|
|
+
|
|
|
+
|
|
|
+void typeRegistration(PyObject *module) {
|
|
|
+
|
|
|
+
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_welch_f32(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float32_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_welch_f32(pDst,nb);
|
|
|
+ FLOATARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_welch_f64(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float64_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_welch_f64(pDst,nb);
|
|
|
+ FLOAT64ARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_bartlett_f32(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float32_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_bartlett_f32(pDst,nb);
|
|
|
+ FLOATARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_bartlett_f64(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float64_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_bartlett_f64(pDst,nb);
|
|
|
+ FLOAT64ARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_hamming_f32(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float32_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_hamming_f32(pDst,nb);
|
|
|
+ FLOATARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_hamming_f64(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float64_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_hamming_f64(pDst,nb);
|
|
|
+ FLOAT64ARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_hanning_f32(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float32_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_hanning_f32(pDst,nb);
|
|
|
+ FLOATARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_hanning_f64(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float64_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_hanning_f64(pDst,nb);
|
|
|
+ FLOAT64ARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_nuttall3_f32(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float32_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_nuttall3_f32(pDst,nb);
|
|
|
+ FLOATARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_nuttall3_f64(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float64_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_nuttall3_f64(pDst,nb);
|
|
|
+ FLOAT64ARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_nuttall4_f32(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float32_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_nuttall4_f32(pDst,nb);
|
|
|
+ FLOATARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_nuttall4_f64(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float64_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_nuttall4_f64(pDst,nb);
|
|
|
+ FLOAT64ARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_nuttall3a_f32(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float32_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_nuttall3a_f32(pDst,nb);
|
|
|
+ FLOATARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_nuttall3a_f64(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float64_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_nuttall3a_f64(pDst,nb);
|
|
|
+ FLOAT64ARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_nuttall3b_f32(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float32_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_nuttall3b_f32(pDst,nb);
|
|
|
+ FLOATARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_nuttall3b_f64(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float64_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_nuttall3b_f64(pDst,nb);
|
|
|
+ FLOAT64ARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_nuttall4a_f32(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float32_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_nuttall4a_f32(pDst,nb);
|
|
|
+ FLOATARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_nuttall4a_f64(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float64_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_nuttall4a_f64(pDst,nb);
|
|
|
+ FLOAT64ARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_blackman_harris_92db_f32(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float32_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_blackman_harris_92db_f32(pDst,nb);
|
|
|
+ FLOATARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_blackman_harris_92db_f64(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float64_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_blackman_harris_92db_f64(pDst,nb);
|
|
|
+ FLOAT64ARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_nuttall4b_f32(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float32_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_nuttall4b_f32(pDst,nb);
|
|
|
+ FLOATARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_nuttall4b_f64(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float64_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_nuttall4b_f64(pDst,nb);
|
|
|
+ FLOAT64ARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_nuttall4c_f32(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float32_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_nuttall4c_f32(pDst,nb);
|
|
|
+ FLOATARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_nuttall4c_f64(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float64_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_nuttall4c_f64(pDst,nb);
|
|
|
+ FLOAT64ARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_hft90d_f32(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float32_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_hft90d_f32(pDst,nb);
|
|
|
+ FLOATARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_hft90d_f64(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float64_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_hft90d_f64(pDst,nb);
|
|
|
+ FLOAT64ARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_hft95_f32(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float32_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_hft95_f32(pDst,nb);
|
|
|
+ FLOATARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_hft95_f64(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float64_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_hft95_f64(pDst,nb);
|
|
|
+ FLOAT64ARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_hft116d_f32(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float32_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_hft116d_f32(pDst,nb);
|
|
|
+ FLOATARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_hft116d_f64(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float64_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_hft116d_f64(pDst,nb);
|
|
|
+ FLOAT64ARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_hft144d_f32(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float32_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_hft144d_f32(pDst,nb);
|
|
|
+ FLOATARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_hft144d_f64(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float64_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_hft144d_f64(pDst,nb);
|
|
|
+ FLOAT64ARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_hft169d_f32(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float32_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_hft169d_f32(pDst,nb);
|
|
|
+ FLOATARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_hft169d_f64(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float64_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_hft169d_f64(pDst,nb);
|
|
|
+ FLOAT64ARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_hft196d_f32(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float32_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_hft196d_f32(pDst,nb);
|
|
|
+ FLOATARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_hft196d_f64(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float64_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_hft196d_f64(pDst,nb);
|
|
|
+ FLOAT64ARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_hft223d_f32(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float32_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_hft223d_f32(pDst,nb);
|
|
|
+ FLOATARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_hft223d_f64(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float64_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_hft223d_f64(pDst,nb);
|
|
|
+ FLOAT64ARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_hft248d_f32(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float32_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_hft248d_f32(pDst,nb);
|
|
|
+ FLOATARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+static PyObject *
|
|
|
+cmsis_arm_hft248d_f64(PyObject *obj, PyObject *args)
|
|
|
+{
|
|
|
+
|
|
|
+
|
|
|
+ float32_t *pDst=NULL; // output
|
|
|
+ int nb; // input
|
|
|
+
|
|
|
+ if (PyArg_ParseTuple(args,"i",&nb))
|
|
|
+ {
|
|
|
+
|
|
|
+ pDst=PyMem_Malloc(sizeof(float64_t)*nb);
|
|
|
+
|
|
|
+
|
|
|
+ arm_hft248d_f64(pDst,nb);
|
|
|
+ FLOAT64ARRAY1(pDstOBJ,nb,pDst);
|
|
|
+
|
|
|
+ PyObject *pythonResult = Py_BuildValue("O",pDstOBJ);
|
|
|
+
|
|
|
+ Py_DECREF(pDstOBJ);
|
|
|
+ return(pythonResult);
|
|
|
+
|
|
|
+ }
|
|
|
+ return(NULL);
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+static PyMethodDef CMSISDSPMethods[] = {
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+{"arm_welch_f32" , cmsis_arm_welch_f32, METH_VARARGS,""},
|
|
|
+{"arm_welch_f64" , cmsis_arm_welch_f64, METH_VARARGS,""},
|
|
|
+
|
|
|
+
|
|
|
+{"arm_bartlett_f32" , cmsis_arm_bartlett_f32, METH_VARARGS,""},
|
|
|
+{"arm_bartlett_f64" , cmsis_arm_bartlett_f64, METH_VARARGS,""},
|
|
|
+
|
|
|
+
|
|
|
+{"arm_hamming_f32" , cmsis_arm_hamming_f32, METH_VARARGS,""},
|
|
|
+{"arm_hamming_f64" , cmsis_arm_hamming_f64, METH_VARARGS,""},
|
|
|
+
|
|
|
+
|
|
|
+{"arm_hanning_f32" , cmsis_arm_hanning_f32, METH_VARARGS,""},
|
|
|
+{"arm_hanning_f64" , cmsis_arm_hanning_f64, METH_VARARGS,""},
|
|
|
+
|
|
|
+
|
|
|
+{"arm_nuttall3_f32" , cmsis_arm_nuttall3_f32, METH_VARARGS,""},
|
|
|
+{"arm_nuttall3_f64" , cmsis_arm_nuttall3_f64, METH_VARARGS,""},
|
|
|
+
|
|
|
+
|
|
|
+{"arm_nuttall4_f32" , cmsis_arm_nuttall4_f32, METH_VARARGS,""},
|
|
|
+{"arm_nuttall4_f64" , cmsis_arm_nuttall4_f64, METH_VARARGS,""},
|
|
|
+
|
|
|
+
|
|
|
+{"arm_nuttall3a_f32" , cmsis_arm_nuttall3a_f32, METH_VARARGS,""},
|
|
|
+{"arm_nuttall3a_f64" , cmsis_arm_nuttall3a_f64, METH_VARARGS,""},
|
|
|
+
|
|
|
+
|
|
|
+{"arm_nuttall3b_f32" , cmsis_arm_nuttall3b_f32, METH_VARARGS,""},
|
|
|
+{"arm_nuttall3b_f64" , cmsis_arm_nuttall3b_f64, METH_VARARGS,""},
|
|
|
+
|
|
|
+
|
|
|
+{"arm_nuttall4a_f32" , cmsis_arm_nuttall4a_f32, METH_VARARGS,""},
|
|
|
+{"arm_nuttall4a_f64" , cmsis_arm_nuttall4a_f64, METH_VARARGS,""},
|
|
|
+
|
|
|
+
|
|
|
+{"arm_blackman_harris_92db_f32" , cmsis_arm_blackman_harris_92db_f32, METH_VARARGS,""},
|
|
|
+{"arm_blackman_harris_92db_f64" , cmsis_arm_blackman_harris_92db_f64, METH_VARARGS,""},
|
|
|
+
|
|
|
+
|
|
|
+{"arm_nuttall4b_f32" , cmsis_arm_nuttall4b_f32, METH_VARARGS,""},
|
|
|
+{"arm_nuttall4b_f64" , cmsis_arm_nuttall4b_f64, METH_VARARGS,""},
|
|
|
+
|
|
|
+
|
|
|
+{"arm_nuttall4c_f32" , cmsis_arm_nuttall4c_f32, METH_VARARGS,""},
|
|
|
+{"arm_nuttall4c_f64" , cmsis_arm_nuttall4c_f64, METH_VARARGS,""},
|
|
|
+
|
|
|
+
|
|
|
+{"arm_hft90d_f32" , cmsis_arm_hft90d_f32, METH_VARARGS,""},
|
|
|
+{"arm_hft90d_f64" , cmsis_arm_hft90d_f64, METH_VARARGS,""},
|
|
|
+
|
|
|
+
|
|
|
+{"arm_hft95_f32" , cmsis_arm_hft95_f32, METH_VARARGS,""},
|
|
|
+{"arm_hft95_f64" , cmsis_arm_hft95_f64, METH_VARARGS,""},
|
|
|
+
|
|
|
+
|
|
|
+{"arm_hft116d_f32" , cmsis_arm_hft116d_f32, METH_VARARGS,""},
|
|
|
+{"arm_hft116d_f64" , cmsis_arm_hft116d_f64, METH_VARARGS,""},
|
|
|
+
|
|
|
+
|
|
|
+{"arm_hft144d_f32" , cmsis_arm_hft144d_f32, METH_VARARGS,""},
|
|
|
+{"arm_hft144d_f64" , cmsis_arm_hft144d_f64, METH_VARARGS,""},
|
|
|
+
|
|
|
+
|
|
|
+{"arm_hft169d_f32" , cmsis_arm_hft169d_f32, METH_VARARGS,""},
|
|
|
+{"arm_hft169d_f64" , cmsis_arm_hft169d_f64, METH_VARARGS,""},
|
|
|
+
|
|
|
+
|
|
|
+{"arm_hft196d_f32" , cmsis_arm_hft196d_f32, METH_VARARGS,""},
|
|
|
+{"arm_hft196d_f64" , cmsis_arm_hft196d_f64, METH_VARARGS,""},
|
|
|
+
|
|
|
+
|
|
|
+{"arm_hft223d_f32" , cmsis_arm_hft223d_f32, METH_VARARGS,""},
|
|
|
+{"arm_hft223d_f64" , cmsis_arm_hft223d_f64, METH_VARARGS,""},
|
|
|
+
|
|
|
+
|
|
|
+{"arm_hft248d_f32" , cmsis_arm_hft248d_f32, METH_VARARGS,""},
|
|
|
+{"arm_hft248d_f64" , cmsis_arm_hft248d_f64, METH_VARARGS,""},
|
|
|
+
|
|
|
+
|
|
|
+ {"error_out", (PyCFunction)error_out, METH_NOARGS, NULL},
|
|
|
+ {NULL, NULL, 0, NULL} /* Sentinel */
|
|
|
+};
|
|
|
+
|
|
|
+#ifdef IS_PY3K
|
|
|
+static int cmsisdsp_traverse(PyObject *m, visitproc visit, void *arg) {
|
|
|
+ Py_VISIT(GETSTATE(m)->error);
|
|
|
+ return 0;
|
|
|
+}
|
|
|
+
|
|
|
+static int cmsisdsp_clear(PyObject *m) {
|
|
|
+ Py_CLEAR(GETSTATE(m)->error);
|
|
|
+ return 0;
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+static struct PyModuleDef moduledef = {
|
|
|
+ PyModuleDef_HEAD_INIT,
|
|
|
+ MODNAME,
|
|
|
+ NULL,
|
|
|
+ sizeof(struct module_state),
|
|
|
+ CMSISDSPMethods,
|
|
|
+ NULL,
|
|
|
+ cmsisdsp_traverse,
|
|
|
+ cmsisdsp_clear,
|
|
|
+ NULL
|
|
|
+};
|
|
|
+
|
|
|
+#define INITERROR return NULL
|
|
|
+
|
|
|
+PyMODINIT_FUNC
|
|
|
+CAT(PyInit_,MODINITNAME)(void)
|
|
|
+
|
|
|
+
|
|
|
+#else
|
|
|
+#define INITERROR return
|
|
|
+
|
|
|
+void CAT(init,MODINITNAME)(void)
|
|
|
+#endif
|
|
|
+{
|
|
|
+ import_array();
|
|
|
+
|
|
|
+ #ifdef IS_PY3K
|
|
|
+ PyObject *module = PyModule_Create(&moduledef);
|
|
|
+ #else
|
|
|
+ PyObject *module = Py_InitModule(MODNAME, CMSISDSPMethods);
|
|
|
+ #endif
|
|
|
+
|
|
|
+ if (module == NULL)
|
|
|
+ INITERROR;
|
|
|
+ struct module_state *st = GETSTATE(module);
|
|
|
+
|
|
|
+ st->error = PyErr_NewException(MODNAME".Error", NULL, NULL);
|
|
|
+ if (st->error == NULL) {
|
|
|
+ Py_DECREF(module);
|
|
|
+ INITERROR;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ typeRegistration(module);
|
|
|
+
|
|
|
+ #ifdef IS_PY3K
|
|
|
+ return module;
|
|
|
+ #endif
|
|
|
+}
|