You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
2472 lines
54 KiB
C
2472 lines
54 KiB
C
/* ----------------------------------------------------------------------
|
|
* Project: CMSIS DSP Python Wrapper
|
|
* Title: cmsismodule.h
|
|
* Description: C code for the CMSIS-DSP Python wrapper
|
|
*
|
|
* $Date: 27 April 2021
|
|
* $Revision: V1.0
|
|
*
|
|
* Target Processor: Cortex-M cores
|
|
* -------------------------------------------------------------------- */
|
|
/*
|
|
* Copyright (C) 2010-2021 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_statistics"
|
|
#define MODINITNAME cmsisdsp_statistics
|
|
|
|
#include "cmsisdsp_module.h"
|
|
|
|
|
|
NUMPYVECTORFROMBUFFER(f32,float32_t,NPY_FLOAT);
|
|
|
|
|
|
|
|
void typeRegistration(PyObject *module) {
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static PyObject *
|
|
cmsis_arm_power_q31(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q31_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q63_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT32,int32_t,int32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
arm_power_q31(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("L",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
|
|
static PyObject *
|
|
cmsis_arm_power_f32(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float32_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float32_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
arm_power_f32(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("f",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_power_f64(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float64_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float64_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float64_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
arm_power_f64(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("d",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
|
|
static PyObject *
|
|
cmsis_arm_power_q15(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q15_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q63_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT16,int16_t,int16_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
|
|
arm_power_q15(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("L",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
|
|
static PyObject *
|
|
cmsis_arm_power_q7(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q7_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q31_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_BYTE,int8_t,q7_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
arm_power_q7(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("i",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
|
|
static PyObject *
|
|
cmsis_arm_mean_q7(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q7_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q7_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_BYTE,int8_t,q7_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
|
|
arm_mean_q7(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("i",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
|
|
static PyObject *
|
|
cmsis_arm_mean_q15(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q15_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q15_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT16,int16_t,int16_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
|
|
arm_mean_q15(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("h",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
|
|
static PyObject *
|
|
cmsis_arm_mean_q31(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q31_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q31_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT32,int32_t,int32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
|
|
arm_mean_q31(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("i",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
|
|
static PyObject *
|
|
cmsis_arm_mean_f32(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float32_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float32_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
arm_mean_f32(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("f",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_mean_f64(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float64_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float64_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float64_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
arm_mean_f64(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("d",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_var_f32(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float32_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float32_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
|
|
arm_var_f32(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("f",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_var_f64(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float64_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float64_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float64_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
|
|
arm_var_f64(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("d",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_var_q31(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q31_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q31_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT32,int32_t,int32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
arm_var_q31(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("i",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
|
|
static PyObject *
|
|
cmsis_arm_var_q15(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q15_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q15_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT16,int16_t,int16_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
arm_var_q15(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("h",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
|
|
static PyObject *
|
|
cmsis_arm_rms_f32(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float32_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float32_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
|
|
arm_rms_f32(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("f",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
|
|
static PyObject *
|
|
cmsis_arm_rms_q31(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q31_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q31_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT32,int32_t,int32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
arm_rms_q31(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("i",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
|
|
static PyObject *
|
|
cmsis_arm_rms_q15(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q15_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q15_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT16,int16_t,int16_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
arm_rms_q15(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("h",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
|
|
static PyObject *
|
|
cmsis_arm_std_f32(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float32_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float32_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
|
|
arm_std_f32(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("f",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_std_f64(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float64_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float64_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float64_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
|
|
arm_std_f64(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("d",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
|
|
static PyObject *
|
|
cmsis_arm_std_q31(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q31_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q31_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT32,int32_t,int32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
arm_std_q31(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("i",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
|
|
static PyObject *
|
|
cmsis_arm_std_q15(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q15_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q15_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT16,int16_t,int16_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
arm_std_q15(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("h",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
|
|
|
|
|
|
static PyObject *
|
|
cmsis_arm_min_q7(PyObject *obj, PyObject *args)
|
|
{
|
|
PyObject *pSrc=NULL; // input
|
|
q7_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q7_t pResult; // output
|
|
uint32_t pIndex; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_BYTE,int8_t,q7_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
arm_min_q7(pSrc_converted,blockSize,&pResult,&pIndex);
|
|
PyObject* pResultOBJ=Py_BuildValue("i",pResult);
|
|
PyObject* pIndexOBJ=Py_BuildValue("i",pIndex);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("OO",pResultOBJ,pIndexOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
Py_DECREF(pIndexOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_min_no_idx_q7(PyObject *obj, PyObject *args)
|
|
{
|
|
PyObject *pSrc=NULL; // input
|
|
q7_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q7_t pResult;
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_BYTE,int8_t,q7_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
|
|
arm_min_no_idx_q7(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("i",pResult);
|
|
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
return(pResultOBJ);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_absmin_q7(PyObject *obj, PyObject *args)
|
|
{
|
|
PyObject *pSrc=NULL; // input
|
|
q7_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q7_t pResult; // output
|
|
uint32_t pIndex; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_BYTE,int8_t,q7_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
arm_absmin_q7(pSrc_converted,blockSize,&pResult,&pIndex);
|
|
PyObject* pResultOBJ=Py_BuildValue("i",pResult);
|
|
PyObject* pIndexOBJ=Py_BuildValue("i",pIndex);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("OO",pResultOBJ,pIndexOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
Py_DECREF(pIndexOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_absmin_no_idx_q7(PyObject *obj, PyObject *args)
|
|
{
|
|
PyObject *pSrc=NULL; // input
|
|
q7_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q7_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_BYTE,int8_t,q7_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
|
|
|
|
|
|
arm_absmin_no_idx_q7(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("i",pResult);
|
|
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
return(pResultOBJ);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
|
|
static PyObject *
|
|
cmsis_arm_min_q15(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q15_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q15_t pResult; // output
|
|
uint32_t pIndex; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT16,int16_t,int16_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
arm_min_q15(pSrc_converted,blockSize,&pResult,&pIndex);
|
|
PyObject* pResultOBJ=Py_BuildValue("h",pResult);
|
|
PyObject* pIndexOBJ=Py_BuildValue("i",pIndex);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("OO",pResultOBJ,pIndexOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
Py_DECREF(pIndexOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_min_no_idx_q15(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q15_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q15_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT16,int16_t,int16_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
|
|
|
|
|
|
arm_min_no_idx_q15(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("h",pResult);
|
|
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
return(pResultOBJ);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_absmin_q15(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q15_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q15_t pResult; // output
|
|
uint32_t pIndex; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT16,int16_t,int16_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
arm_absmin_q15(pSrc_converted,blockSize,&pResult,&pIndex);
|
|
PyObject* pResultOBJ=Py_BuildValue("h",pResult);
|
|
PyObject* pIndexOBJ=Py_BuildValue("i",pIndex);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("OO",pResultOBJ,pIndexOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
Py_DECREF(pIndexOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_absmin_no_idx_q15(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q15_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q15_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT16,int16_t,int16_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
|
|
|
|
|
|
arm_absmin_no_idx_q15(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("h",pResult);
|
|
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
return(pResultOBJ);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
|
|
static PyObject *
|
|
cmsis_arm_min_q31(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q31_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q31_t pResult; // output
|
|
uint32_t pIndex; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT32,int32_t,int32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
arm_min_q31(pSrc_converted,blockSize,&pResult,&pIndex);
|
|
PyObject* pResultOBJ=Py_BuildValue("i",pResult);
|
|
PyObject* pIndexOBJ=Py_BuildValue("i",pIndex);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("OO",pResultOBJ,pIndexOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
Py_DECREF(pIndexOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_min_no_idx_q31(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q31_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q31_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT32,int32_t,int32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
|
|
|
|
|
|
arm_min_no_idx_q31(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("i",pResult);
|
|
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
return(pResultOBJ);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_absmin_q31(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q31_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q31_t pResult; // output
|
|
uint32_t pIndex; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT32,int32_t,int32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
arm_absmin_q31(pSrc_converted,blockSize,&pResult,&pIndex);
|
|
PyObject* pResultOBJ=Py_BuildValue("i",pResult);
|
|
PyObject* pIndexOBJ=Py_BuildValue("i",pIndex);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("OO",pResultOBJ,pIndexOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
Py_DECREF(pIndexOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_absmin_no_idx_q31(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q31_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q31_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT32,int32_t,int32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
|
|
|
|
arm_absmin_no_idx_q31(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("i",pResult);
|
|
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
return(pResultOBJ);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
|
|
static PyObject *
|
|
cmsis_arm_min_f32(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float32_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float32_t pResult; // output
|
|
uint32_t pIndex; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
arm_min_f32(pSrc_converted,blockSize,&pResult,&pIndex);
|
|
PyObject* pResultOBJ=Py_BuildValue("f",pResult);
|
|
PyObject* pIndexOBJ=Py_BuildValue("i",pIndex);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("OO",pResultOBJ,pIndexOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
Py_DECREF(pIndexOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_min_f64(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float64_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float64_t pResult; // output
|
|
uint32_t pIndex; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float64_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
arm_min_f64(pSrc_converted,blockSize,&pResult,&pIndex);
|
|
PyObject* pResultOBJ=Py_BuildValue("d",pResult);
|
|
PyObject* pIndexOBJ=Py_BuildValue("i",pIndex);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("OO",pResultOBJ,pIndexOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
Py_DECREF(pIndexOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_min_no_idx_f32(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float32_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float32_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
arm_min_no_idx_f32(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("f",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_min_no_idx_f64(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float64_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float64_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float64_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
arm_min_no_idx_f64(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("d",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_absmin_f32(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float32_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float32_t pResult; // output
|
|
uint32_t pIndex; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
arm_absmin_f32(pSrc_converted,blockSize,&pResult,&pIndex);
|
|
PyObject* pResultOBJ=Py_BuildValue("f",pResult);
|
|
PyObject* pIndexOBJ=Py_BuildValue("i",pIndex);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("OO",pResultOBJ,pIndexOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
Py_DECREF(pIndexOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_absmin_f64(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float64_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float64_t pResult; // output
|
|
uint32_t pIndex; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float64_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
arm_absmin_f64(pSrc_converted,blockSize,&pResult,&pIndex);
|
|
PyObject* pResultOBJ=Py_BuildValue("d",pResult);
|
|
PyObject* pIndexOBJ=Py_BuildValue("i",pIndex);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("OO",pResultOBJ,pIndexOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
Py_DECREF(pIndexOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_absmin_no_idx_f32(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float32_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float32_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
arm_absmin_no_idx_f32(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("f",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_absmin_no_idx_f64(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float64_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float64_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float64_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
arm_absmin_no_idx_f64(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("d",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
|
|
static PyObject *
|
|
cmsis_arm_max_q7(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q7_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q7_t pResult; // output
|
|
uint32_t pIndex; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_BYTE,int8_t,q7_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
arm_max_q7(pSrc_converted,blockSize,&pResult,&pIndex);
|
|
PyObject* pResultOBJ=Py_BuildValue("i",pResult);
|
|
PyObject* pIndexOBJ=Py_BuildValue("i",pIndex);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("OO",pResultOBJ,pIndexOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
Py_DECREF(pIndexOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_max_no_idx_q7(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q7_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q7_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_BYTE,int8_t,q7_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
|
|
|
|
|
|
arm_max_no_idx_q7(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("i",pResult);
|
|
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
return(pResultOBJ);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_absmax_q7(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q7_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q7_t pResult; // output
|
|
uint32_t pIndex; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_BYTE,int8_t,q7_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
arm_absmax_q7(pSrc_converted,blockSize,&pResult,&pIndex);
|
|
PyObject* pResultOBJ=Py_BuildValue("i",pResult);
|
|
PyObject* pIndexOBJ=Py_BuildValue("i",pIndex);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("OO",pResultOBJ,pIndexOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
Py_DECREF(pIndexOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_absmax_no_idx_q7(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q7_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q7_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_BYTE,int8_t,q7_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
|
|
|
|
|
|
arm_absmax_no_idx_q7(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("i",pResult);
|
|
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
return(pResultOBJ);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
|
|
static PyObject *
|
|
cmsis_arm_max_q15(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q15_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q15_t pResult; // output
|
|
uint32_t pIndex; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT16,int16_t,int16_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
arm_max_q15(pSrc_converted,blockSize,&pResult,&pIndex);
|
|
PyObject* pResultOBJ=Py_BuildValue("h",pResult);
|
|
PyObject* pIndexOBJ=Py_BuildValue("i",pIndex);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("OO",pResultOBJ,pIndexOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
Py_DECREF(pIndexOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_max_no_idx_q15(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q15_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q15_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT16,int16_t,int16_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
|
|
|
|
|
|
arm_max_no_idx_q15(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("h",pResult);
|
|
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
return(pResultOBJ);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_absmax_q15(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q15_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q15_t pResult; // output
|
|
uint32_t pIndex; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT16,int16_t,int16_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
arm_absmax_q15(pSrc_converted,blockSize,&pResult,&pIndex);
|
|
PyObject* pResultOBJ=Py_BuildValue("h",pResult);
|
|
PyObject* pIndexOBJ=Py_BuildValue("i",pIndex);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("OO",pResultOBJ,pIndexOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
Py_DECREF(pIndexOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_absmax_no_idx_q15(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q15_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q15_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT16,int16_t,int16_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
|
|
|
|
arm_absmax_no_idx_q15(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("h",pResult);
|
|
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
return(pResultOBJ);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
|
|
static PyObject *
|
|
cmsis_arm_max_q31(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q31_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q31_t pResult; // output
|
|
uint32_t pIndex; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT32,int32_t,int32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
arm_max_q31(pSrc_converted,blockSize,&pResult,&pIndex);
|
|
PyObject* pResultOBJ=Py_BuildValue("i",pResult);
|
|
PyObject* pIndexOBJ=Py_BuildValue("i",pIndex);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("OO",pResultOBJ,pIndexOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
Py_DECREF(pIndexOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_max_no_idx_q31(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q31_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q31_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT32,int32_t,int32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
|
|
|
|
|
|
arm_max_no_idx_q31(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("i",pResult);
|
|
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
return(pResultOBJ);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_absmax_q31(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q31_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q31_t pResult; // output
|
|
uint32_t pIndex; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT32,int32_t,int32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
arm_absmax_q31(pSrc_converted,blockSize,&pResult,&pIndex);
|
|
PyObject* pResultOBJ=Py_BuildValue("i",pResult);
|
|
PyObject* pIndexOBJ=Py_BuildValue("i",pIndex);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("OO",pResultOBJ,pIndexOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
Py_DECREF(pIndexOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_absmax_no_idx_q31(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
q31_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
q31_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_INT32,int32_t,int32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
|
|
|
|
arm_absmax_no_idx_q31(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("i",pResult);
|
|
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
return(pResultOBJ);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
|
|
static PyObject *
|
|
cmsis_arm_max_f32(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float32_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float32_t pResult; // output
|
|
uint32_t pIndex; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
arm_max_f32(pSrc_converted,blockSize,&pResult,&pIndex);
|
|
PyObject* pResultOBJ=Py_BuildValue("f",pResult);
|
|
PyObject* pIndexOBJ=Py_BuildValue("i",pIndex);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("OO",pResultOBJ,pIndexOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
Py_DECREF(pIndexOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_max_f64(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float64_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float64_t pResult; // output
|
|
uint32_t pIndex; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float64_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
arm_max_f64(pSrc_converted,blockSize,&pResult,&pIndex);
|
|
PyObject* pResultOBJ=Py_BuildValue("d",pResult);
|
|
PyObject* pIndexOBJ=Py_BuildValue("i",pIndex);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("OO",pResultOBJ,pIndexOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
Py_DECREF(pIndexOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_max_no_idx_f32(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float32_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float32_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
arm_max_no_idx_f32(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("f",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_max_no_idx_f64(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float64_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float64_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float64_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
|
|
arm_max_no_idx_f64(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("d",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_absmax_f32(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float32_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float32_t pResult; // output
|
|
uint32_t pIndex; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
arm_absmax_f32(pSrc_converted,blockSize,&pResult,&pIndex);
|
|
PyObject* pResultOBJ=Py_BuildValue("f",pResult);
|
|
PyObject* pIndexOBJ=Py_BuildValue("i",pIndex);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("OO",pResultOBJ,pIndexOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
Py_DECREF(pIndexOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_absmax_f64(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float64_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float64_t pResult; // output
|
|
uint32_t pIndex; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float64_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
arm_absmax_f64(pSrc_converted,blockSize,&pResult,&pIndex);
|
|
PyObject* pResultOBJ=Py_BuildValue("d",pResult);
|
|
PyObject* pIndexOBJ=Py_BuildValue("i",pIndex);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("OO",pResultOBJ,pIndexOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
Py_DECREF(pIndexOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_absmax_no_idx_f32(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float32_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float32_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
arm_absmax_no_idx_f32(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("f",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_absmax_no_idx_f64(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float64_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float64_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float64_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
arm_absmax_no_idx_f64(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("d",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_entropy_f32(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float32_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float32_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
pResult=arm_entropy_f32(pSrc_converted,blockSize);
|
|
PyObject* pResultOBJ=Py_BuildValue("f",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_accumulate_f32(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float32_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float32_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
arm_accumulate_f32(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("f",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_entropy_f64(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float64_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float64_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float64_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
pResult=arm_entropy_f64(pSrc_converted,blockSize);
|
|
PyObject* pResultOBJ=Py_BuildValue("d",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_accumulate_f64(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float64_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float64_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float64_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
arm_accumulate_f64(pSrc_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("d",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_kullback_leibler_f32(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrcA=NULL; // input
|
|
float32_t *pSrcA_converted=NULL; // input
|
|
PyObject *pSrcB=NULL; // input
|
|
float32_t *pSrcB_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float32_t result; // output
|
|
|
|
if (PyArg_ParseTuple(args,"OO",&pSrcA,&pSrcB))
|
|
{
|
|
|
|
GETARGUMENT(pSrcA,NPY_DOUBLE,double,float32_t);
|
|
GETARGUMENT(pSrcB,NPY_DOUBLE,double,float32_t);
|
|
blockSize = arraySizepSrcA ;
|
|
|
|
|
|
|
|
result=arm_kullback_leibler_f32(pSrcA_converted,pSrcB_converted,blockSize);
|
|
PyObject* resultOBJ=Py_BuildValue("f",result);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",resultOBJ);
|
|
|
|
FREEARGUMENT(pSrcA_converted);
|
|
FREEARGUMENT(pSrcB_converted);
|
|
Py_DECREF(resultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_kullback_leibler_f64(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrcA=NULL; // input
|
|
float64_t *pSrcA_converted=NULL; // input
|
|
PyObject *pSrcB=NULL; // input
|
|
float64_t *pSrcB_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float64_t result; // output
|
|
|
|
if (PyArg_ParseTuple(args,"OO",&pSrcA,&pSrcB))
|
|
{
|
|
|
|
GETARGUMENT(pSrcA,NPY_DOUBLE,double,float64_t);
|
|
GETARGUMENT(pSrcB,NPY_DOUBLE,double,float64_t);
|
|
blockSize = arraySizepSrcA ;
|
|
|
|
|
|
|
|
result=arm_kullback_leibler_f64(pSrcA_converted,pSrcB_converted,blockSize);
|
|
PyObject* resultOBJ=Py_BuildValue("d",result);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",resultOBJ);
|
|
|
|
FREEARGUMENT(pSrcA_converted);
|
|
FREEARGUMENT(pSrcB_converted);
|
|
Py_DECREF(resultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_logsumexp_f32(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrc=NULL; // input
|
|
float32_t *pSrc_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float32_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"O",&pSrc))
|
|
{
|
|
|
|
GETARGUMENT(pSrc,NPY_DOUBLE,double,float32_t);
|
|
blockSize = arraySizepSrc ;
|
|
|
|
pResult=arm_logsumexp_f32(pSrc_converted,blockSize);
|
|
PyObject* pResultOBJ=Py_BuildValue("f",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrc_converted);
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_logsumexp_dot_prod_f32(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrcA=NULL; // input
|
|
float32_t *pSrcA_converted=NULL; // input
|
|
PyObject *pSrcB=NULL; // input
|
|
float32_t *pSrcB_converted=NULL; // input
|
|
uint32_t blockSize; // input
|
|
float32_t result; // output
|
|
|
|
if (PyArg_ParseTuple(args,"OO",&pSrcA,&pSrcB))
|
|
{
|
|
|
|
GETARGUMENT(pSrcA,NPY_DOUBLE,double,float32_t);
|
|
GETARGUMENT(pSrcB,NPY_DOUBLE,double,float32_t);
|
|
blockSize = arraySizepSrcA ;
|
|
|
|
float32_t *tmp=PyMem_Malloc(sizeof(float32_t)*blockSize);
|
|
|
|
result=arm_logsumexp_dot_prod_f32(pSrcA_converted,pSrcB_converted,blockSize,tmp);
|
|
PyMem_Free(tmp);
|
|
|
|
PyObject* resultOBJ=Py_BuildValue("f",result);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",resultOBJ);
|
|
|
|
FREEARGUMENT(pSrcA_converted);
|
|
FREEARGUMENT(pSrcB_converted);
|
|
Py_DECREF(resultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_mse_q7(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrcA=NULL; // input
|
|
q7_t *pSrcA_converted=NULL; // input
|
|
PyObject *pSrcB=NULL; // input
|
|
q7_t *pSrcB_converted=NULL; // input
|
|
|
|
uint32_t blockSize; // input
|
|
q7_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"OO",&pSrcA,&pSrcB))
|
|
{
|
|
|
|
GETARGUMENT(pSrcA,NPY_BYTE,int8_t,q7_t);
|
|
GETARGUMENT(pSrcB,NPY_BYTE,int8_t,q7_t);
|
|
|
|
blockSize = arraySizepSrcA ;
|
|
|
|
|
|
arm_mse_q7(pSrcA_converted,pSrcB_converted, blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("i",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrcA_converted);
|
|
FREEARGUMENT(pSrcB_converted);
|
|
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_mse_q15(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrcA=NULL; // input
|
|
q15_t *pSrcA_converted=NULL; // input
|
|
PyObject *pSrcB=NULL; // input
|
|
q15_t *pSrcB_converted=NULL; // input
|
|
|
|
uint32_t blockSize; // input
|
|
q15_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"OO",&pSrcA,&pSrcB))
|
|
{
|
|
|
|
GETARGUMENT(pSrcA,NPY_INT16,int16_t,q15_t);
|
|
GETARGUMENT(pSrcB,NPY_INT16,int16_t,q15_t);
|
|
|
|
blockSize = arraySizepSrcA ;
|
|
|
|
|
|
arm_mse_q15(pSrcA_converted,pSrcB_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("i",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrcA_converted);
|
|
FREEARGUMENT(pSrcB_converted);
|
|
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_mse_q31(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrcA=NULL; // input
|
|
q31_t *pSrcA_converted=NULL; // input
|
|
PyObject *pSrcB=NULL; // input
|
|
q31_t *pSrcB_converted=NULL; // input
|
|
|
|
uint32_t blockSize; // input
|
|
q31_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"OO",&pSrcA,&pSrcB))
|
|
{
|
|
|
|
GETARGUMENT(pSrcA,NPY_INT32,int32_t,q31_t);
|
|
GETARGUMENT(pSrcB,NPY_INT32,int32_t,q31_t);
|
|
|
|
blockSize = arraySizepSrcA ;
|
|
|
|
|
|
arm_mse_q31(pSrcA_converted,pSrcB_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("i",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrcA_converted);
|
|
FREEARGUMENT(pSrcB_converted);
|
|
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_mse_f32(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrcA=NULL; // input
|
|
float32_t *pSrcA_converted=NULL; // input
|
|
PyObject *pSrcB=NULL; // input
|
|
float32_t *pSrcB_converted=NULL; // input
|
|
|
|
uint32_t blockSize; // input
|
|
float32_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"OO",&pSrcA,&pSrcB))
|
|
{
|
|
|
|
GETARGUMENT(pSrcA,NPY_DOUBLE,double,float32_t);
|
|
GETARGUMENT(pSrcB,NPY_DOUBLE,double,float32_t);
|
|
|
|
blockSize = arraySizepSrcA ;
|
|
|
|
|
|
arm_mse_f32(pSrcA_converted,pSrcB_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("f",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrcA_converted);
|
|
FREEARGUMENT(pSrcB_converted);
|
|
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyObject *
|
|
cmsis_arm_mse_f64(PyObject *obj, PyObject *args)
|
|
{
|
|
|
|
PyObject *pSrcA=NULL; // input
|
|
float64_t *pSrcA_converted=NULL; // input
|
|
PyObject *pSrcB=NULL; // input
|
|
float64_t *pSrcB_converted=NULL; // input
|
|
|
|
uint32_t blockSize; // input
|
|
float64_t pResult; // output
|
|
|
|
if (PyArg_ParseTuple(args,"OO",&pSrcA,&pSrcB))
|
|
{
|
|
|
|
GETARGUMENT(pSrcA,NPY_DOUBLE,double,float64_t);
|
|
GETARGUMENT(pSrcB,NPY_DOUBLE,double,float64_t);
|
|
|
|
blockSize = arraySizepSrcA ;
|
|
|
|
|
|
arm_mse_f64(pSrcA_converted,pSrcB_converted,blockSize,&pResult);
|
|
PyObject* pResultOBJ=Py_BuildValue("d",pResult);
|
|
|
|
PyObject *pythonResult = Py_BuildValue("O",pResultOBJ);
|
|
|
|
FREEARGUMENT(pSrcA_converted);
|
|
FREEARGUMENT(pSrcB_converted);
|
|
|
|
Py_DECREF(pResultOBJ);
|
|
return(pythonResult);
|
|
|
|
}
|
|
return(NULL);
|
|
}
|
|
|
|
static PyMethodDef CMSISDSPMethods[] = {
|
|
|
|
|
|
{"arm_power_q31", cmsis_arm_power_q31, METH_VARARGS,""},
|
|
{"arm_power_f32", cmsis_arm_power_f32, METH_VARARGS,""},
|
|
{"arm_power_f64", cmsis_arm_power_f64, METH_VARARGS,""},
|
|
{"arm_power_q15", cmsis_arm_power_q15, METH_VARARGS,""},
|
|
{"arm_power_q7", cmsis_arm_power_q7, METH_VARARGS,""},
|
|
{"arm_mean_q7", cmsis_arm_mean_q7, METH_VARARGS,""},
|
|
{"arm_mean_q15", cmsis_arm_mean_q15, METH_VARARGS,""},
|
|
{"arm_mean_q31", cmsis_arm_mean_q31, METH_VARARGS,""},
|
|
{"arm_mean_f32", cmsis_arm_mean_f32, METH_VARARGS,""},
|
|
{"arm_mean_f64", cmsis_arm_mean_f64, METH_VARARGS,""},
|
|
{"arm_var_f32", cmsis_arm_var_f32, METH_VARARGS,""},
|
|
{"arm_var_f64", cmsis_arm_var_f64, METH_VARARGS,""},
|
|
{"arm_var_q31", cmsis_arm_var_q31, METH_VARARGS,""},
|
|
{"arm_var_q15", cmsis_arm_var_q15, METH_VARARGS,""},
|
|
{"arm_rms_f32", cmsis_arm_rms_f32, METH_VARARGS,""},
|
|
{"arm_rms_q31", cmsis_arm_rms_q31, METH_VARARGS,""},
|
|
{"arm_rms_q15", cmsis_arm_rms_q15, METH_VARARGS,""},
|
|
{"arm_std_f32", cmsis_arm_std_f32, METH_VARARGS,""},
|
|
{"arm_std_f64", cmsis_arm_std_f64, METH_VARARGS,""},
|
|
|
|
{"arm_std_q31", cmsis_arm_std_q31, METH_VARARGS,""},
|
|
{"arm_std_q15", cmsis_arm_std_q15, METH_VARARGS,""},
|
|
|
|
{"arm_min_q7", cmsis_arm_min_q7, METH_VARARGS,""},
|
|
{"arm_min_no_idx_q7", cmsis_arm_min_no_idx_q7, METH_VARARGS,""},
|
|
{"arm_min_no_idx_q15", cmsis_arm_min_no_idx_q15, METH_VARARGS,""},
|
|
{"arm_min_no_idx_q31", cmsis_arm_min_no_idx_q31, METH_VARARGS,""},
|
|
{"arm_min_q15", cmsis_arm_min_q15, METH_VARARGS,""},
|
|
{"arm_min_q31", cmsis_arm_min_q31, METH_VARARGS,""},
|
|
{"arm_min_f32", cmsis_arm_min_f32, METH_VARARGS,""},
|
|
{"arm_min_f64", cmsis_arm_min_f64, METH_VARARGS,""},
|
|
{"arm_min_no_idx_f32", cmsis_arm_min_no_idx_f32, METH_VARARGS,""},
|
|
{"arm_min_no_idx_f64", cmsis_arm_min_no_idx_f64, METH_VARARGS,""},
|
|
|
|
{"arm_absmin_q7", cmsis_arm_absmin_q7, METH_VARARGS,""},
|
|
{"arm_absmin_q15", cmsis_arm_absmin_q15, METH_VARARGS,""},
|
|
{"arm_absmin_q31", cmsis_arm_absmin_q31, METH_VARARGS,""},
|
|
{"arm_absmin_no_idx_q7", cmsis_arm_absmin_no_idx_q7, METH_VARARGS,""},
|
|
{"arm_absmin_no_idx_q15", cmsis_arm_absmin_no_idx_q15, METH_VARARGS,""},
|
|
{"arm_absmin_no_idx_q31", cmsis_arm_absmin_no_idx_q31, METH_VARARGS,""},
|
|
{"arm_absmin_f32", cmsis_arm_absmin_f32, METH_VARARGS,""},
|
|
{"arm_absmin_f64", cmsis_arm_absmin_f64, METH_VARARGS,""},
|
|
{"arm_absmin_no_idx_f64", cmsis_arm_absmin_no_idx_f64, METH_VARARGS,""},
|
|
{"arm_absmin_no_idx_f32", cmsis_arm_absmin_no_idx_f32, METH_VARARGS,""},
|
|
{"arm_max_q7", cmsis_arm_max_q7, METH_VARARGS,""},
|
|
{"arm_max_q15", cmsis_arm_max_q15, METH_VARARGS,""},
|
|
{"arm_max_q31", cmsis_arm_max_q31, METH_VARARGS,""},
|
|
{"arm_absmax_q7", cmsis_arm_absmax_q7, METH_VARARGS,""},
|
|
{"arm_absmax_q15", cmsis_arm_absmax_q15, METH_VARARGS,""},
|
|
{"arm_absmax_q31", cmsis_arm_absmax_q31, METH_VARARGS,""},
|
|
{"arm_max_f32", cmsis_arm_max_f32, METH_VARARGS,""},
|
|
{"arm_max_f64", cmsis_arm_max_f64, METH_VARARGS,""},
|
|
|
|
{"arm_max_no_idx_f32", cmsis_arm_max_no_idx_f32, METH_VARARGS,""},
|
|
{"arm_max_no_idx_f64", cmsis_arm_max_no_idx_f64, METH_VARARGS,""},
|
|
|
|
{"arm_absmax_f32", cmsis_arm_absmax_f32, METH_VARARGS,""},
|
|
{"arm_absmax_f64", cmsis_arm_absmax_f64, METH_VARARGS,""},
|
|
|
|
{"arm_absmax_no_idx_f32", cmsis_arm_absmax_no_idx_f32, METH_VARARGS,""},
|
|
{"arm_absmax_no_idx_f64", cmsis_arm_absmax_no_idx_f64, METH_VARARGS,""},
|
|
|
|
{"arm_max_no_idx_q7", cmsis_arm_max_no_idx_q7, METH_VARARGS,""},
|
|
{"arm_max_no_idx_q15", cmsis_arm_max_no_idx_q15, METH_VARARGS,""},
|
|
{"arm_max_no_idx_q31", cmsis_arm_max_no_idx_q31, METH_VARARGS,""},
|
|
{"arm_absmax_no_idx_q7", cmsis_arm_absmax_no_idx_q7, METH_VARARGS,""},
|
|
{"arm_absmax_no_idx_q15", cmsis_arm_absmax_no_idx_q15, METH_VARARGS,""},
|
|
{"arm_absmax_no_idx_q31", cmsis_arm_absmax_no_idx_q31, METH_VARARGS,""},
|
|
{"arm_entropy_f32", cmsis_arm_entropy_f32, METH_VARARGS,""},
|
|
{"arm_entropy_f64", cmsis_arm_entropy_f64, METH_VARARGS,""},
|
|
{"arm_kullback_leibler_f32", cmsis_arm_kullback_leibler_f32, METH_VARARGS,""},
|
|
{"arm_kullback_leibler_f64", cmsis_arm_kullback_leibler_f64, METH_VARARGS,""},
|
|
|
|
{"arm_logsumexp_f32", cmsis_arm_logsumexp_f32, METH_VARARGS,""},
|
|
{"arm_logsumexp_dot_prod_f32", cmsis_arm_logsumexp_dot_prod_f32, METH_VARARGS,""},
|
|
{"arm_mse_q7", cmsis_arm_mse_q7, METH_VARARGS,""},
|
|
{"arm_mse_q15", cmsis_arm_mse_q15, METH_VARARGS,""},
|
|
{"arm_mse_q31", cmsis_arm_mse_q31, METH_VARARGS,""},
|
|
{"arm_mse_f32", cmsis_arm_mse_f32, METH_VARARGS,""},
|
|
{"arm_mse_f64", cmsis_arm_mse_f64, METH_VARARGS,""},
|
|
{"arm_accumulate_f32", cmsis_arm_accumulate_f32, METH_VARARGS,""},
|
|
{"arm_accumulate_f64", cmsis_arm_accumulate_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
|
|
} |