Marcell Rausch / mbed-dev-no-serial

Fork of mbed-dev by mbed official

Embed: (wiki syntax)

« Back to documentation index

Show/hide line numbers arm_math.h Source File

arm_math.h

00001 /* ----------------------------------------------------------------------
00002 * Copyright (C) 2010-2015 ARM Limited. All rights reserved.
00003 *
00004 * $Date:        19. March 2015
00005 * $Revision:    V.1.4.5
00006 *
00007 * Project:      CMSIS DSP Library
00008 * Title:        arm_math.h
00009 *
00010 * Description:  Public header file for CMSIS DSP Library
00011 *
00012 * Target Processor: Cortex-M7/Cortex-M4/Cortex-M3/Cortex-M0
00013 *
00014 * Redistribution and use in source and binary forms, with or without
00015 * modification, are permitted provided that the following conditions
00016 * are met:
00017 *   - Redistributions of source code must retain the above copyright
00018 *     notice, this list of conditions and the following disclaimer.
00019 *   - Redistributions in binary form must reproduce the above copyright
00020 *     notice, this list of conditions and the following disclaimer in
00021 *     the documentation and/or other materials provided with the
00022 *     distribution.
00023 *   - Neither the name of ARM LIMITED nor the names of its contributors
00024 *     may be used to endorse or promote products derived from this
00025 *     software without specific prior written permission.
00026 *
00027 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
00028 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
00029 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
00030 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
00031 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
00032 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
00033 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
00034 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
00035 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
00036 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
00037 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00038 * POSSIBILITY OF SUCH DAMAGE.
00039  * -------------------------------------------------------------------- */
00040 
00041 /**
00042    \mainpage CMSIS DSP Software Library
00043    *
00044    * Introduction
00045    * ------------
00046    *
00047    * This user manual describes the CMSIS DSP software library,
00048    * a suite of common signal processing functions for use on Cortex-M processor based devices.
00049    *
00050    * The library is divided into a number of functions each covering a specific category:
00051    * - Basic math functions
00052    * - Fast math functions
00053    * - Complex math functions
00054    * - Filters
00055    * - Matrix functions
00056    * - Transforms
00057    * - Motor control functions
00058    * - Statistical functions
00059    * - Support functions
00060    * - Interpolation functions
00061    *
00062    * The library has separate functions for operating on 8-bit integers, 16-bit integers,
00063    * 32-bit integer and 32-bit floating-point values.
00064    *
00065    * Using the Library
00066    * ------------
00067    *
00068    * The library installer contains prebuilt versions of the libraries in the <code>Lib</code> folder.
00069    * - arm_cortexM7lfdp_math.lib (Little endian and Double Precision Floating Point Unit on Cortex-M7)
00070    * - arm_cortexM7bfdp_math.lib (Big endian and Double Precision Floating Point Unit on Cortex-M7)
00071    * - arm_cortexM7lfsp_math.lib (Little endian and Single Precision Floating Point Unit on Cortex-M7)
00072    * - arm_cortexM7bfsp_math.lib (Big endian and Single Precision Floating Point Unit on Cortex-M7)
00073    * - arm_cortexM7l_math.lib (Little endian on Cortex-M7)
00074    * - arm_cortexM7b_math.lib (Big endian on Cortex-M7)
00075    * - arm_cortexM4lf_math.lib (Little endian and Floating Point Unit on Cortex-M4)
00076    * - arm_cortexM4bf_math.lib (Big endian and Floating Point Unit on Cortex-M4)
00077    * - arm_cortexM4l_math.lib (Little endian on Cortex-M4)
00078    * - arm_cortexM4b_math.lib (Big endian on Cortex-M4)
00079    * - arm_cortexM3l_math.lib (Little endian on Cortex-M3)
00080    * - arm_cortexM3b_math.lib (Big endian on Cortex-M3)
00081    * - arm_cortexM0l_math.lib (Little endian on Cortex-M0 / CortexM0+)
00082    * - arm_cortexM0b_math.lib (Big endian on Cortex-M0 / CortexM0+)
00083    *
00084    * The library functions are declared in the public file <code>arm_math.h</code> which is placed in the <code>Include</code> folder.
00085    * Simply include this file and link the appropriate library in the application and begin calling the library functions. The Library supports single
00086    * public header file <code> arm_math.h</code> for Cortex-M7/M4/M3/M0/M0+ with little endian and big endian. Same header file will be used for floating point unit(FPU) variants.
00087    * Define the appropriate pre processor MACRO ARM_MATH_CM7 or ARM_MATH_CM4 or  ARM_MATH_CM3 or
00088    * ARM_MATH_CM0 or ARM_MATH_CM0PLUS depending on the target processor in the application.
00089    *
00090    * Examples
00091    * --------
00092    *
00093    * The library ships with a number of examples which demonstrate how to use the library functions.
00094    *
00095    * Toolchain Support
00096    * ------------
00097    *
00098    * The library has been developed and tested with MDK-ARM version 5.14.0.0
00099    * The library is being tested in GCC and IAR toolchains and updates on this activity will be made available shortly.
00100    *
00101    * Building the Library
00102    * ------------
00103    *
00104    * The library installer contains a project file to re build libraries on MDK-ARM Tool chain in the <code>CMSIS\\DSP_Lib\\Source\\ARM</code> folder.
00105    * - arm_cortexM_math.uvprojx
00106    *
00107    *
00108    * The libraries can be built by opening the arm_cortexM_math.uvprojx project in MDK-ARM, selecting a specific target, and defining the optional pre processor MACROs detailed above.
00109    *
00110    * Pre-processor Macros
00111    * ------------
00112    *
00113    * Each library project have differant pre-processor macros.
00114    *
00115    * - UNALIGNED_SUPPORT_DISABLE:
00116    *
00117    * Define macro UNALIGNED_SUPPORT_DISABLE, If the silicon does not support unaligned memory access
00118    *
00119    * - ARM_MATH_BIG_ENDIAN:
00120    *
00121    * Define macro ARM_MATH_BIG_ENDIAN to build the library for big endian targets. By default library builds for little endian targets.
00122    *
00123    * - ARM_MATH_MATRIX_CHECK:
00124    *
00125    * Define macro ARM_MATH_MATRIX_CHECK for checking on the input and output sizes of matrices
00126    *
00127    * - ARM_MATH_ROUNDING:
00128    *
00129    * Define macro ARM_MATH_ROUNDING for rounding on support functions
00130    *
00131    * - ARM_MATH_CMx:
00132    *
00133    * Define macro ARM_MATH_CM4 for building the library on Cortex-M4 target, ARM_MATH_CM3 for building library on Cortex-M3 target
00134    * and ARM_MATH_CM0 for building library on Cortex-M0 target, ARM_MATH_CM0PLUS for building library on Cortex-M0+ target, and
00135    * ARM_MATH_CM7 for building the library on cortex-M7.
00136    *
00137    * - __FPU_PRESENT:
00138    *
00139    * Initialize macro __FPU_PRESENT = 1 when building on FPU supported Targets. Enable this macro for M4bf and M4lf libraries
00140    *
00141    * <hr>
00142    * CMSIS-DSP in ARM::CMSIS Pack
00143    * -----------------------------
00144    * 
00145    * The following files relevant to CMSIS-DSP are present in the <b>ARM::CMSIS</b> Pack directories:
00146    * |File/Folder                   |Content                                                                 |
00147    * |------------------------------|------------------------------------------------------------------------|
00148    * |\b CMSIS\\Documentation\\DSP  | This documentation                                                     |
00149    * |\b CMSIS\\DSP_Lib             | Software license agreement (license.txt)                               |
00150    * |\b CMSIS\\DSP_Lib\\Examples   | Example projects demonstrating the usage of the library functions      |
00151    * |\b CMSIS\\DSP_Lib\\Source     | Source files for rebuilding the library                                |
00152    * 
00153    * <hr>
00154    * Revision History of CMSIS-DSP
00155    * ------------
00156    * Please refer to \ref ChangeLog_pg.
00157    *
00158    * Copyright Notice
00159    * ------------
00160    *
00161    * Copyright (C) 2010-2015 ARM Limited. All rights reserved.
00162    */
00163 
00164 
00165 /**
00166  * @defgroup groupMath Basic Math Functions
00167  */
00168 
00169 /**
00170  * @defgroup groupFastMath Fast Math Functions
00171  * This set of functions provides a fast approximation to sine, cosine, and square root.
00172  * As compared to most of the other functions in the CMSIS math library, the fast math functions
00173  * operate on individual values and not arrays.
00174  * There are separate functions for Q15, Q31, and floating-point data.
00175  *
00176  */
00177 
00178 /**
00179  * @defgroup groupCmplxMath Complex Math Functions
00180  * This set of functions operates on complex data vectors.
00181  * The data in the complex arrays is stored in an interleaved fashion
00182  * (real, imag, real, imag, ...).
00183  * In the API functions, the number of samples in a complex array refers
00184  * to the number of complex values; the array contains twice this number of
00185  * real values.
00186  */
00187 
00188 /**
00189  * @defgroup groupFilters Filtering Functions
00190  */
00191 
00192 /**
00193  * @defgroup groupMatrix Matrix Functions
00194  *
00195  * This set of functions provides basic matrix math operations.
00196  * The functions operate on matrix data structures.  For example,
00197  * the type
00198  * definition for the floating-point matrix structure is shown
00199  * below:
00200  * <pre>
00201  *     typedef struct
00202  *     {
00203  *       uint16_t numRows;     // number of rows of the matrix.
00204  *       uint16_t numCols;     // number of columns of the matrix.
00205  *       float32_t *pData;     // points to the data of the matrix.
00206  *     } arm_matrix_instance_f32;
00207  * </pre>
00208  * There are similar definitions for Q15 and Q31 data types.
00209  *
00210  * The structure specifies the size of the matrix and then points to
00211  * an array of data.  The array is of size <code>numRows X numCols</code>
00212  * and the values are arranged in row order.  That is, the
00213  * matrix element (i, j) is stored at:
00214  * <pre>
00215  *     pData[i*numCols + j]
00216  * </pre>
00217  *
00218  * \par Init Functions
00219  * There is an associated initialization function for each type of matrix
00220  * data structure.
00221  * The initialization function sets the values of the internal structure fields.
00222  * Refer to the function <code>arm_mat_init_f32()</code>, <code>arm_mat_init_q31()</code>
00223  * and <code>arm_mat_init_q15()</code> for floating-point, Q31 and Q15 types,  respectively.
00224  *
00225  * \par
00226  * Use of the initialization function is optional. However, if initialization function is used
00227  * then the instance structure cannot be placed into a const data section.
00228  * To place the instance structure in a const data
00229  * section, manually initialize the data structure.  For example:
00230  * <pre>
00231  * <code>arm_matrix_instance_f32 S = {nRows, nColumns, pData};</code>
00232  * <code>arm_matrix_instance_q31 S = {nRows, nColumns, pData};</code>
00233  * <code>arm_matrix_instance_q15 S = {nRows, nColumns, pData};</code>
00234  * </pre>
00235  * where <code>nRows</code> specifies the number of rows, <code>nColumns</code>
00236  * specifies the number of columns, and <code>pData</code> points to the
00237  * data array.
00238  *
00239  * \par Size Checking
00240  * By default all of the matrix functions perform size checking on the input and
00241  * output matrices.  For example, the matrix addition function verifies that the
00242  * two input matrices and the output matrix all have the same number of rows and
00243  * columns.  If the size check fails the functions return:
00244  * <pre>
00245  *     ARM_MATH_SIZE_MISMATCH
00246  * </pre>
00247  * Otherwise the functions return
00248  * <pre>
00249  *     ARM_MATH_SUCCESS
00250  * </pre>
00251  * There is some overhead associated with this matrix size checking.
00252  * The matrix size checking is enabled via the \#define
00253  * <pre>
00254  *     ARM_MATH_MATRIX_CHECK
00255  * </pre>
00256  * within the library project settings.  By default this macro is defined
00257  * and size checking is enabled.  By changing the project settings and
00258  * undefining this macro size checking is eliminated and the functions
00259  * run a bit faster.  With size checking disabled the functions always
00260  * return <code>ARM_MATH_SUCCESS</code>.
00261  */
00262 
00263 /**
00264  * @defgroup groupTransforms Transform Functions
00265  */
00266 
00267 /**
00268  * @defgroup groupController Controller Functions
00269  */
00270 
00271 /**
00272  * @defgroup groupStats Statistics Functions
00273  */
00274 /**
00275  * @defgroup groupSupport Support Functions
00276  */
00277 
00278 /**
00279  * @defgroup groupInterpolation Interpolation Functions
00280  * These functions perform 1- and 2-dimensional interpolation of data.
00281  * Linear interpolation is used for 1-dimensional data and
00282  * bilinear interpolation is used for 2-dimensional data.
00283  */
00284 
00285 /**
00286  * @defgroup groupExamples Examples
00287  */
00288 #ifndef _ARM_MATH_H
00289 #define _ARM_MATH_H
00290 
00291 #define __CMSIS_GENERIC         /* disable NVIC and Systick functions */
00292 
00293 #if defined(ARM_MATH_CM7)
00294   #include "core_cm7.h"
00295 #elif defined (ARM_MATH_CM4)
00296   #include "core_cm4.h"
00297 #elif defined (ARM_MATH_CM3)
00298   #include "core_cm3.h"
00299 #elif defined (ARM_MATH_CM0)
00300   #include "core_cm0.h"
00301 #define ARM_MATH_CM0_FAMILY
00302   #elif defined (ARM_MATH_CM0PLUS)
00303 #include "core_cm0plus.h"
00304   #define ARM_MATH_CM0_FAMILY
00305 #else
00306   #error "Define according the used Cortex core ARM_MATH_CM7, ARM_MATH_CM4, ARM_MATH_CM3, ARM_MATH_CM0PLUS or ARM_MATH_CM0"
00307 #endif
00308 
00309 #undef  __CMSIS_GENERIC         /* enable NVIC and Systick functions */
00310 #include "string.h"
00311 #include "math.h"
00312 #ifdef  __cplusplus
00313 extern "C"
00314 {
00315 #endif
00316 
00317 
00318   /**
00319    * @brief Macros required for reciprocal calculation in Normalized LMS
00320    */
00321 
00322 #define DELTA_Q31           (0x100)
00323 #define DELTA_Q15           0x5
00324 #define INDEX_MASK          0x0000003F
00325 #ifndef PI
00326 #define PI                  3.14159265358979f
00327 #endif
00328 
00329   /**
00330    * @brief Macros required for SINE and COSINE Fast math approximations
00331    */
00332 
00333 #define FAST_MATH_TABLE_SIZE  512
00334 #define FAST_MATH_Q31_SHIFT   (32 - 10)
00335 #define FAST_MATH_Q15_SHIFT   (16 - 10)
00336 #define CONTROLLER_Q31_SHIFT  (32 - 9)
00337 #define TABLE_SIZE  256
00338 #define TABLE_SPACING_Q31      0x400000
00339 #define TABLE_SPACING_Q15      0x80
00340 
00341   /**
00342    * @brief Macros required for SINE and COSINE Controller functions
00343    */
00344   /* 1.31(q31) Fixed value of 2/360 */
00345   /* -1 to +1 is divided into 360 values so total spacing is (2/360) */
00346 #define INPUT_SPACING           0xB60B61
00347 
00348   /**
00349    * @brief Macro for Unaligned Support
00350    */
00351 #ifndef UNALIGNED_SUPPORT_DISABLE
00352     #define ALIGN4
00353 #else
00354   #if defined  (__GNUC__)
00355     #define ALIGN4 __attribute__((aligned(4)))
00356   #else
00357     #define ALIGN4 __align(4)
00358   #endif
00359 #endif  /*  #ifndef UNALIGNED_SUPPORT_DISABLE   */
00360 
00361   /**
00362    * @brief Error status returned by some functions in the library.
00363    */
00364 
00365   typedef enum
00366   {
00367     ARM_MATH_SUCCESS = 0,                /**< No error */
00368     ARM_MATH_ARGUMENT_ERROR = -1,        /**< One or more arguments are incorrect */
00369     ARM_MATH_LENGTH_ERROR = -2,          /**< Length of data buffer is incorrect */
00370     ARM_MATH_SIZE_MISMATCH = -3,         /**< Size of matrices is not compatible with the operation. */
00371     ARM_MATH_NANINF = -4,                /**< Not-a-number (NaN) or infinity is generated */
00372     ARM_MATH_SINGULAR = -5,              /**< Generated by matrix inversion if the input matrix is singular and cannot be inverted. */
00373     ARM_MATH_TEST_FAILURE = -6           /**< Test Failed  */
00374   } arm_status;
00375 
00376   /**
00377    * @brief 8-bit fractional data type in 1.7 format.
00378    */
00379   typedef int8_t q7_t;
00380 
00381   /**
00382    * @brief 16-bit fractional data type in 1.15 format.
00383    */
00384   typedef int16_t q15_t;
00385 
00386   /**
00387    * @brief 32-bit fractional data type in 1.31 format.
00388    */
00389   typedef int32_t q31_t;
00390 
00391   /**
00392    * @brief 64-bit fractional data type in 1.63 format.
00393    */
00394   typedef int64_t q63_t;
00395 
00396   /**
00397    * @brief 32-bit floating-point type definition.
00398    */
00399   typedef float float32_t;
00400 
00401   /**
00402    * @brief 64-bit floating-point type definition.
00403    */
00404   typedef double float64_t;
00405 
00406   /**
00407    * @brief definition to read/write two 16 bit values.
00408    */
00409 #if defined __CC_ARM
00410   #define __SIMD32_TYPE int32_t __packed
00411   #define CMSIS_UNUSED __attribute__((unused))
00412 #elif defined __ICCARM__
00413   #define __SIMD32_TYPE int32_t __packed
00414   #define CMSIS_UNUSED
00415 #elif defined __GNUC__
00416   #define __SIMD32_TYPE int32_t
00417   #define CMSIS_UNUSED __attribute__((unused))
00418 #elif defined __CSMC__          /* Cosmic */
00419   #define __SIMD32_TYPE int32_t
00420   #define CMSIS_UNUSED
00421 #elif defined __TASKING__
00422   #define __SIMD32_TYPE __unaligned int32_t
00423   #define CMSIS_UNUSED
00424 #else
00425   #error Unknown compiler
00426 #endif
00427 
00428 #define __SIMD32(addr)  (*(__SIMD32_TYPE **) & (addr))
00429 #define __SIMD32_CONST(addr)  ((__SIMD32_TYPE *)(addr))
00430 
00431 #define _SIMD32_OFFSET(addr)  (*(__SIMD32_TYPE *)  (addr))
00432 
00433 #define __SIMD64(addr)  (*(int64_t **) & (addr))
00434 
00435 #if defined (ARM_MATH_CM3) || defined (ARM_MATH_CM0_FAMILY)
00436   /**
00437    * @brief definition to pack two 16 bit values.
00438    */
00439 #define __PKHBT(ARG1, ARG2, ARG3)      ( (((int32_t)(ARG1) <<  0) & (int32_t)0x0000FFFF) | \
00440                                          (((int32_t)(ARG2) << ARG3) & (int32_t)0xFFFF0000)  )
00441 #define __PKHTB(ARG1, ARG2, ARG3)      ( (((int32_t)(ARG1) <<  0) & (int32_t)0xFFFF0000) | \
00442                                          (((int32_t)(ARG2) >> ARG3) & (int32_t)0x0000FFFF)  )
00443 
00444 #endif
00445 
00446 
00447    /**
00448    * @brief definition to pack four 8 bit values.
00449    */
00450 #ifndef ARM_MATH_BIG_ENDIAN
00451 
00452 #define __PACKq7(v0,v1,v2,v3) ( (((int32_t)(v0) <<  0) & (int32_t)0x000000FF) | \
00453                                 (((int32_t)(v1) <<  8) & (int32_t)0x0000FF00) | \
00454                                 (((int32_t)(v2) << 16) & (int32_t)0x00FF0000) | \
00455                                 (((int32_t)(v3) << 24) & (int32_t)0xFF000000)  )
00456 #else
00457 
00458 #define __PACKq7(v0,v1,v2,v3) ( (((int32_t)(v3) <<  0) & (int32_t)0x000000FF) | \
00459                                 (((int32_t)(v2) <<  8) & (int32_t)0x0000FF00) | \
00460                                 (((int32_t)(v1) << 16) & (int32_t)0x00FF0000) | \
00461                                 (((int32_t)(v0) << 24) & (int32_t)0xFF000000)  )
00462 
00463 #endif
00464 
00465 
00466   /**
00467    * @brief Clips Q63 to Q31 values.
00468    */
00469   static __INLINE q31_t clip_q63_to_q31(
00470   q63_t x)
00471   {
00472     return ((q31_t) (x >> 32) != ((q31_t) x >> 31)) ?
00473       ((0x7FFFFFFF ^ ((q31_t) (x >> 63)))) : (q31_t) x;
00474   }
00475 
00476   /**
00477    * @brief Clips Q63 to Q15 values.
00478    */
00479   static __INLINE q15_t clip_q63_to_q15(
00480   q63_t x)
00481   {
00482     return ((q31_t) (x >> 32) != ((q31_t) x >> 31)) ?
00483       ((0x7FFF ^ ((q15_t) (x >> 63)))) : (q15_t) (x >> 15);
00484   }
00485 
00486   /**
00487    * @brief Clips Q31 to Q7 values.
00488    */
00489   static __INLINE q7_t clip_q31_to_q7(
00490   q31_t x)
00491   {
00492     return ((q31_t) (x >> 24) != ((q31_t) x >> 23)) ?
00493       ((0x7F ^ ((q7_t) (x >> 31)))) : (q7_t) x;
00494   }
00495 
00496   /**
00497    * @brief Clips Q31 to Q15 values.
00498    */
00499   static __INLINE q15_t clip_q31_to_q15(
00500   q31_t x)
00501   {
00502     return ((q31_t) (x >> 16) != ((q31_t) x >> 15)) ?
00503       ((0x7FFF ^ ((q15_t) (x >> 31)))) : (q15_t) x;
00504   }
00505 
00506   /**
00507    * @brief Multiplies 32 X 64 and returns 32 bit result in 2.30 format.
00508    */
00509 
00510   static __INLINE q63_t mult32x64(
00511   q63_t x,
00512   q31_t y)
00513   {
00514     return ((((q63_t) (x & 0x00000000FFFFFFFF) * y) >> 32) +
00515             (((q63_t) (x >> 32) * y)));
00516   }
00517 
00518 
00519 //#if defined (ARM_MATH_CM0_FAMILY) && defined ( __CC_ARM   )
00520 //#define __CLZ __clz
00521 //#endif
00522 
00523 //note: function can be removed when all toolchain support __CLZ for Cortex-M0
00524 #if defined (ARM_MATH_CM0_FAMILY) && ((defined (__ICCARM__))  )
00525 
00526   static __INLINE uint32_t __CLZ(
00527   q31_t data);
00528 
00529 
00530   static __INLINE uint32_t __CLZ(
00531   q31_t data)
00532   {
00533     uint32_t count = 0;
00534     uint32_t mask = 0x80000000;
00535 
00536     while((data & mask) == 0)
00537     {
00538       count += 1u;
00539       mask = mask >> 1u;
00540     }
00541 
00542     return (count);
00543 
00544   }
00545 
00546 #endif
00547 
00548   /**
00549    * @brief Function to Calculates 1/in (reciprocal) value of Q31 Data type.
00550    */
00551 
00552   static __INLINE uint32_t arm_recip_q31(
00553   q31_t in,
00554   q31_t * dst,
00555   q31_t * pRecipTable)
00556   {
00557 
00558     uint32_t out, tempVal;
00559     uint32_t index, i;
00560     uint32_t signBits;
00561 
00562     if(in > 0)
00563     {
00564       signBits = __CLZ(in) - 1;
00565     }
00566     else
00567     {
00568       signBits = __CLZ(-in) - 1;
00569     }
00570 
00571     /* Convert input sample to 1.31 format */
00572     in = in << signBits;
00573 
00574     /* calculation of index for initial approximated Val */
00575     index = (uint32_t) (in >> 24u);
00576     index = (index & INDEX_MASK);
00577 
00578     /* 1.31 with exp 1 */
00579     out = pRecipTable[index];
00580 
00581     /* calculation of reciprocal value */
00582     /* running approximation for two iterations */
00583     for (i = 0u; i < 2u; i++)
00584     {
00585       tempVal = (q31_t) (((q63_t) in * out) >> 31u);
00586       tempVal = 0x7FFFFFFF - tempVal;
00587       /*      1.31 with exp 1 */
00588       //out = (q31_t) (((q63_t) out * tempVal) >> 30u);
00589       out = (q31_t) clip_q63_to_q31(((q63_t) out * tempVal) >> 30u);
00590     }
00591 
00592     /* write output */
00593     *dst = out;
00594 
00595     /* return num of signbits of out = 1/in value */
00596     return (signBits + 1u);
00597 
00598   }
00599 
00600   /**
00601    * @brief Function to Calculates 1/in (reciprocal) value of Q15 Data type.
00602    */
00603   static __INLINE uint32_t arm_recip_q15(
00604   q15_t in,
00605   q15_t * dst,
00606   q15_t * pRecipTable)
00607   {
00608 
00609     uint32_t out = 0, tempVal = 0;
00610     uint32_t index = 0, i = 0;
00611     uint32_t signBits = 0;
00612 
00613     if(in > 0)
00614     {
00615       signBits = __CLZ(in) - 17;
00616     }
00617     else
00618     {
00619       signBits = __CLZ(-in) - 17;
00620     }
00621 
00622     /* Convert input sample to 1.15 format */
00623     in = in << signBits;
00624 
00625     /* calculation of index for initial approximated Val */
00626     index = in >> 8;
00627     index = (index & INDEX_MASK);
00628 
00629     /*      1.15 with exp 1  */
00630     out = pRecipTable[index];
00631 
00632     /* calculation of reciprocal value */
00633     /* running approximation for two iterations */
00634     for (i = 0; i < 2; i++)
00635     {
00636       tempVal = (q15_t) (((q31_t) in * out) >> 15);
00637       tempVal = 0x7FFF - tempVal;
00638       /*      1.15 with exp 1 */
00639       out = (q15_t) (((q31_t) out * tempVal) >> 14);
00640     }
00641 
00642     /* write output */
00643     *dst = out;
00644 
00645     /* return num of signbits of out = 1/in value */
00646     return (signBits + 1);
00647 
00648   }
00649 
00650 
00651   /*
00652    * @brief C custom defined intrinisic function for only M0 processors
00653    */
00654 #if defined(ARM_MATH_CM0_FAMILY)
00655 
00656   static __INLINE q31_t __SSAT(
00657   q31_t x,
00658   uint32_t y)
00659   {
00660     int32_t posMax, negMin;
00661     uint32_t i;
00662 
00663     posMax = 1;
00664     for (i = 0; i < (y - 1); i++)
00665     {
00666       posMax = posMax * 2;
00667     }
00668 
00669     if(x > 0)
00670     {
00671       posMax = (posMax - 1);
00672 
00673       if(x > posMax)
00674       {
00675         x = posMax;
00676       }
00677     }
00678     else
00679     {
00680       negMin = -posMax;
00681 
00682       if(x < negMin)
00683       {
00684         x = negMin;
00685       }
00686     }
00687     return (x);
00688 
00689 
00690   }
00691 
00692 #endif /* end of ARM_MATH_CM0_FAMILY */
00693 
00694 
00695 
00696   /*
00697    * @brief C custom defined intrinsic function for M3 and M0 processors
00698    */
00699 #if defined (ARM_MATH_CM3) || defined (ARM_MATH_CM0_FAMILY)
00700 
00701   /*
00702    * @brief C custom defined QADD8 for M3 and M0 processors
00703    */
00704   static __INLINE q31_t __QADD8(
00705   q31_t x,
00706   q31_t y)
00707   {
00708 
00709     q31_t sum;
00710     q7_t r, s, t, u;
00711 
00712     r = (q7_t) x;
00713     s = (q7_t) y;
00714 
00715     r = __SSAT((q31_t) (r + s), 8);
00716     s = __SSAT(((q31_t) (((x << 16) >> 24) + ((y << 16) >> 24))), 8);
00717     t = __SSAT(((q31_t) (((x << 8) >> 24) + ((y << 8) >> 24))), 8);
00718     u = __SSAT(((q31_t) ((x >> 24) + (y >> 24))), 8);
00719 
00720     sum =
00721       (((q31_t) u << 24) & 0xFF000000) | (((q31_t) t << 16) & 0x00FF0000) |
00722       (((q31_t) s << 8) & 0x0000FF00) | (r & 0x000000FF);
00723 
00724     return sum;
00725 
00726   }
00727 
00728   /*
00729    * @brief C custom defined QSUB8 for M3 and M0 processors
00730    */
00731   static __INLINE q31_t __QSUB8(
00732   q31_t x,
00733   q31_t y)
00734   {
00735 
00736     q31_t sum;
00737     q31_t r, s, t, u;
00738 
00739     r = (q7_t) x;
00740     s = (q7_t) y;
00741 
00742     r = __SSAT((r - s), 8);
00743     s = __SSAT(((q31_t) (((x << 16) >> 24) - ((y << 16) >> 24))), 8) << 8;
00744     t = __SSAT(((q31_t) (((x << 8) >> 24) - ((y << 8) >> 24))), 8) << 16;
00745     u = __SSAT(((q31_t) ((x >> 24) - (y >> 24))), 8) << 24;
00746 
00747     sum =
00748       (u & 0xFF000000) | (t & 0x00FF0000) | (s & 0x0000FF00) | (r &
00749                                                                 0x000000FF);
00750 
00751     return sum;
00752   }
00753 
00754   /*
00755    * @brief C custom defined QADD16 for M3 and M0 processors
00756    */
00757 
00758   /*
00759    * @brief C custom defined QADD16 for M3 and M0 processors
00760    */
00761   static __INLINE q31_t __QADD16(
00762   q31_t x,
00763   q31_t y)
00764   {
00765 
00766     q31_t sum;
00767     q31_t r, s;
00768 
00769     r = (q15_t) x;
00770     s = (q15_t) y;
00771 
00772     r = __SSAT(r + s, 16);
00773     s = __SSAT(((q31_t) ((x >> 16) + (y >> 16))), 16) << 16;
00774 
00775     sum = (s & 0xFFFF0000) | (r & 0x0000FFFF);
00776 
00777     return sum;
00778 
00779   }
00780 
00781   /*
00782    * @brief C custom defined SHADD16 for M3 and M0 processors
00783    */
00784   static __INLINE q31_t __SHADD16(
00785   q31_t x,
00786   q31_t y)
00787   {
00788 
00789     q31_t sum;
00790     q31_t r, s;
00791 
00792     r = (q15_t) x;
00793     s = (q15_t) y;
00794 
00795     r = ((r >> 1) + (s >> 1));
00796     s = ((q31_t) ((x >> 17) + (y >> 17))) << 16;
00797 
00798     sum = (s & 0xFFFF0000) | (r & 0x0000FFFF);
00799 
00800     return sum;
00801 
00802   }
00803 
00804   /*
00805    * @brief C custom defined QSUB16 for M3 and M0 processors
00806    */
00807   static __INLINE q31_t __QSUB16(
00808   q31_t x,
00809   q31_t y)
00810   {
00811 
00812     q31_t sum;
00813     q31_t r, s;
00814 
00815     r = (q15_t) x;
00816     s = (q15_t) y;
00817 
00818     r = __SSAT(r - s, 16);
00819     s = __SSAT(((q31_t) ((x >> 16) - (y >> 16))), 16) << 16;
00820 
00821     sum = (s & 0xFFFF0000) | (r & 0x0000FFFF);
00822 
00823     return sum;
00824   }
00825 
00826   /*
00827    * @brief C custom defined SHSUB16 for M3 and M0 processors
00828    */
00829   static __INLINE q31_t __SHSUB16(
00830   q31_t x,
00831   q31_t y)
00832   {
00833 
00834     q31_t diff;
00835     q31_t r, s;
00836 
00837     r = (q15_t) x;
00838     s = (q15_t) y;
00839 
00840     r = ((r >> 1) - (s >> 1));
00841     s = (((x >> 17) - (y >> 17)) << 16);
00842 
00843     diff = (s & 0xFFFF0000) | (r & 0x0000FFFF);
00844 
00845     return diff;
00846   }
00847 
00848   /*
00849    * @brief C custom defined QASX for M3 and M0 processors
00850    */
00851   static __INLINE q31_t __QASX(
00852   q31_t x,
00853   q31_t y)
00854   {
00855 
00856     q31_t sum = 0;
00857 
00858     sum =
00859       ((sum +
00860         clip_q31_to_q15((q31_t) ((q15_t) (x >> 16) + (q15_t) y))) << 16) +
00861       clip_q31_to_q15((q31_t) ((q15_t) x - (q15_t) (y >> 16)));
00862 
00863     return sum;
00864   }
00865 
00866   /*
00867    * @brief C custom defined SHASX for M3 and M0 processors
00868    */
00869   static __INLINE q31_t __SHASX(
00870   q31_t x,
00871   q31_t y)
00872   {
00873 
00874     q31_t sum;
00875     q31_t r, s;
00876 
00877     r = (q15_t) x;
00878     s = (q15_t) y;
00879 
00880     r = ((r >> 1) - (y >> 17));
00881     s = (((x >> 17) + (s >> 1)) << 16);
00882 
00883     sum = (s & 0xFFFF0000) | (r & 0x0000FFFF);
00884 
00885     return sum;
00886   }
00887 
00888 
00889   /*
00890    * @brief C custom defined QSAX for M3 and M0 processors
00891    */
00892   static __INLINE q31_t __QSAX(
00893   q31_t x,
00894   q31_t y)
00895   {
00896 
00897     q31_t sum = 0;
00898 
00899     sum =
00900       ((sum +
00901         clip_q31_to_q15((q31_t) ((q15_t) (x >> 16) - (q15_t) y))) << 16) +
00902       clip_q31_to_q15((q31_t) ((q15_t) x + (q15_t) (y >> 16)));
00903 
00904     return sum;
00905   }
00906 
00907   /*
00908    * @brief C custom defined SHSAX for M3 and M0 processors
00909    */
00910   static __INLINE q31_t __SHSAX(
00911   q31_t x,
00912   q31_t y)
00913   {
00914 
00915     q31_t sum;
00916     q31_t r, s;
00917 
00918     r = (q15_t) x;
00919     s = (q15_t) y;
00920 
00921     r = ((r >> 1) + (y >> 17));
00922     s = (((x >> 17) - (s >> 1)) << 16);
00923 
00924     sum = (s & 0xFFFF0000) | (r & 0x0000FFFF);
00925 
00926     return sum;
00927   }
00928 
00929   /*
00930    * @brief C custom defined SMUSDX for M3 and M0 processors
00931    */
00932   static __INLINE q31_t __SMUSDX(
00933   q31_t x,
00934   q31_t y)
00935   {
00936 
00937     return ((q31_t) (((q15_t) x * (q15_t) (y >> 16)) -
00938                      ((q15_t) (x >> 16) * (q15_t) y)));
00939   }
00940 
00941   /*
00942    * @brief C custom defined SMUADX for M3 and M0 processors
00943    */
00944   static __INLINE q31_t __SMUADX(
00945   q31_t x,
00946   q31_t y)
00947   {
00948 
00949     return ((q31_t) (((q15_t) x * (q15_t) (y >> 16)) +
00950                      ((q15_t) (x >> 16) * (q15_t) y)));
00951   }
00952 
00953   /*
00954    * @brief C custom defined QADD for M3 and M0 processors
00955    */
00956   static __INLINE q31_t __QADD(
00957   q31_t x,
00958   q31_t y)
00959   {
00960     return clip_q63_to_q31((q63_t) x + y);
00961   }
00962 
00963   /*
00964    * @brief C custom defined QSUB for M3 and M0 processors
00965    */
00966   static __INLINE q31_t __QSUB(
00967   q31_t x,
00968   q31_t y)
00969   {
00970     return clip_q63_to_q31((q63_t) x - y);
00971   }
00972 
00973   /*
00974    * @brief C custom defined SMLAD for M3 and M0 processors
00975    */
00976   static __INLINE q31_t __SMLAD(
00977   q31_t x,
00978   q31_t y,
00979   q31_t sum)
00980   {
00981 
00982     return (sum + ((q15_t) (x >> 16) * (q15_t) (y >> 16)) +
00983             ((q15_t) x * (q15_t) y));
00984   }
00985 
00986   /*
00987    * @brief C custom defined SMLADX for M3 and M0 processors
00988    */
00989   static __INLINE q31_t __SMLADX(
00990   q31_t x,
00991   q31_t y,
00992   q31_t sum)
00993   {
00994 
00995     return (sum + ((q15_t) (x >> 16) * (q15_t) (y)) +
00996             ((q15_t) x * (q15_t) (y >> 16)));
00997   }
00998 
00999   /*
01000    * @brief C custom defined SMLSDX for M3 and M0 processors
01001    */
01002   static __INLINE q31_t __SMLSDX(
01003   q31_t x,
01004   q31_t y,
01005   q31_t sum)
01006   {
01007 
01008     return (sum - ((q15_t) (x >> 16) * (q15_t) (y)) +
01009             ((q15_t) x * (q15_t) (y >> 16)));
01010   }
01011 
01012   /*
01013    * @brief C custom defined SMLALD for M3 and M0 processors
01014    */
01015   static __INLINE q63_t __SMLALD(
01016   q31_t x,
01017   q31_t y,
01018   q63_t sum)
01019   {
01020 
01021     return (sum + ((q15_t) (x >> 16) * (q15_t) (y >> 16)) +
01022             ((q15_t) x * (q15_t) y));
01023   }
01024 
01025   /*
01026    * @brief C custom defined SMLALDX for M3 and M0 processors
01027    */
01028   static __INLINE q63_t __SMLALDX(
01029   q31_t x,
01030   q31_t y,
01031   q63_t sum)
01032   {
01033 
01034     return (sum + ((q15_t) (x >> 16) * (q15_t) y)) +
01035       ((q15_t) x * (q15_t) (y >> 16));
01036   }
01037 
01038   /*
01039    * @brief C custom defined SMUAD for M3 and M0 processors
01040    */
01041   static __INLINE q31_t __SMUAD(
01042   q31_t x,
01043   q31_t y)
01044   {
01045 
01046     return (((x >> 16) * (y >> 16)) +
01047             (((x << 16) >> 16) * ((y << 16) >> 16)));
01048   }
01049 
01050   /*
01051    * @brief C custom defined SMUSD for M3 and M0 processors
01052    */
01053   static __INLINE q31_t __SMUSD(
01054   q31_t x,
01055   q31_t y)
01056   {
01057 
01058     return (-((x >> 16) * (y >> 16)) +
01059             (((x << 16) >> 16) * ((y << 16) >> 16)));
01060   }
01061 
01062 
01063   /*
01064    * @brief C custom defined SXTB16 for M3 and M0 processors
01065    */
01066   static __INLINE q31_t __SXTB16(
01067   q31_t x)
01068   {
01069 
01070     return ((((x << 24) >> 24) & 0x0000FFFF) |
01071             (((x << 8) >> 8) & 0xFFFF0000));
01072   }
01073 
01074 
01075 #endif /* defined (ARM_MATH_CM3) || defined (ARM_MATH_CM0_FAMILY) */
01076 
01077 
01078   /**
01079    * @brief Instance structure for the Q7 FIR filter.
01080    */
01081   typedef struct
01082   {
01083     uint16_t numTaps;        /**< number of filter coefficients in the filter. */
01084     q7_t *pState;            /**< points to the state variable array. The array is of length numTaps+blockSize-1. */
01085     q7_t *pCoeffs;           /**< points to the coefficient array. The array is of length numTaps.*/
01086   } arm_fir_instance_q7;
01087 
01088   /**
01089    * @brief Instance structure for the Q15 FIR filter.
01090    */
01091   typedef struct
01092   {
01093     uint16_t numTaps;         /**< number of filter coefficients in the filter. */
01094     q15_t *pState;            /**< points to the state variable array. The array is of length numTaps+blockSize-1. */
01095     q15_t *pCoeffs;           /**< points to the coefficient array. The array is of length numTaps.*/
01096   } arm_fir_instance_q15;
01097 
01098   /**
01099    * @brief Instance structure for the Q31 FIR filter.
01100    */
01101   typedef struct
01102   {
01103     uint16_t numTaps;         /**< number of filter coefficients in the filter. */
01104     q31_t *pState;            /**< points to the state variable array. The array is of length numTaps+blockSize-1. */
01105     q31_t *pCoeffs;           /**< points to the coefficient array. The array is of length numTaps. */
01106   } arm_fir_instance_q31;
01107 
01108   /**
01109    * @brief Instance structure for the floating-point FIR filter.
01110    */
01111   typedef struct
01112   {
01113     uint16_t numTaps;     /**< number of filter coefficients in the filter. */
01114     float32_t *pState;    /**< points to the state variable array. The array is of length numTaps+blockSize-1. */
01115     float32_t *pCoeffs;   /**< points to the coefficient array. The array is of length numTaps. */
01116   } arm_fir_instance_f32;
01117 
01118 
01119   /**
01120    * @brief Processing function for the Q7 FIR filter.
01121    * @param[in] *S points to an instance of the Q7 FIR filter structure.
01122    * @param[in] *pSrc points to the block of input data.
01123    * @param[out] *pDst points to the block of output data.
01124    * @param[in] blockSize number of samples to process.
01125    * @return none.
01126    */
01127   void arm_fir_q7(
01128   const arm_fir_instance_q7 * S,
01129   q7_t * pSrc,
01130   q7_t * pDst,
01131   uint32_t blockSize);
01132 
01133 
01134   /**
01135    * @brief  Initialization function for the Q7 FIR filter.
01136    * @param[in,out] *S points to an instance of the Q7 FIR structure.
01137    * @param[in] numTaps  Number of filter coefficients in the filter.
01138    * @param[in] *pCoeffs points to the filter coefficients.
01139    * @param[in] *pState points to the state buffer.
01140    * @param[in] blockSize number of samples that are processed.
01141    * @return none
01142    */
01143   void arm_fir_init_q7(
01144   arm_fir_instance_q7 * S,
01145   uint16_t numTaps,
01146   q7_t * pCoeffs,
01147   q7_t * pState,
01148   uint32_t blockSize);
01149 
01150 
01151   /**
01152    * @brief Processing function for the Q15 FIR filter.
01153    * @param[in] *S points to an instance of the Q15 FIR structure.
01154    * @param[in] *pSrc points to the block of input data.
01155    * @param[out] *pDst points to the block of output data.
01156    * @param[in] blockSize number of samples to process.
01157    * @return none.
01158    */
01159   void arm_fir_q15(
01160   const arm_fir_instance_q15 * S,
01161   q15_t * pSrc,
01162   q15_t * pDst,
01163   uint32_t blockSize);
01164 
01165   /**
01166    * @brief Processing function for the fast Q15 FIR filter for Cortex-M3 and Cortex-M4.
01167    * @param[in] *S points to an instance of the Q15 FIR filter structure.
01168    * @param[in] *pSrc points to the block of input data.
01169    * @param[out] *pDst points to the block of output data.
01170    * @param[in] blockSize number of samples to process.
01171    * @return none.
01172    */
01173   void arm_fir_fast_q15(
01174   const arm_fir_instance_q15 * S,
01175   q15_t * pSrc,
01176   q15_t * pDst,
01177   uint32_t blockSize);
01178 
01179   /**
01180    * @brief  Initialization function for the Q15 FIR filter.
01181    * @param[in,out] *S points to an instance of the Q15 FIR filter structure.
01182    * @param[in] numTaps  Number of filter coefficients in the filter. Must be even and greater than or equal to 4.
01183    * @param[in] *pCoeffs points to the filter coefficients.
01184    * @param[in] *pState points to the state buffer.
01185    * @param[in] blockSize number of samples that are processed at a time.
01186    * @return The function returns ARM_MATH_SUCCESS if initialization was successful or ARM_MATH_ARGUMENT_ERROR if
01187    * <code>numTaps</code> is not a supported value.
01188    */
01189 
01190   arm_status arm_fir_init_q15(
01191   arm_fir_instance_q15 * S,
01192   uint16_t numTaps,
01193   q15_t * pCoeffs,
01194   q15_t * pState,
01195   uint32_t blockSize);
01196 
01197   /**
01198    * @brief Processing function for the Q31 FIR filter.
01199    * @param[in] *S points to an instance of the Q31 FIR filter structure.
01200    * @param[in] *pSrc points to the block of input data.
01201    * @param[out] *pDst points to the block of output data.
01202    * @param[in] blockSize number of samples to process.
01203    * @return none.
01204    */
01205   void arm_fir_q31(
01206   const arm_fir_instance_q31 * S,
01207   q31_t * pSrc,
01208   q31_t * pDst,
01209   uint32_t blockSize);
01210 
01211   /**
01212    * @brief Processing function for the fast Q31 FIR filter for Cortex-M3 and Cortex-M4.
01213    * @param[in] *S points to an instance of the Q31 FIR structure.
01214    * @param[in] *pSrc points to the block of input data.
01215    * @param[out] *pDst points to the block of output data.
01216    * @param[in] blockSize number of samples to process.
01217    * @return none.
01218    */
01219   void arm_fir_fast_q31(
01220   const arm_fir_instance_q31 * S,
01221   q31_t * pSrc,
01222   q31_t * pDst,
01223   uint32_t blockSize);
01224 
01225   /**
01226    * @brief  Initialization function for the Q31 FIR filter.
01227    * @param[in,out] *S points to an instance of the Q31 FIR structure.
01228    * @param[in]     numTaps  Number of filter coefficients in the filter.
01229    * @param[in]     *pCoeffs points to the filter coefficients.
01230    * @param[in]     *pState points to the state buffer.
01231    * @param[in]     blockSize number of samples that are processed at a time.
01232    * @return        none.
01233    */
01234   void arm_fir_init_q31(
01235   arm_fir_instance_q31 * S,
01236   uint16_t numTaps,
01237   q31_t * pCoeffs,
01238   q31_t * pState,
01239   uint32_t blockSize);
01240 
01241   /**
01242    * @brief Processing function for the floating-point FIR filter.
01243    * @param[in] *S points to an instance of the floating-point FIR structure.
01244    * @param[in] *pSrc points to the block of input data.
01245    * @param[out] *pDst points to the block of output data.
01246    * @param[in] blockSize number of samples to process.
01247    * @return none.
01248    */
01249   void arm_fir_f32(
01250   const arm_fir_instance_f32 * S,
01251   float32_t * pSrc,
01252   float32_t * pDst,
01253   uint32_t blockSize);
01254 
01255   /**
01256    * @brief  Initialization function for the floating-point FIR filter.
01257    * @param[in,out] *S points to an instance of the floating-point FIR filter structure.
01258    * @param[in]     numTaps  Number of filter coefficients in the filter.
01259    * @param[in]     *pCoeffs points to the filter coefficients.
01260    * @param[in]     *pState points to the state buffer.
01261    * @param[in]     blockSize number of samples that are processed at a time.
01262    * @return        none.
01263    */
01264   void arm_fir_init_f32(
01265   arm_fir_instance_f32 * S,
01266   uint16_t numTaps,
01267   float32_t * pCoeffs,
01268   float32_t * pState,
01269   uint32_t blockSize);
01270 
01271 
01272   /**
01273    * @brief Instance structure for the Q15 Biquad cascade filter.
01274    */
01275   typedef struct
01276   {
01277     int8_t numStages;         /**< number of 2nd order stages in the filter.  Overall order is 2*numStages. */
01278     q15_t *pState;            /**< Points to the array of state coefficients.  The array is of length 4*numStages. */
01279     q15_t *pCoeffs;           /**< Points to the array of coefficients.  The array is of length 5*numStages. */
01280     int8_t postShift;         /**< Additional shift, in bits, applied to each output sample. */
01281 
01282   } arm_biquad_casd_df1_inst_q15;
01283 
01284 
01285   /**
01286    * @brief Instance structure for the Q31 Biquad cascade filter.
01287    */
01288   typedef struct
01289   {
01290     uint32_t numStages;      /**< number of 2nd order stages in the filter.  Overall order is 2*numStages. */
01291     q31_t *pState;           /**< Points to the array of state coefficients.  The array is of length 4*numStages. */
01292     q31_t *pCoeffs;          /**< Points to the array of coefficients.  The array is of length 5*numStages. */
01293     uint8_t postShift;       /**< Additional shift, in bits, applied to each output sample. */
01294 
01295   } arm_biquad_casd_df1_inst_q31;
01296 
01297   /**
01298    * @brief Instance structure for the floating-point Biquad cascade filter.
01299    */
01300   typedef struct
01301   {
01302     uint32_t numStages;         /**< number of 2nd order stages in the filter.  Overall order is 2*numStages. */
01303     float32_t *pState;          /**< Points to the array of state coefficients.  The array is of length 4*numStages. */
01304     float32_t *pCoeffs;         /**< Points to the array of coefficients.  The array is of length 5*numStages. */
01305 
01306 
01307   } arm_biquad_casd_df1_inst_f32;
01308 
01309 
01310 
01311   /**
01312    * @brief Processing function for the Q15 Biquad cascade filter.
01313    * @param[in]  *S points to an instance of the Q15 Biquad cascade structure.
01314    * @param[in]  *pSrc points to the block of input data.
01315    * @param[out] *pDst points to the block of output data.
01316    * @param[in]  blockSize number of samples to process.
01317    * @return     none.
01318    */
01319 
01320   void arm_biquad_cascade_df1_q15(
01321   const arm_biquad_casd_df1_inst_q15 * S,
01322   q15_t * pSrc,
01323   q15_t * pDst,
01324   uint32_t blockSize);
01325 
01326   /**
01327    * @brief  Initialization function for the Q15 Biquad cascade filter.
01328    * @param[in,out] *S           points to an instance of the Q15 Biquad cascade structure.
01329    * @param[in]     numStages    number of 2nd order stages in the filter.
01330    * @param[in]     *pCoeffs     points to the filter coefficients.
01331    * @param[in]     *pState      points to the state buffer.
01332    * @param[in]     postShift    Shift to be applied to the output. Varies according to the coefficients format
01333    * @return        none
01334    */
01335 
01336   void arm_biquad_cascade_df1_init_q15(
01337   arm_biquad_casd_df1_inst_q15 * S,
01338   uint8_t numStages,
01339   q15_t * pCoeffs,
01340   q15_t * pState,
01341   int8_t postShift);
01342 
01343 
01344   /**
01345    * @brief Fast but less precise processing function for the Q15 Biquad cascade filter for Cortex-M3 and Cortex-M4.
01346    * @param[in]  *S points to an instance of the Q15 Biquad cascade structure.
01347    * @param[in]  *pSrc points to the block of input data.
01348    * @param[out] *pDst points to the block of output data.
01349    * @param[in]  blockSize number of samples to process.
01350    * @return     none.
01351    */
01352 
01353   void arm_biquad_cascade_df1_fast_q15(
01354   const arm_biquad_casd_df1_inst_q15 * S,
01355   q15_t * pSrc,
01356   q15_t * pDst,
01357   uint32_t blockSize);
01358 
01359 
01360   /**
01361    * @brief Processing function for the Q31 Biquad cascade filter
01362    * @param[in]  *S         points to an instance of the Q31 Biquad cascade structure.
01363    * @param[in]  *pSrc      points to the block of input data.
01364    * @param[out] *pDst      points to the block of output data.
01365    * @param[in]  blockSize  number of samples to process.
01366    * @return     none.
01367    */
01368 
01369   void arm_biquad_cascade_df1_q31(
01370   const arm_biquad_casd_df1_inst_q31 * S,
01371   q31_t * pSrc,
01372   q31_t * pDst,
01373   uint32_t blockSize);
01374 
01375   /**
01376    * @brief Fast but less precise processing function for the Q31 Biquad cascade filter for Cortex-M3 and Cortex-M4.
01377    * @param[in]  *S         points to an instance of the Q31 Biquad cascade structure.
01378    * @param[in]  *pSrc      points to the block of input data.
01379    * @param[out] *pDst      points to the block of output data.
01380    * @param[in]  blockSize  number of samples to process.
01381    * @return     none.
01382    */
01383 
01384   void arm_biquad_cascade_df1_fast_q31(
01385   const arm_biquad_casd_df1_inst_q31 * S,
01386   q31_t * pSrc,
01387   q31_t * pDst,
01388   uint32_t blockSize);
01389 
01390   /**
01391    * @brief  Initialization function for the Q31 Biquad cascade filter.
01392    * @param[in,out] *S           points to an instance of the Q31 Biquad cascade structure.
01393    * @param[in]     numStages      number of 2nd order stages in the filter.
01394    * @param[in]     *pCoeffs     points to the filter coefficients.
01395    * @param[in]     *pState      points to the state buffer.
01396    * @param[in]     postShift    Shift to be applied to the output. Varies according to the coefficients format
01397    * @return        none
01398    */
01399 
01400   void arm_biquad_cascade_df1_init_q31(
01401   arm_biquad_casd_df1_inst_q31 * S,
01402   uint8_t numStages,
01403   q31_t * pCoeffs,
01404   q31_t * pState,
01405   int8_t postShift);
01406 
01407   /**
01408    * @brief Processing function for the floating-point Biquad cascade filter.
01409    * @param[in]  *S         points to an instance of the floating-point Biquad cascade structure.
01410    * @param[in]  *pSrc      points to the block of input data.
01411    * @param[out] *pDst      points to the block of output data.
01412    * @param[in]  blockSize  number of samples to process.
01413    * @return     none.
01414    */
01415 
01416   void arm_biquad_cascade_df1_f32(
01417   const arm_biquad_casd_df1_inst_f32 * S,
01418   float32_t * pSrc,
01419   float32_t * pDst,
01420   uint32_t blockSize);
01421 
01422   /**
01423    * @brief  Initialization function for the floating-point Biquad cascade filter.
01424    * @param[in,out] *S           points to an instance of the floating-point Biquad cascade structure.
01425    * @param[in]     numStages    number of 2nd order stages in the filter.
01426    * @param[in]     *pCoeffs     points to the filter coefficients.
01427    * @param[in]     *pState      points to the state buffer.
01428    * @return        none
01429    */
01430 
01431   void arm_biquad_cascade_df1_init_f32(
01432   arm_biquad_casd_df1_inst_f32 * S,
01433   uint8_t numStages,
01434   float32_t * pCoeffs,
01435   float32_t * pState);
01436 
01437 
01438   /**
01439    * @brief Instance structure for the floating-point matrix structure.
01440    */
01441 
01442   typedef struct
01443   {
01444     uint16_t numRows;     /**< number of rows of the matrix.     */
01445     uint16_t numCols;     /**< number of columns of the matrix.  */
01446     float32_t *pData;     /**< points to the data of the matrix. */
01447   } arm_matrix_instance_f32;
01448 
01449 
01450   /**
01451    * @brief Instance structure for the floating-point matrix structure.
01452    */
01453 
01454   typedef struct
01455   {
01456     uint16_t numRows;     /**< number of rows of the matrix.     */
01457     uint16_t numCols;     /**< number of columns of the matrix.  */
01458     float64_t *pData;     /**< points to the data of the matrix. */
01459   } arm_matrix_instance_f64;
01460 
01461   /**
01462    * @brief Instance structure for the Q15 matrix structure.
01463    */
01464 
01465   typedef struct
01466   {
01467     uint16_t numRows;     /**< number of rows of the matrix.     */
01468     uint16_t numCols;     /**< number of columns of the matrix.  */
01469     q15_t *pData;         /**< points to the data of the matrix. */
01470 
01471   } arm_matrix_instance_q15;
01472 
01473   /**
01474    * @brief Instance structure for the Q31 matrix structure.
01475    */
01476 
01477   typedef struct
01478   {
01479     uint16_t numRows;     /**< number of rows of the matrix.     */
01480     uint16_t numCols;     /**< number of columns of the matrix.  */
01481     q31_t *pData;         /**< points to the data of the matrix. */
01482 
01483   } arm_matrix_instance_q31;
01484 
01485 
01486 
01487   /**
01488    * @brief Floating-point matrix addition.
01489    * @param[in]       *pSrcA points to the first input matrix structure
01490    * @param[in]       *pSrcB points to the second input matrix structure
01491    * @param[out]      *pDst points to output matrix structure
01492    * @return     The function returns either
01493    * <code>ARM_MATH_SIZE_MISMATCH</code> or <code>ARM_MATH_SUCCESS</code> based on the outcome of size checking.
01494    */
01495 
01496   arm_status arm_mat_add_f32(
01497   const arm_matrix_instance_f32 * pSrcA,
01498   const arm_matrix_instance_f32 * pSrcB,
01499   arm_matrix_instance_f32 * pDst);
01500 
01501   /**
01502    * @brief Q15 matrix addition.
01503    * @param[in]       *pSrcA points to the first input matrix structure
01504    * @param[in]       *pSrcB points to the second input matrix structure
01505    * @param[out]      *pDst points to output matrix structure
01506    * @return     The function returns either
01507    * <code>ARM_MATH_SIZE_MISMATCH</code> or <code>ARM_MATH_SUCCESS</code> based on the outcome of size checking.
01508    */
01509 
01510   arm_status arm_mat_add_q15(
01511   const arm_matrix_instance_q15 * pSrcA,
01512   const arm_matrix_instance_q15 * pSrcB,
01513   arm_matrix_instance_q15 * pDst);
01514 
01515   /**
01516    * @brief Q31 matrix addition.
01517    * @param[in]       *pSrcA points to the first input matrix structure
01518    * @param[in]       *pSrcB points to the second input matrix structure
01519    * @param[out]      *pDst points to output matrix structure
01520    * @return     The function returns either
01521    * <code>ARM_MATH_SIZE_MISMATCH</code> or <code>ARM_MATH_SUCCESS</code> based on the outcome of size checking.
01522    */
01523 
01524   arm_status arm_mat_add_q31(
01525   const arm_matrix_instance_q31 * pSrcA,
01526   const arm_matrix_instance_q31 * pSrcB,
01527   arm_matrix_instance_q31 * pDst);
01528 
01529   /**
01530    * @brief Floating-point, complex, matrix multiplication.
01531    * @param[in]       *pSrcA points to the first input matrix structure
01532    * @param[in]       *pSrcB points to the second input matrix structure
01533    * @param[out]      *pDst points to output matrix structure
01534    * @return     The function returns either
01535    * <code>ARM_MATH_SIZE_MISMATCH</code> or <code>ARM_MATH_SUCCESS</code> based on the outcome of size checking.
01536    */
01537 
01538   arm_status arm_mat_cmplx_mult_f32(
01539   const arm_matrix_instance_f32 * pSrcA,
01540   const arm_matrix_instance_f32 * pSrcB,
01541   arm_matrix_instance_f32 * pDst);
01542 
01543   /**
01544    * @brief Q15, complex,  matrix multiplication.
01545    * @param[in]       *pSrcA points to the first input matrix structure
01546    * @param[in]       *pSrcB points to the second input matrix structure
01547    * @param[out]      *pDst points to output matrix structure
01548    * @return     The function returns either
01549    * <code>ARM_MATH_SIZE_MISMATCH</code> or <code>ARM_MATH_SUCCESS</code> based on the outcome of size checking.
01550    */
01551 
01552   arm_status arm_mat_cmplx_mult_q15(
01553   const arm_matrix_instance_q15 * pSrcA,
01554   const arm_matrix_instance_q15 * pSrcB,
01555   arm_matrix_instance_q15 * pDst,
01556   q15_t * pScratch);
01557 
01558   /**
01559    * @brief Q31, complex, matrix multiplication.
01560    * @param[in]       *pSrcA points to the first input matrix structure
01561    * @param[in]       *pSrcB points to the second input matrix structure
01562    * @param[out]      *pDst points to output matrix structure
01563    * @return     The function returns either
01564    * <code>ARM_MATH_SIZE_MISMATCH</code> or <code>ARM_MATH_SUCCESS</code> based on the outcome of size checking.
01565    */
01566 
01567   arm_status arm_mat_cmplx_mult_q31(
01568   const arm_matrix_instance_q31 * pSrcA,
01569   const arm_matrix_instance_q31 * pSrcB,
01570   arm_matrix_instance_q31 * pDst);
01571 
01572 
01573   /**
01574    * @brief Floating-point matrix transpose.
01575    * @param[in]  *pSrc points to the input matrix
01576    * @param[out] *pDst points to the output matrix
01577    * @return    The function returns either  <code>ARM_MATH_SIZE_MISMATCH</code>
01578    * or <code>ARM_MATH_SUCCESS</code> based on the outcome of size checking.
01579    */
01580 
01581   arm_status arm_mat_trans_f32(
01582   const arm_matrix_instance_f32 * pSrc,
01583   arm_matrix_instance_f32 * pDst);
01584 
01585 
01586   /**
01587    * @brief Q15 matrix transpose.
01588    * @param[in]  *pSrc points to the input matrix
01589    * @param[out] *pDst points to the output matrix
01590    * @return    The function returns either  <code>ARM_MATH_SIZE_MISMATCH</code>
01591    * or <code>ARM_MATH_SUCCESS</code> based on the outcome of size checking.
01592    */
01593 
01594   arm_status arm_mat_trans_q15(
01595   const arm_matrix_instance_q15 * pSrc,
01596   arm_matrix_instance_q15 * pDst);
01597 
01598   /**
01599    * @brief Q31 matrix transpose.
01600    * @param[in]  *pSrc points to the input matrix
01601    * @param[out] *pDst points to the output matrix
01602    * @return    The function returns either  <code>ARM_MATH_SIZE_MISMATCH</code>
01603    * or <code>ARM_MATH_SUCCESS</code> based on the outcome of size checking.
01604    */
01605 
01606   arm_status arm_mat_trans_q31(
01607   const arm_matrix_instance_q31 * pSrc,
01608   arm_matrix_instance_q31 * pDst);
01609 
01610 
01611   /**
01612    * @brief Floating-point matrix multiplication
01613    * @param[in]       *pSrcA points to the first input matrix structure
01614    * @param[in]       *pSrcB points to the second input matrix structure
01615    * @param[out]      *pDst points to output matrix structure
01616    * @return     The function returns either
01617    * <code>ARM_MATH_SIZE_MISMATCH</code> or <code>ARM_MATH_SUCCESS</code> based on the outcome of size checking.
01618    */
01619 
01620   arm_status arm_mat_mult_f32(
01621   const arm_matrix_instance_f32 * pSrcA,
01622   const arm_matrix_instance_f32 * pSrcB,
01623   arm_matrix_instance_f32 * pDst);
01624 
01625   /**
01626    * @brief Q15 matrix multiplication
01627    * @param[in]       *pSrcA points to the first input matrix structure
01628    * @param[in]       *pSrcB points to the second input matrix structure
01629    * @param[out]      *pDst points to output matrix structure
01630    * @param[in]      *pState points to the array for storing intermediate results
01631    * @return     The function returns either
01632    * <code>ARM_MATH_SIZE_MISMATCH</code> or <code>ARM_MATH_SUCCESS</code> based on the outcome of size checking.
01633    */
01634 
01635   arm_status arm_mat_mult_q15(
01636   const arm_matrix_instance_q15 * pSrcA,
01637   const arm_matrix_instance_q15 * pSrcB,
01638   arm_matrix_instance_q15 * pDst,
01639   q15_t * pState);
01640 
01641   /**
01642    * @brief Q15 matrix multiplication (fast variant) for Cortex-M3 and Cortex-M4
01643    * @param[in]       *pSrcA  points to the first input matrix structure
01644    * @param[in]       *pSrcB  points to the second input matrix structure
01645    * @param[out]      *pDst   points to output matrix structure
01646    * @param[in]       *pState points to the array for storing intermediate results
01647    * @return     The function returns either
01648    * <code>ARM_MATH_SIZE_MISMATCH</code> or <code>ARM_MATH_SUCCESS</code> based on the outcome of size checking.
01649    */
01650 
01651   arm_status arm_mat_mult_fast_q15(
01652   const arm_matrix_instance_q15 * pSrcA,
01653   const arm_matrix_instance_q15 * pSrcB,
01654   arm_matrix_instance_q15 * pDst,
01655   q15_t * pState);
01656 
01657   /**
01658    * @brief Q31 matrix multiplication
01659    * @param[in]       *pSrcA points to the first input matrix structure
01660    * @param[in]       *pSrcB points to the second input matrix structure
01661    * @param[out]      *pDst points to output matrix structure
01662    * @return     The function returns either
01663    * <code>ARM_MATH_SIZE_MISMATCH</code> or <code>ARM_MATH_SUCCESS</code> based on the outcome of size checking.
01664    */
01665 
01666   arm_status arm_mat_mult_q31(
01667   const arm_matrix_instance_q31 * pSrcA,
01668   const arm_matrix_instance_q31 * pSrcB,
01669   arm_matrix_instance_q31 * pDst);
01670 
01671   /**
01672    * @brief Q31 matrix multiplication (fast variant) for Cortex-M3 and Cortex-M4
01673    * @param[in]       *pSrcA points to the first input matrix structure
01674    * @param[in]       *pSrcB points to the second input matrix structure
01675    * @param[out]      *pDst points to output matrix structure
01676    * @return     The function returns either
01677    * <code>ARM_MATH_SIZE_MISMATCH</code> or <code>ARM_MATH_SUCCESS</code> based on the outcome of size checking.
01678    */
01679 
01680   arm_status arm_mat_mult_fast_q31(
01681   const arm_matrix_instance_q31 * pSrcA,
01682   const arm_matrix_instance_q31 * pSrcB,
01683   arm_matrix_instance_q31 * pDst);
01684 
01685 
01686   /**
01687    * @brief Floating-point matrix subtraction
01688    * @param[in]       *pSrcA points to the first input matrix structure
01689    * @param[in]       *pSrcB points to the second input matrix structure
01690    * @param[out]      *pDst points to output matrix structure
01691    * @return     The function returns either
01692    * <code>ARM_MATH_SIZE_MISMATCH</code> or <code>ARM_MATH_SUCCESS</code> based on the outcome of size checking.
01693    */
01694 
01695   arm_status arm_mat_sub_f32(
01696   const arm_matrix_instance_f32 * pSrcA,
01697   const arm_matrix_instance_f32 * pSrcB,
01698   arm_matrix_instance_f32 * pDst);
01699 
01700   /**
01701    * @brief Q15 matrix subtraction
01702    * @param[in]       *pSrcA points to the first input matrix structure
01703    * @param[in]       *pSrcB points to the second input matrix structure
01704    * @param[out]      *pDst points to output matrix structure
01705    * @return     The function returns either
01706    * <code>ARM_MATH_SIZE_MISMATCH</code> or <code>ARM_MATH_SUCCESS</code> based on the outcome of size checking.
01707    */
01708 
01709   arm_status arm_mat_sub_q15(
01710   const arm_matrix_instance_q15 * pSrcA,
01711   const arm_matrix_instance_q15 * pSrcB,
01712   arm_matrix_instance_q15 * pDst);
01713 
01714   /**
01715    * @brief Q31 matrix subtraction
01716    * @param[in]       *pSrcA points to the first input matrix structure
01717    * @param[in]       *pSrcB points to the second input matrix structure
01718    * @param[out]      *pDst points to output matrix structure
01719    * @return     The function returns either
01720    * <code>ARM_MATH_SIZE_MISMATCH</code> or <code>ARM_MATH_SUCCESS</code> based on the outcome of size checking.
01721    */
01722 
01723   arm_status arm_mat_sub_q31(
01724   const arm_matrix_instance_q31 * pSrcA,
01725   const arm_matrix_instance_q31 * pSrcB,
01726   arm_matrix_instance_q31 * pDst);
01727 
01728   /**
01729    * @brief Floating-point matrix scaling.
01730    * @param[in]  *pSrc points to the input matrix
01731    * @param[in]  scale scale factor
01732    * @param[out] *pDst points to the output matrix
01733    * @return     The function returns either
01734    * <code>ARM_MATH_SIZE_MISMATCH</code> or <code>ARM_MATH_SUCCESS</code> based on the outcome of size checking.
01735    */
01736 
01737   arm_status arm_mat_scale_f32(
01738   const arm_matrix_instance_f32 * pSrc,
01739   float32_t scale,
01740   arm_matrix_instance_f32 * pDst);
01741 
01742   /**
01743    * @brief Q15 matrix scaling.
01744    * @param[in]       *pSrc points to input matrix
01745    * @param[in]       scaleFract fractional portion of the scale factor
01746    * @param[in]       shift number of bits to shift the result by
01747    * @param[out]      *pDst points to output matrix
01748    * @return     The function returns either
01749    * <code>ARM_MATH_SIZE_MISMATCH</code> or <code>ARM_MATH_SUCCESS</code> based on the outcome of size checking.
01750    */
01751 
01752   arm_status arm_mat_scale_q15(
01753   const arm_matrix_instance_q15 * pSrc,
01754   q15_t scaleFract,
01755   int32_t shift,
01756   arm_matrix_instance_q15 * pDst);
01757 
01758   /**
01759    * @brief Q31 matrix scaling.
01760    * @param[in]       *pSrc points to input matrix
01761    * @param[in]       scaleFract fractional portion of the scale factor
01762    * @param[in]       shift number of bits to shift the result by
01763    * @param[out]      *pDst points to output matrix structure
01764    * @return     The function returns either
01765    * <code>ARM_MATH_SIZE_MISMATCH</code> or <code>ARM_MATH_SUCCESS</code> based on the outcome of size checking.
01766    */
01767 
01768   arm_status arm_mat_scale_q31(
01769   const arm_matrix_instance_q31 * pSrc,
01770   q31_t scaleFract,
01771   int32_t shift,
01772   arm_matrix_instance_q31 * pDst);
01773 
01774 
01775   /**
01776    * @brief  Q31 matrix initialization.
01777    * @param[in,out] *S             points to an instance of the floating-point matrix structure.
01778    * @param[in]     nRows          number of rows in the matrix.
01779    * @param[in]     nColumns       number of columns in the matrix.
01780    * @param[in]     *pData         points to the matrix data array.
01781    * @return        none
01782    */
01783 
01784   void arm_mat_init_q31(
01785   arm_matrix_instance_q31 * S,
01786   uint16_t nRows,
01787   uint16_t nColumns,
01788   q31_t * pData);
01789 
01790   /**
01791    * @brief  Q15 matrix initialization.
01792    * @param[in,out] *S             points to an instance of the floating-point matrix structure.
01793    * @param[in]     nRows          number of rows in the matrix.
01794    * @param[in]     nColumns       number of columns in the matrix.
01795    * @param[in]     *pData         points to the matrix data array.
01796    * @return        none
01797    */
01798 
01799   void arm_mat_init_q15(
01800   arm_matrix_instance_q15 * S,
01801   uint16_t nRows,
01802   uint16_t nColumns,
01803   q15_t * pData);
01804 
01805   /**
01806    * @brief  Floating-point matrix initialization.
01807    * @param[in,out] *S             points to an instance of the floating-point matrix structure.
01808    * @param[in]     nRows          number of rows in the matrix.
01809    * @param[in]     nColumns       number of columns in the matrix.
01810    * @param[in]     *pData         points to the matrix data array.
01811    * @return        none
01812    */
01813 
01814   void arm_mat_init_f32(
01815   arm_matrix_instance_f32 * S,
01816   uint16_t nRows,
01817   uint16_t nColumns,
01818   float32_t * pData);
01819 
01820 
01821 
01822   /**
01823    * @brief Instance structure for the Q15 PID Control.
01824    */
01825   typedef struct
01826   {
01827     q15_t A0;    /**< The derived gain, A0 = Kp + Ki + Kd . */
01828 #ifdef ARM_MATH_CM0_FAMILY
01829     q15_t A1;
01830     q15_t A2;
01831 #else
01832     q31_t A1;           /**< The derived gain A1 = -Kp - 2Kd | Kd.*/
01833 #endif
01834     q15_t state[3];       /**< The state array of length 3. */
01835     q15_t Kp;           /**< The proportional gain. */
01836     q15_t Ki;           /**< The integral gain. */
01837     q15_t Kd;           /**< The derivative gain. */
01838   } arm_pid_instance_q15;
01839 
01840   /**
01841    * @brief Instance structure for the Q31 PID Control.
01842    */
01843   typedef struct
01844   {
01845     q31_t A0;            /**< The derived gain, A0 = Kp + Ki + Kd . */
01846     q31_t A1;            /**< The derived gain, A1 = -Kp - 2Kd. */
01847     q31_t A2;            /**< The derived gain, A2 = Kd . */
01848     q31_t state[3];      /**< The state array of length 3. */
01849     q31_t Kp;            /**< The proportional gain. */
01850     q31_t Ki;            /**< The integral gain. */
01851     q31_t Kd;            /**< The derivative gain. */
01852 
01853   } arm_pid_instance_q31;
01854 
01855   /**
01856    * @brief Instance structure for the floating-point PID Control.
01857    */
01858   typedef struct
01859   {
01860     float32_t A0;          /**< The derived gain, A0 = Kp + Ki + Kd . */
01861     float32_t A1;          /**< The derived gain, A1 = -Kp - 2Kd. */
01862     float32_t A2;          /**< The derived gain, A2 = Kd . */
01863     float32_t state[3];    /**< The state array of length 3. */
01864     float32_t Kp;               /**< The proportional gain. */
01865     float32_t Ki;               /**< The integral gain. */
01866     float32_t Kd;               /**< The derivative gain. */
01867   } arm_pid_instance_f32;
01868 
01869 
01870 
01871   /**
01872    * @brief  Initialization function for the floating-point PID Control.
01873    * @param[in,out] *S      points to an instance of the PID structure.
01874    * @param[in]     resetStateFlag  flag to reset the state. 0 = no change in state 1 = reset the state.
01875    * @return none.
01876    */
01877   void arm_pid_init_f32(
01878   arm_pid_instance_f32 * S,
01879   int32_t resetStateFlag);
01880 
01881   /**
01882    * @brief  Reset function for the floating-point PID Control.
01883    * @param[in,out] *S is an instance of the floating-point PID Control structure
01884    * @return none
01885    */
01886   void arm_pid_reset_f32(
01887   arm_pid_instance_f32 * S);
01888 
01889 
01890   /**
01891    * @brief  Initialization function for the Q31 PID Control.
01892    * @param[in,out] *S points to an instance of the Q15 PID structure.
01893    * @param[in]     resetStateFlag  flag to reset the state. 0 = no change in state 1 = reset the state.
01894    * @return none.
01895    */
01896   void arm_pid_init_q31(
01897   arm_pid_instance_q31 * S,
01898   int32_t resetStateFlag);
01899 
01900 
01901   /**
01902    * @brief  Reset function for the Q31 PID Control.
01903    * @param[in,out] *S points to an instance of the Q31 PID Control structure
01904    * @return none
01905    */
01906 
01907   void arm_pid_reset_q31(
01908   arm_pid_instance_q31 * S);
01909 
01910   /**
01911    * @brief  Initialization function for the Q15 PID Control.
01912    * @param[in,out] *S points to an instance of the Q15 PID structure.
01913    * @param[in] resetStateFlag  flag to reset the state. 0 = no change in state 1 = reset the state.
01914    * @return none.
01915    */
01916   void arm_pid_init_q15(
01917   arm_pid_instance_q15 * S,
01918   int32_t resetStateFlag);
01919 
01920   /**
01921    * @brief  Reset function for the Q15 PID Control.
01922    * @param[in,out] *S points to an instance of the q15 PID Control structure
01923    * @return none
01924    */
01925   void arm_pid_reset_q15(
01926   arm_pid_instance_q15 * S);
01927 
01928 
01929   /**
01930    * @brief Instance structure for the floating-point Linear Interpolate function.
01931    */
01932   typedef struct
01933   {
01934     uint32_t nValues;           /**< nValues */
01935     float32_t x1;               /**< x1 */
01936     float32_t xSpacing;         /**< xSpacing */
01937     float32_t *pYData;          /**< pointer to the table of Y values */
01938   } arm_linear_interp_instance_f32;
01939 
01940   /**
01941    * @brief Instance structure for the floating-point bilinear interpolation function.
01942    */
01943 
01944   typedef struct
01945   {
01946     uint16_t numRows;   /**< number of rows in the data table. */
01947     uint16_t numCols;   /**< number of columns in the data table. */
01948     float32_t *pData;   /**< points to the data table. */
01949   } arm_bilinear_interp_instance_f32;
01950 
01951    /**
01952    * @brief Instance structure for the Q31 bilinear interpolation function.
01953    */
01954 
01955   typedef struct
01956   {
01957     uint16_t numRows;   /**< number of rows in the data table. */
01958     uint16_t numCols;   /**< number of columns in the data table. */
01959     q31_t *pData;       /**< points to the data table. */
01960   } arm_bilinear_interp_instance_q31;
01961 
01962    /**
01963    * @brief Instance structure for the Q15 bilinear interpolation function.
01964    */
01965 
01966   typedef struct
01967   {
01968     uint16_t numRows;   /**< number of rows in the data table. */
01969     uint16_t numCols;   /**< number of columns in the data table. */
01970     q15_t *pData;       /**< points to the data table. */
01971   } arm_bilinear_interp_instance_q15;
01972 
01973    /**
01974    * @brief Instance structure for the Q15 bilinear interpolation function.
01975    */
01976 
01977   typedef struct
01978   {
01979     uint16_t numRows;   /**< number of rows in the data table. */
01980     uint16_t numCols;   /**< number of columns in the data table. */
01981     q7_t *pData;                /**< points to the data table. */
01982   } arm_bilinear_interp_instance_q7;
01983 
01984 
01985   /**
01986    * @brief Q7 vector multiplication.
01987    * @param[in]       *pSrcA points to the first input vector
01988    * @param[in]       *pSrcB points to the second input vector
01989    * @param[out]      *pDst  points to the output vector
01990    * @param[in]       blockSize number of samples in each vector
01991    * @return none.
01992    */
01993 
01994   void arm_mult_q7(
01995   q7_t * pSrcA,
01996   q7_t * pSrcB,
01997   q7_t * pDst,
01998   uint32_t blockSize);
01999 
02000   /**
02001    * @brief Q15 vector multiplication.
02002    * @param[in]       *pSrcA points to the first input vector
02003    * @param[in]       *pSrcB points to the second input vector
02004    * @param[out]      *pDst  points to the output vector
02005    * @param[in]       blockSize number of samples in each vector
02006    * @return none.
02007    */
02008 
02009   void arm_mult_q15(
02010   q15_t * pSrcA,
02011   q15_t * pSrcB,
02012   q15_t * pDst,
02013   uint32_t blockSize);
02014 
02015   /**
02016    * @brief Q31 vector multiplication.
02017    * @param[in]       *pSrcA points to the first input vector
02018    * @param[in]       *pSrcB points to the second input vector
02019    * @param[out]      *pDst points to the output vector
02020    * @param[in]       blockSize number of samples in each vector
02021    * @return none.
02022    */
02023 
02024   void arm_mult_q31(
02025   q31_t * pSrcA,
02026   q31_t * pSrcB,
02027   q31_t * pDst,
02028   uint32_t blockSize);
02029 
02030   /**
02031    * @brief Floating-point vector multiplication.
02032    * @param[in]       *pSrcA points to the first input vector
02033    * @param[in]       *pSrcB points to the second input vector
02034    * @param[out]      *pDst points to the output vector
02035    * @param[in]       blockSize number of samples in each vector
02036    * @return none.
02037    */
02038 
02039   void arm_mult_f32(
02040   float32_t * pSrcA,
02041   float32_t * pSrcB,
02042   float32_t * pDst,
02043   uint32_t blockSize);
02044 
02045 
02046 
02047 
02048 
02049 
02050   /**
02051    * @brief Instance structure for the Q15 CFFT/CIFFT function.
02052    */
02053 
02054   typedef struct
02055   {
02056     uint16_t fftLen;                 /**< length of the FFT. */
02057     uint8_t ifftFlag;                /**< flag that selects forward (ifftFlag=0) or inverse (ifftFlag=1) transform. */
02058     uint8_t bitReverseFlag;          /**< flag that enables (bitReverseFlag=1) or disables (bitReverseFlag=0) bit reversal of output. */
02059     q15_t *pTwiddle;                     /**< points to the Sin twiddle factor table. */
02060     uint16_t *pBitRevTable;          /**< points to the bit reversal table. */
02061     uint16_t twidCoefModifier;       /**< twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. */
02062     uint16_t bitRevFactor;           /**< bit reversal modifier that supports different size FFTs with the same bit reversal table. */
02063   } arm_cfft_radix2_instance_q15;
02064 
02065 /* Deprecated */
02066   arm_status arm_cfft_radix2_init_q15(
02067   arm_cfft_radix2_instance_q15 * S,
02068   uint16_t fftLen,
02069   uint8_t ifftFlag,
02070   uint8_t bitReverseFlag);
02071 
02072 /* Deprecated */
02073   void arm_cfft_radix2_q15(
02074   const arm_cfft_radix2_instance_q15 * S,
02075   q15_t * pSrc);
02076 
02077 
02078 
02079   /**
02080    * @brief Instance structure for the Q15 CFFT/CIFFT function.
02081    */
02082 
02083   typedef struct
02084   {
02085     uint16_t fftLen;                 /**< length of the FFT. */
02086     uint8_t ifftFlag;                /**< flag that selects forward (ifftFlag=0) or inverse (ifftFlag=1) transform. */
02087     uint8_t bitReverseFlag;          /**< flag that enables (bitReverseFlag=1) or disables (bitReverseFlag=0) bit reversal of output. */
02088     q15_t *pTwiddle;                 /**< points to the twiddle factor table. */
02089     uint16_t *pBitRevTable;          /**< points to the bit reversal table. */
02090     uint16_t twidCoefModifier;       /**< twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. */
02091     uint16_t bitRevFactor;           /**< bit reversal modifier that supports different size FFTs with the same bit reversal table. */
02092   } arm_cfft_radix4_instance_q15;
02093 
02094 /* Deprecated */
02095   arm_status arm_cfft_radix4_init_q15(
02096   arm_cfft_radix4_instance_q15 * S,
02097   uint16_t fftLen,
02098   uint8_t ifftFlag,
02099   uint8_t bitReverseFlag);
02100 
02101 /* Deprecated */
02102   void arm_cfft_radix4_q15(
02103   const arm_cfft_radix4_instance_q15 * S,
02104   q15_t * pSrc);
02105 
02106   /**
02107    * @brief Instance structure for the Radix-2 Q31 CFFT/CIFFT function.
02108    */
02109 
02110   typedef struct
02111   {
02112     uint16_t fftLen;                 /**< length of the FFT. */
02113     uint8_t ifftFlag;                /**< flag that selects forward (ifftFlag=0) or inverse (ifftFlag=1) transform. */
02114     uint8_t bitReverseFlag;          /**< flag that enables (bitReverseFlag=1) or disables (bitReverseFlag=0) bit reversal of output. */
02115     q31_t *pTwiddle;                     /**< points to the Twiddle factor table. */
02116     uint16_t *pBitRevTable;          /**< points to the bit reversal table. */
02117     uint16_t twidCoefModifier;       /**< twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. */
02118     uint16_t bitRevFactor;           /**< bit reversal modifier that supports different size FFTs with the same bit reversal table. */
02119   } arm_cfft_radix2_instance_q31;
02120 
02121 /* Deprecated */
02122   arm_status arm_cfft_radix2_init_q31(
02123   arm_cfft_radix2_instance_q31 * S,
02124   uint16_t fftLen,
02125   uint8_t ifftFlag,
02126   uint8_t bitReverseFlag);
02127 
02128 /* Deprecated */
02129   void arm_cfft_radix2_q31(
02130   const arm_cfft_radix2_instance_q31 * S,
02131   q31_t * pSrc);
02132 
02133   /**
02134    * @brief Instance structure for the Q31 CFFT/CIFFT function.
02135    */
02136 
02137   typedef struct
02138   {
02139     uint16_t fftLen;                 /**< length of the FFT. */
02140     uint8_t ifftFlag;                /**< flag that selects forward (ifftFlag=0) or inverse (ifftFlag=1) transform. */
02141     uint8_t bitReverseFlag;          /**< flag that enables (bitReverseFlag=1) or disables (bitReverseFlag=0) bit reversal of output. */
02142     q31_t *pTwiddle;                 /**< points to the twiddle factor table. */
02143     uint16_t *pBitRevTable;          /**< points to the bit reversal table. */
02144     uint16_t twidCoefModifier;       /**< twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. */
02145     uint16_t bitRevFactor;           /**< bit reversal modifier that supports different size FFTs with the same bit reversal table. */
02146   } arm_cfft_radix4_instance_q31;
02147 
02148 /* Deprecated */
02149   void arm_cfft_radix4_q31(
02150   const arm_cfft_radix4_instance_q31 * S,
02151   q31_t * pSrc);
02152 
02153 /* Deprecated */
02154   arm_status arm_cfft_radix4_init_q31(
02155   arm_cfft_radix4_instance_q31 * S,
02156   uint16_t fftLen,
02157   uint8_t ifftFlag,
02158   uint8_t bitReverseFlag);
02159 
02160   /**
02161    * @brief Instance structure for the floating-point CFFT/CIFFT function.
02162    */
02163 
02164   typedef struct
02165   {
02166     uint16_t fftLen;                   /**< length of the FFT. */
02167     uint8_t ifftFlag;                  /**< flag that selects forward (ifftFlag=0) or inverse (ifftFlag=1) transform. */
02168     uint8_t bitReverseFlag;            /**< flag that enables (bitReverseFlag=1) or disables (bitReverseFlag=0) bit reversal of output. */
02169     float32_t *pTwiddle;               /**< points to the Twiddle factor table. */
02170     uint16_t *pBitRevTable;            /**< points to the bit reversal table. */
02171     uint16_t twidCoefModifier;         /**< twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. */
02172     uint16_t bitRevFactor;             /**< bit reversal modifier that supports different size FFTs with the same bit reversal table. */
02173     float32_t onebyfftLen;                 /**< value of 1/fftLen. */
02174   } arm_cfft_radix2_instance_f32;
02175 
02176 /* Deprecated */
02177   arm_status arm_cfft_radix2_init_f32(
02178   arm_cfft_radix2_instance_f32 * S,
02179   uint16_t fftLen,
02180   uint8_t ifftFlag,
02181   uint8_t bitReverseFlag);
02182 
02183 /* Deprecated */
02184   void arm_cfft_radix2_f32(
02185   const arm_cfft_radix2_instance_f32 * S,
02186   float32_t * pSrc);
02187 
02188   /**
02189    * @brief Instance structure for the floating-point CFFT/CIFFT function.
02190    */
02191 
02192   typedef struct
02193   {
02194     uint16_t fftLen;                   /**< length of the FFT. */
02195     uint8_t ifftFlag;                  /**< flag that selects forward (ifftFlag=0) or inverse (ifftFlag=1) transform. */
02196     uint8_t bitReverseFlag;            /**< flag that enables (bitReverseFlag=1) or disables (bitReverseFlag=0) bit reversal of output. */
02197     float32_t *pTwiddle;               /**< points to the Twiddle factor table. */
02198     uint16_t *pBitRevTable;            /**< points to the bit reversal table. */
02199     uint16_t twidCoefModifier;         /**< twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. */
02200     uint16_t bitRevFactor;             /**< bit reversal modifier that supports different size FFTs with the same bit reversal table. */
02201     float32_t onebyfftLen;                 /**< value of 1/fftLen. */
02202   } arm_cfft_radix4_instance_f32;
02203 
02204 /* Deprecated */
02205   arm_status arm_cfft_radix4_init_f32(
02206   arm_cfft_radix4_instance_f32 * S,
02207   uint16_t fftLen,
02208   uint8_t ifftFlag,
02209   uint8_t bitReverseFlag);
02210 
02211 /* Deprecated */
02212   void arm_cfft_radix4_f32(
02213   const arm_cfft_radix4_instance_f32 * S,
02214   float32_t * pSrc);
02215 
02216   /**
02217    * @brief Instance structure for the fixed-point CFFT/CIFFT function.
02218    */
02219 
02220   typedef struct
02221   {
02222     uint16_t fftLen;                   /**< length of the FFT. */
02223     const q15_t *pTwiddle;             /**< points to the Twiddle factor table. */
02224     const uint16_t *pBitRevTable;      /**< points to the bit reversal table. */
02225     uint16_t bitRevLength;             /**< bit reversal table length. */
02226   } arm_cfft_instance_q15;
02227 
02228 void arm_cfft_q15( 
02229     const arm_cfft_instance_q15 * S, 
02230     q15_t * p1,
02231     uint8_t ifftFlag,
02232     uint8_t bitReverseFlag);  
02233 
02234   /**
02235    * @brief Instance structure for the fixed-point CFFT/CIFFT function.
02236    */
02237 
02238   typedef struct
02239   {
02240     uint16_t fftLen;                   /**< length of the FFT. */
02241     const q31_t *pTwiddle;             /**< points to the Twiddle factor table. */
02242     const uint16_t *pBitRevTable;      /**< points to the bit reversal table. */
02243     uint16_t bitRevLength;             /**< bit reversal table length. */
02244   } arm_cfft_instance_q31;
02245 
02246 void arm_cfft_q31( 
02247     const arm_cfft_instance_q31 * S, 
02248     q31_t * p1,
02249     uint8_t ifftFlag,
02250     uint8_t bitReverseFlag);  
02251   
02252   /**
02253    * @brief Instance structure for the floating-point CFFT/CIFFT function.
02254    */
02255 
02256   typedef struct
02257   {
02258     uint16_t fftLen;                   /**< length of the FFT. */
02259     const float32_t *pTwiddle;         /**< points to the Twiddle factor table. */
02260     const uint16_t *pBitRevTable;      /**< points to the bit reversal table. */
02261     uint16_t bitRevLength;             /**< bit reversal table length. */
02262   } arm_cfft_instance_f32;
02263 
02264   void arm_cfft_f32(
02265   const arm_cfft_instance_f32 * S,
02266   float32_t * p1,
02267   uint8_t ifftFlag,
02268   uint8_t bitReverseFlag);
02269 
02270   /**
02271    * @brief Instance structure for the Q15 RFFT/RIFFT function.
02272    */
02273 
02274   typedef struct
02275   {
02276     uint32_t fftLenReal;                      /**< length of the real FFT. */
02277     uint8_t ifftFlagR;                        /**< flag that selects forward (ifftFlagR=0) or inverse (ifftFlagR=1) transform. */
02278     uint8_t bitReverseFlagR;                  /**< flag that enables (bitReverseFlagR=1) or disables (bitReverseFlagR=0) bit reversal of output. */
02279     uint32_t twidCoefRModifier;               /**< twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. */
02280     q15_t *pTwiddleAReal;                     /**< points to the real twiddle factor table. */
02281     q15_t *pTwiddleBReal;                     /**< points to the imag twiddle factor table. */
02282     const arm_cfft_instance_q15 *pCfft;       /**< points to the complex FFT instance. */
02283   } arm_rfft_instance_q15;
02284 
02285   arm_status arm_rfft_init_q15(
02286   arm_rfft_instance_q15 * S,
02287   uint32_t fftLenReal,
02288   uint32_t ifftFlagR,
02289   uint32_t bitReverseFlag);
02290 
02291   void arm_rfft_q15(
02292   const arm_rfft_instance_q15 * S,
02293   q15_t * pSrc,
02294   q15_t * pDst);
02295 
02296   /**
02297    * @brief Instance structure for the Q31 RFFT/RIFFT function.
02298    */
02299 
02300   typedef struct
02301   {
02302     uint32_t fftLenReal;                        /**< length of the real FFT. */
02303     uint8_t ifftFlagR;                          /**< flag that selects forward (ifftFlagR=0) or inverse (ifftFlagR=1) transform. */
02304     uint8_t bitReverseFlagR;                    /**< flag that enables (bitReverseFlagR=1) or disables (bitReverseFlagR=0) bit reversal of output. */
02305     uint32_t twidCoefRModifier;                 /**< twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. */
02306     q31_t *pTwiddleAReal;                       /**< points to the real twiddle factor table. */
02307     q31_t *pTwiddleBReal;                       /**< points to the imag twiddle factor table. */
02308     const arm_cfft_instance_q31 *pCfft;         /**< points to the complex FFT instance. */
02309   } arm_rfft_instance_q31;
02310 
02311   arm_status arm_rfft_init_q31(
02312   arm_rfft_instance_q31 * S,
02313   uint32_t fftLenReal,
02314   uint32_t ifftFlagR,
02315   uint32_t bitReverseFlag);
02316 
02317   void arm_rfft_q31(
02318   const arm_rfft_instance_q31 * S,
02319   q31_t * pSrc,
02320   q31_t * pDst);
02321 
02322   /**
02323    * @brief Instance structure for the floating-point RFFT/RIFFT function.
02324    */
02325 
02326   typedef struct
02327   {
02328     uint32_t fftLenReal;                        /**< length of the real FFT. */
02329     uint16_t fftLenBy2;                         /**< length of the complex FFT. */
02330     uint8_t ifftFlagR;                          /**< flag that selects forward (ifftFlagR=0) or inverse (ifftFlagR=1) transform. */
02331     uint8_t bitReverseFlagR;                    /**< flag that enables (bitReverseFlagR=1) or disables (bitReverseFlagR=0) bit reversal of output. */
02332     uint32_t twidCoefRModifier;                     /**< twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. */
02333     float32_t *pTwiddleAReal;                   /**< points to the real twiddle factor table. */
02334     float32_t *pTwiddleBReal;                   /**< points to the imag twiddle factor table. */
02335     arm_cfft_radix4_instance_f32 *pCfft;        /**< points to the complex FFT instance. */
02336   } arm_rfft_instance_f32;
02337 
02338   arm_status arm_rfft_init_f32(
02339   arm_rfft_instance_f32 * S,
02340   arm_cfft_radix4_instance_f32 * S_CFFT,
02341   uint32_t fftLenReal,
02342   uint32_t ifftFlagR,
02343   uint32_t bitReverseFlag);
02344 
02345   void arm_rfft_f32(
02346   const arm_rfft_instance_f32 * S,
02347   float32_t * pSrc,
02348   float32_t * pDst);
02349 
02350   /**
02351    * @brief Instance structure for the floating-point RFFT/RIFFT function.
02352    */
02353 
02354 typedef struct
02355   {
02356     arm_cfft_instance_f32 Sint;      /**< Internal CFFT structure. */
02357     uint16_t fftLenRFFT;                        /**< length of the real sequence */
02358     float32_t * pTwiddleRFFT;                   /**< Twiddle factors real stage  */
02359   } arm_rfft_fast_instance_f32 ;
02360 
02361 arm_status arm_rfft_fast_init_f32 (
02362     arm_rfft_fast_instance_f32 * S,
02363     uint16_t fftLen);
02364 
02365 void arm_rfft_fast_f32(
02366   arm_rfft_fast_instance_f32 * S,
02367   float32_t * p, float32_t * pOut,
02368   uint8_t ifftFlag);
02369 
02370   /**
02371    * @brief Instance structure for the floating-point DCT4/IDCT4 function.
02372    */
02373 
02374   typedef struct
02375   {
02376     uint16_t N;                         /**< length of the DCT4. */
02377     uint16_t Nby2;                      /**< half of the length of the DCT4. */
02378     float32_t normalize;                /**< normalizing factor. */
02379     float32_t *pTwiddle;                /**< points to the twiddle factor table. */
02380     float32_t *pCosFactor;              /**< points to the cosFactor table. */
02381     arm_rfft_instance_f32 *pRfft;        /**< points to the real FFT instance. */
02382     arm_cfft_radix4_instance_f32 *pCfft; /**< points to the complex FFT instance. */
02383   } arm_dct4_instance_f32;
02384 
02385   /**
02386    * @brief  Initialization function for the floating-point DCT4/IDCT4.
02387    * @param[in,out] *S         points to an instance of floating-point DCT4/IDCT4 structure.
02388    * @param[in]     *S_RFFT    points to an instance of floating-point RFFT/RIFFT structure.
02389    * @param[in]     *S_CFFT    points to an instance of floating-point CFFT/CIFFT structure.
02390    * @param[in]     N          length of the DCT4.
02391    * @param[in]     Nby2       half of the length of the DCT4.
02392    * @param[in]     normalize  normalizing factor.
02393    * @return        arm_status function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_ARGUMENT_ERROR if <code>fftLenReal</code> is not a supported transform length.
02394    */
02395 
02396   arm_status arm_dct4_init_f32(
02397   arm_dct4_instance_f32 * S,
02398   arm_rfft_instance_f32 * S_RFFT,
02399   arm_cfft_radix4_instance_f32 * S_CFFT,
02400   uint16_t N,
02401   uint16_t Nby2,
02402   float32_t normalize);
02403 
02404   /**
02405    * @brief Processing function for the floating-point DCT4/IDCT4.
02406    * @param[in]       *S             points to an instance of the floating-point DCT4/IDCT4 structure.
02407    * @param[in]       *pState        points to state buffer.
02408    * @param[in,out]   *pInlineBuffer points to the in-place input and output buffer.
02409    * @return none.
02410    */
02411 
02412   void arm_dct4_f32(
02413   const arm_dct4_instance_f32 * S,
02414   float32_t * pState,
02415   float32_t * pInlineBuffer);
02416 
02417   /**
02418    * @brief Instance structure for the Q31 DCT4/IDCT4 function.
02419    */
02420 
02421   typedef struct
02422   {
02423     uint16_t N;                         /**< length of the DCT4. */
02424     uint16_t Nby2;                      /**< half of the length of the DCT4. */
02425     q31_t normalize;                    /**< normalizing factor. */
02426     q31_t *pTwiddle;                    /**< points to the twiddle factor table. */
02427     q31_t *pCosFactor;                  /**< points to the cosFactor table. */
02428     arm_rfft_instance_q31 *pRfft;        /**< points to the real FFT instance. */
02429     arm_cfft_radix4_instance_q31 *pCfft; /**< points to the complex FFT instance. */
02430   } arm_dct4_instance_q31;
02431 
02432   /**
02433    * @brief  Initialization function for the Q31 DCT4/IDCT4.
02434    * @param[in,out] *S         points to an instance of Q31 DCT4/IDCT4 structure.
02435    * @param[in]     *S_RFFT    points to an instance of Q31 RFFT/RIFFT structure
02436    * @param[in]     *S_CFFT    points to an instance of Q31 CFFT/CIFFT structure
02437    * @param[in]     N          length of the DCT4.
02438    * @param[in]     Nby2       half of the length of the DCT4.
02439    * @param[in]     normalize  normalizing factor.
02440    * @return        arm_status function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_ARGUMENT_ERROR if <code>N</code> is not a supported transform length.
02441    */
02442 
02443   arm_status arm_dct4_init_q31(
02444   arm_dct4_instance_q31 * S,
02445   arm_rfft_instance_q31 * S_RFFT,
02446   arm_cfft_radix4_instance_q31 * S_CFFT,
02447   uint16_t N,
02448   uint16_t Nby2,
02449   q31_t normalize);
02450 
02451   /**
02452    * @brief Processing function for the Q31 DCT4/IDCT4.
02453    * @param[in]       *S             points to an instance of the Q31 DCT4 structure.
02454    * @param[in]       *pState        points to state buffer.
02455    * @param[in,out]   *pInlineBuffer points to the in-place input and output buffer.
02456    * @return none.
02457    */
02458 
02459   void arm_dct4_q31(
02460   const arm_dct4_instance_q31 * S,
02461   q31_t * pState,
02462   q31_t * pInlineBuffer);
02463 
02464   /**
02465    * @brief Instance structure for the Q15 DCT4/IDCT4 function.
02466    */
02467 
02468   typedef struct
02469   {
02470     uint16_t N;                         /**< length of the DCT4. */
02471     uint16_t Nby2;                      /**< half of the length of the DCT4. */
02472     q15_t normalize;                    /**< normalizing factor. */
02473     q15_t *pTwiddle;                    /**< points to the twiddle factor table. */
02474     q15_t *pCosFactor;                  /**< points to the cosFactor table. */
02475     arm_rfft_instance_q15 *pRfft;        /**< points to the real FFT instance. */
02476     arm_cfft_radix4_instance_q15 *pCfft; /**< points to the complex FFT instance. */
02477   } arm_dct4_instance_q15;
02478 
02479   /**
02480    * @brief  Initialization function for the Q15 DCT4/IDCT4.
02481    * @param[in,out] *S         points to an instance of Q15 DCT4/IDCT4 structure.
02482    * @param[in]     *S_RFFT    points to an instance of Q15 RFFT/RIFFT structure.
02483    * @param[in]     *S_CFFT    points to an instance of Q15 CFFT/CIFFT structure.
02484    * @param[in]     N          length of the DCT4.
02485    * @param[in]     Nby2       half of the length of the DCT4.
02486    * @param[in]     normalize  normalizing factor.
02487    * @return        arm_status function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_ARGUMENT_ERROR if <code>N</code> is not a supported transform length.
02488    */
02489 
02490   arm_status arm_dct4_init_q15(
02491   arm_dct4_instance_q15 * S,
02492   arm_rfft_instance_q15 * S_RFFT,
02493   arm_cfft_radix4_instance_q15 * S_CFFT,
02494   uint16_t N,
02495   uint16_t Nby2,
02496   q15_t normalize);
02497 
02498   /**
02499    * @brief Processing function for the Q15 DCT4/IDCT4.
02500    * @param[in]       *S             points to an instance of the Q15 DCT4 structure.
02501    * @param[in]       *pState        points to state buffer.
02502    * @param[in,out]   *pInlineBuffer points to the in-place input and output buffer.
02503    * @return none.
02504    */
02505 
02506   void arm_dct4_q15(
02507   const arm_dct4_instance_q15 * S,
02508   q15_t * pState,
02509   q15_t * pInlineBuffer);
02510 
02511   /**
02512    * @brief Floating-point vector addition.
02513    * @param[in]       *pSrcA points to the first input vector
02514    * @param[in]       *pSrcB points to the second input vector
02515    * @param[out]      *pDst points to the output vector
02516    * @param[in]       blockSize number of samples in each vector
02517    * @return none.
02518    */
02519 
02520   void arm_add_f32(
02521   float32_t * pSrcA,
02522   float32_t * pSrcB,
02523   float32_t * pDst,
02524   uint32_t blockSize);
02525 
02526   /**
02527    * @brief Q7 vector addition.
02528    * @param[in]       *pSrcA points to the first input vector
02529    * @param[in]       *pSrcB points to the second input vector
02530    * @param[out]      *pDst points to the output vector
02531    * @param[in]       blockSize number of samples in each vector
02532    * @return none.
02533    */
02534 
02535   void arm_add_q7(
02536   q7_t * pSrcA,
02537   q7_t * pSrcB,
02538   q7_t * pDst,
02539   uint32_t blockSize);
02540 
02541   /**
02542    * @brief Q15 vector addition.
02543    * @param[in]       *pSrcA points to the first input vector
02544    * @param[in]       *pSrcB points to the second input vector
02545    * @param[out]      *pDst points to the output vector
02546    * @param[in]       blockSize number of samples in each vector
02547    * @return none.
02548    */
02549 
02550   void arm_add_q15(
02551   q15_t * pSrcA,
02552   q15_t * pSrcB,
02553   q15_t * pDst,
02554   uint32_t blockSize);
02555 
02556   /**
02557    * @brief Q31 vector addition.
02558    * @param[in]       *pSrcA points to the first input vector
02559    * @param[in]       *pSrcB points to the second input vector
02560    * @param[out]      *pDst points to the output vector
02561    * @param[in]       blockSize number of samples in each vector
02562    * @return none.
02563    */
02564 
02565   void arm_add_q31(
02566   q31_t * pSrcA,
02567   q31_t * pSrcB,
02568   q31_t * pDst,
02569   uint32_t blockSize);
02570 
02571   /**
02572    * @brief Floating-point vector subtraction.
02573    * @param[in]       *pSrcA points to the first input vector
02574    * @param[in]       *pSrcB points to the second input vector
02575    * @param[out]      *pDst points to the output vector
02576    * @param[in]       blockSize number of samples in each vector
02577    * @return none.
02578    */
02579 
02580   void arm_sub_f32(
02581   float32_t * pSrcA,
02582   float32_t * pSrcB,
02583   float32_t * pDst,
02584   uint32_t blockSize);
02585 
02586   /**
02587    * @brief Q7 vector subtraction.
02588    * @param[in]       *pSrcA points to the first input vector
02589    * @param[in]       *pSrcB points to the second input vector
02590    * @param[out]      *pDst points to the output vector
02591    * @param[in]       blockSize number of samples in each vector
02592    * @return none.
02593    */
02594 
02595   void arm_sub_q7(
02596   q7_t * pSrcA,
02597   q7_t * pSrcB,
02598   q7_t * pDst,
02599   uint32_t blockSize);
02600 
02601   /**
02602    * @brief Q15 vector subtraction.
02603    * @param[in]       *pSrcA points to the first input vector
02604    * @param[in]       *pSrcB points to the second input vector
02605    * @param[out]      *pDst points to the output vector
02606    * @param[in]       blockSize number of samples in each vector
02607    * @return none.
02608    */
02609 
02610   void arm_sub_q15(
02611   q15_t * pSrcA,
02612   q15_t * pSrcB,
02613   q15_t * pDst,
02614   uint32_t blockSize);
02615 
02616   /**
02617    * @brief Q31 vector subtraction.
02618    * @param[in]       *pSrcA points to the first input vector
02619    * @param[in]       *pSrcB points to the second input vector
02620    * @param[out]      *pDst points to the output vector
02621    * @param[in]       blockSize number of samples in each vector
02622    * @return none.
02623    */
02624 
02625   void arm_sub_q31(
02626   q31_t * pSrcA,
02627   q31_t * pSrcB,
02628   q31_t * pDst,
02629   uint32_t blockSize);
02630 
02631   /**
02632    * @brief Multiplies a floating-point vector by a scalar.
02633    * @param[in]       *pSrc points to the input vector
02634    * @param[in]       scale scale factor to be applied
02635    * @param[out]      *pDst points to the output vector
02636    * @param[in]       blockSize number of samples in the vector
02637    * @return none.
02638    */
02639 
02640   void arm_scale_f32(
02641   float32_t * pSrc,
02642   float32_t scale,
02643   float32_t * pDst,
02644   uint32_t blockSize);
02645 
02646   /**
02647    * @brief Multiplies a Q7 vector by a scalar.
02648    * @param[in]       *pSrc points to the input vector
02649    * @param[in]       scaleFract fractional portion of the scale value
02650    * @param[in]       shift number of bits to shift the result by
02651    * @param[out]      *pDst points to the output vector
02652    * @param[in]       blockSize number of samples in the vector
02653    * @return none.
02654    */
02655 
02656   void arm_scale_q7(
02657   q7_t * pSrc,
02658   q7_t scaleFract,
02659   int8_t shift,
02660   q7_t * pDst,
02661   uint32_t blockSize);
02662 
02663   /**
02664    * @brief Multiplies a Q15 vector by a scalar.
02665    * @param[in]       *pSrc points to the input vector
02666    * @param[in]       scaleFract fractional portion of the scale value
02667    * @param[in]       shift number of bits to shift the result by
02668    * @param[out]      *pDst points to the output vector
02669    * @param[in]       blockSize number of samples in the vector
02670    * @return none.
02671    */
02672 
02673   void arm_scale_q15(
02674   q15_t * pSrc,
02675   q15_t scaleFract,
02676   int8_t shift,
02677   q15_t * pDst,
02678   uint32_t blockSize);
02679 
02680   /**
02681    * @brief Multiplies a Q31 vector by a scalar.
02682    * @param[in]       *pSrc points to the input vector
02683    * @param[in]       scaleFract fractional portion of the scale value
02684    * @param[in]       shift number of bits to shift the result by
02685    * @param[out]      *pDst points to the output vector
02686    * @param[in]       blockSize number of samples in the vector
02687    * @return none.
02688    */
02689 
02690   void arm_scale_q31(
02691   q31_t * pSrc,
02692   q31_t scaleFract,
02693   int8_t shift,
02694   q31_t * pDst,
02695   uint32_t blockSize);
02696 
02697   /**
02698    * @brief Q7 vector absolute value.
02699    * @param[in]       *pSrc points to the input buffer
02700    * @param[out]      *pDst points to the output buffer
02701    * @param[in]       blockSize number of samples in each vector
02702    * @return none.
02703    */
02704 
02705   void arm_abs_q7(
02706   q7_t * pSrc,
02707   q7_t * pDst,
02708   uint32_t blockSize);
02709 
02710   /**
02711    * @brief Floating-point vector absolute value.
02712    * @param[in]       *pSrc points to the input buffer
02713    * @param[out]      *pDst points to the output buffer
02714    * @param[in]       blockSize number of samples in each vector
02715    * @return none.
02716    */
02717 
02718   void arm_abs_f32(
02719   float32_t * pSrc,
02720   float32_t * pDst,
02721   uint32_t blockSize);
02722 
02723   /**
02724    * @brief Q15 vector absolute value.
02725    * @param[in]       *pSrc points to the input buffer
02726    * @param[out]      *pDst points to the output buffer
02727    * @param[in]       blockSize number of samples in each vector
02728    * @return none.
02729    */
02730 
02731   void arm_abs_q15(
02732   q15_t * pSrc,
02733   q15_t * pDst,
02734   uint32_t blockSize);
02735 
02736   /**
02737    * @brief Q31 vector absolute value.
02738    * @param[in]       *pSrc points to the input buffer
02739    * @param[out]      *pDst points to the output buffer
02740    * @param[in]       blockSize number of samples in each vector
02741    * @return none.
02742    */
02743 
02744   void arm_abs_q31(
02745   q31_t * pSrc,
02746   q31_t * pDst,
02747   uint32_t blockSize);
02748 
02749   /**
02750    * @brief Dot product of floating-point vectors.
02751    * @param[in]       *pSrcA points to the first input vector
02752    * @param[in]       *pSrcB points to the second input vector
02753    * @param[in]       blockSize number of samples in each vector
02754    * @param[out]      *result output result returned here
02755    * @return none.
02756    */
02757 
02758   void arm_dot_prod_f32(
02759   float32_t * pSrcA,
02760   float32_t * pSrcB,
02761   uint32_t blockSize,
02762   float32_t * result);
02763 
02764   /**
02765    * @brief Dot product of Q7 vectors.
02766    * @param[in]       *pSrcA points to the first input vector
02767    * @param[in]       *pSrcB points to the second input vector
02768    * @param[in]       blockSize number of samples in each vector
02769    * @param[out]      *result output result returned here
02770    * @return none.
02771    */
02772 
02773   void arm_dot_prod_q7(
02774   q7_t * pSrcA,
02775   q7_t * pSrcB,
02776   uint32_t blockSize,
02777   q31_t * result);
02778 
02779   /**
02780    * @brief Dot product of Q15 vectors.
02781    * @param[in]       *pSrcA points to the first input vector
02782    * @param[in]       *pSrcB points to the second input vector
02783    * @param[in]       blockSize number of samples in each vector
02784    * @param[out]      *result output result returned here
02785    * @return none.
02786    */
02787 
02788   void arm_dot_prod_q15(
02789   q15_t * pSrcA,
02790   q15_t * pSrcB,
02791   uint32_t blockSize,
02792   q63_t * result);
02793 
02794   /**
02795    * @brief Dot product of Q31 vectors.
02796    * @param[in]       *pSrcA points to the first input vector
02797    * @param[in]       *pSrcB points to the second input vector
02798    * @param[in]       blockSize number of samples in each vector
02799    * @param[out]      *result output result returned here
02800    * @return none.
02801    */
02802 
02803   void arm_dot_prod_q31(
02804   q31_t * pSrcA,
02805   q31_t * pSrcB,
02806   uint32_t blockSize,
02807   q63_t * result);
02808 
02809   /**
02810    * @brief  Shifts the elements of a Q7 vector a specified number of bits.
02811    * @param[in]  *pSrc points to the input vector
02812    * @param[in]  shiftBits number of bits to shift.  A positive value shifts left; a negative value shifts right.
02813    * @param[out]  *pDst points to the output vector
02814    * @param[in]  blockSize number of samples in the vector
02815    * @return none.
02816    */
02817 
02818   void arm_shift_q7(
02819   q7_t * pSrc,
02820   int8_t shiftBits,
02821   q7_t * pDst,
02822   uint32_t blockSize);
02823 
02824   /**
02825    * @brief  Shifts the elements of a Q15 vector a specified number of bits.
02826    * @param[in]  *pSrc points to the input vector
02827    * @param[in]  shiftBits number of bits to shift.  A positive value shifts left; a negative value shifts right.
02828    * @param[out]  *pDst points to the output vector
02829    * @param[in]  blockSize number of samples in the vector
02830    * @return none.
02831    */
02832 
02833   void arm_shift_q15(
02834   q15_t * pSrc,
02835   int8_t shiftBits,
02836   q15_t * pDst,
02837   uint32_t blockSize);
02838 
02839   /**
02840    * @brief  Shifts the elements of a Q31 vector a specified number of bits.
02841    * @param[in]  *pSrc points to the input vector
02842    * @param[in]  shiftBits number of bits to shift.  A positive value shifts left; a negative value shifts right.
02843    * @param[out]  *pDst points to the output vector
02844    * @param[in]  blockSize number of samples in the vector
02845    * @return none.
02846    */
02847 
02848   void arm_shift_q31(
02849   q31_t * pSrc,
02850   int8_t shiftBits,
02851   q31_t * pDst,
02852   uint32_t blockSize);
02853 
02854   /**
02855    * @brief  Adds a constant offset to a floating-point vector.
02856    * @param[in]  *pSrc points to the input vector
02857    * @param[in]  offset is the offset to be added
02858    * @param[out]  *pDst points to the output vector
02859    * @param[in]  blockSize number of samples in the vector
02860    * @return none.
02861    */
02862 
02863   void arm_offset_f32(
02864   float32_t * pSrc,
02865   float32_t offset,
02866   float32_t * pDst,
02867   uint32_t blockSize);
02868 
02869   /**
02870    * @brief  Adds a constant offset to a Q7 vector.
02871    * @param[in]  *pSrc points to the input vector
02872    * @param[in]  offset is the offset to be added
02873    * @param[out]  *pDst points to the output vector
02874    * @param[in]  blockSize number of samples in the vector
02875    * @return none.
02876    */
02877 
02878   void arm_offset_q7(
02879   q7_t * pSrc,
02880   q7_t offset,
02881   q7_t * pDst,
02882   uint32_t blockSize);
02883 
02884   /**
02885    * @brief  Adds a constant offset to a Q15 vector.
02886    * @param[in]  *pSrc points to the input vector
02887    * @param[in]  offset is the offset to be added
02888    * @param[out]  *pDst points to the output vector
02889    * @param[in]  blockSize number of samples in the vector
02890    * @return none.
02891    */
02892 
02893   void arm_offset_q15(
02894   q15_t * pSrc,
02895   q15_t offset,
02896   q15_t * pDst,
02897   uint32_t blockSize);
02898 
02899   /**
02900    * @brief  Adds a constant offset to a Q31 vector.
02901    * @param[in]  *pSrc points to the input vector
02902    * @param[in]  offset is the offset to be added
02903    * @param[out]  *pDst points to the output vector
02904    * @param[in]  blockSize number of samples in the vector
02905    * @return none.
02906    */
02907 
02908   void arm_offset_q31(
02909   q31_t * pSrc,
02910   q31_t offset,
02911   q31_t * pDst,
02912   uint32_t blockSize);
02913 
02914   /**
02915    * @brief  Negates the elements of a floating-point vector.
02916    * @param[in]  *pSrc points to the input vector
02917    * @param[out]  *pDst points to the output vector
02918    * @param[in]  blockSize number of samples in the vector
02919    * @return none.
02920    */
02921 
02922   void arm_negate_f32(
02923   float32_t * pSrc,
02924   float32_t * pDst,
02925   uint32_t blockSize);
02926 
02927   /**
02928    * @brief  Negates the elements of a Q7 vector.
02929    * @param[in]  *pSrc points to the input vector
02930    * @param[out]  *pDst points to the output vector
02931    * @param[in]  blockSize number of samples in the vector
02932    * @return none.
02933    */
02934 
02935   void arm_negate_q7(
02936   q7_t * pSrc,
02937   q7_t * pDst,
02938   uint32_t blockSize);
02939 
02940   /**
02941    * @brief  Negates the elements of a Q15 vector.
02942    * @param[in]  *pSrc points to the input vector
02943    * @param[out]  *pDst points to the output vector
02944    * @param[in]  blockSize number of samples in the vector
02945    * @return none.
02946    */
02947 
02948   void arm_negate_q15(
02949   q15_t * pSrc,
02950   q15_t * pDst,
02951   uint32_t blockSize);
02952 
02953   /**
02954    * @brief  Negates the elements of a Q31 vector.
02955    * @param[in]  *pSrc points to the input vector
02956    * @param[out]  *pDst points to the output vector
02957    * @param[in]  blockSize number of samples in the vector
02958    * @return none.
02959    */
02960 
02961   void arm_negate_q31(
02962   q31_t * pSrc,
02963   q31_t * pDst,
02964   uint32_t blockSize);
02965   /**
02966    * @brief  Copies the elements of a floating-point vector.
02967    * @param[in]  *pSrc input pointer
02968    * @param[out]  *pDst output pointer
02969    * @param[in]  blockSize number of samples to process
02970    * @return none.
02971    */
02972   void arm_copy_f32(
02973   float32_t * pSrc,
02974   float32_t * pDst,
02975   uint32_t blockSize);
02976 
02977   /**
02978    * @brief  Copies the elements of a Q7 vector.
02979    * @param[in]  *pSrc input pointer
02980    * @param[out]  *pDst output pointer
02981    * @param[in]  blockSize number of samples to process
02982    * @return none.
02983    */
02984   void arm_copy_q7(
02985   q7_t * pSrc,
02986   q7_t * pDst,
02987   uint32_t blockSize);
02988 
02989   /**
02990    * @brief  Copies the elements of a Q15 vector.
02991    * @param[in]  *pSrc input pointer
02992    * @param[out]  *pDst output pointer
02993    * @param[in]  blockSize number of samples to process
02994    * @return none.
02995    */
02996   void arm_copy_q15(
02997   q15_t * pSrc,
02998   q15_t * pDst,
02999   uint32_t blockSize);
03000 
03001   /**
03002    * @brief  Copies the elements of a Q31 vector.
03003    * @param[in]  *pSrc input pointer
03004    * @param[out]  *pDst output pointer
03005    * @param[in]  blockSize number of samples to process
03006    * @return none.
03007    */
03008   void arm_copy_q31(
03009   q31_t * pSrc,
03010   q31_t * pDst,
03011   uint32_t blockSize);
03012   /**
03013    * @brief  Fills a constant value into a floating-point vector.
03014    * @param[in]  value input value to be filled
03015    * @param[out]  *pDst output pointer
03016    * @param[in]  blockSize number of samples to process
03017    * @return none.
03018    */
03019   void arm_fill_f32(
03020   float32_t value,
03021   float32_t * pDst,
03022   uint32_t blockSize);
03023 
03024   /**
03025    * @brief  Fills a constant value into a Q7 vector.
03026    * @param[in]  value input value to be filled
03027    * @param[out]  *pDst output pointer
03028    * @param[in]  blockSize number of samples to process
03029    * @return none.
03030    */
03031   void arm_fill_q7(
03032   q7_t value,
03033   q7_t * pDst,
03034   uint32_t blockSize);
03035 
03036   /**
03037    * @brief  Fills a constant value into a Q15 vector.
03038    * @param[in]  value input value to be filled
03039    * @param[out]  *pDst output pointer
03040    * @param[in]  blockSize number of samples to process
03041    * @return none.
03042    */
03043   void arm_fill_q15(
03044   q15_t value,
03045   q15_t * pDst,
03046   uint32_t blockSize);
03047 
03048   /**
03049    * @brief  Fills a constant value into a Q31 vector.
03050    * @param[in]  value input value to be filled
03051    * @param[out]  *pDst output pointer
03052    * @param[in]  blockSize number of samples to process
03053    * @return none.
03054    */
03055   void arm_fill_q31(
03056   q31_t value,
03057   q31_t * pDst,
03058   uint32_t blockSize);
03059 
03060 /**
03061  * @brief Convolution of floating-point sequences.
03062  * @param[in] *pSrcA points to the first input sequence.
03063  * @param[in] srcALen length of the first input sequence.
03064  * @param[in] *pSrcB points to the second input sequence.
03065  * @param[in] srcBLen length of the second input sequence.
03066  * @param[out] *pDst points to the location where the output result is written.  Length srcALen+srcBLen-1.
03067  * @return none.
03068  */
03069 
03070   void arm_conv_f32(
03071   float32_t * pSrcA,
03072   uint32_t srcALen,
03073   float32_t * pSrcB,
03074   uint32_t srcBLen,
03075   float32_t * pDst);
03076 
03077 
03078   /**
03079    * @brief Convolution of Q15 sequences.
03080    * @param[in] *pSrcA points to the first input sequence.
03081    * @param[in] srcALen length of the first input sequence.
03082    * @param[in] *pSrcB points to the second input sequence.
03083    * @param[in] srcBLen length of the second input sequence.
03084    * @param[out] *pDst points to the block of output data  Length srcALen+srcBLen-1.
03085    * @param[in]  *pScratch1 points to scratch buffer of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2.
03086    * @param[in]  *pScratch2 points to scratch buffer of size min(srcALen, srcBLen).
03087    * @return none.
03088    */
03089 
03090 
03091   void arm_conv_opt_q15(
03092   q15_t * pSrcA,
03093   uint32_t srcALen,
03094   q15_t * pSrcB,
03095   uint32_t srcBLen,
03096   q15_t * pDst,
03097   q15_t * pScratch1,
03098   q15_t * pScratch2);
03099 
03100 
03101 /**
03102  * @brief Convolution of Q15 sequences.
03103  * @param[in] *pSrcA points to the first input sequence.
03104  * @param[in] srcALen length of the first input sequence.
03105  * @param[in] *pSrcB points to the second input sequence.
03106  * @param[in] srcBLen length of the second input sequence.
03107  * @param[out] *pDst points to the location where the output result is written.  Length srcALen+srcBLen-1.
03108  * @return none.
03109  */
03110 
03111   void arm_conv_q15(
03112   q15_t * pSrcA,
03113   uint32_t srcALen,
03114   q15_t * pSrcB,
03115   uint32_t srcBLen,
03116   q15_t * pDst);
03117 
03118   /**
03119    * @brief Convolution of Q15 sequences (fast version) for Cortex-M3 and Cortex-M4
03120    * @param[in] *pSrcA points to the first input sequence.
03121    * @param[in] srcALen length of the first input sequence.
03122    * @param[in] *pSrcB points to the second input sequence.
03123    * @param[in] srcBLen length of the second input sequence.
03124    * @param[out] *pDst points to the block of output data  Length srcALen+srcBLen-1.
03125    * @return none.
03126    */
03127 
03128   void arm_conv_fast_q15(
03129               q15_t * pSrcA,
03130              uint32_t srcALen,
03131               q15_t * pSrcB,
03132              uint32_t srcBLen,
03133              q15_t * pDst);
03134 
03135   /**
03136    * @brief Convolution of Q15 sequences (fast version) for Cortex-M3 and Cortex-M4
03137    * @param[in] *pSrcA points to the first input sequence.
03138    * @param[in] srcALen length of the first input sequence.
03139    * @param[in] *pSrcB points to the second input sequence.
03140    * @param[in] srcBLen length of the second input sequence.
03141    * @param[out] *pDst points to the block of output data  Length srcALen+srcBLen-1.
03142    * @param[in]  *pScratch1 points to scratch buffer of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2.
03143    * @param[in]  *pScratch2 points to scratch buffer of size min(srcALen, srcBLen).
03144    * @return none.
03145    */
03146 
03147   void arm_conv_fast_opt_q15(
03148   q15_t * pSrcA,
03149   uint32_t srcALen,
03150   q15_t * pSrcB,
03151   uint32_t srcBLen,
03152   q15_t * pDst,
03153   q15_t * pScratch1,
03154   q15_t * pScratch2);
03155 
03156 
03157 
03158   /**
03159    * @brief Convolution of Q31 sequences.
03160    * @param[in] *pSrcA points to the first input sequence.
03161    * @param[in] srcALen length of the first input sequence.
03162    * @param[in] *pSrcB points to the second input sequence.
03163    * @param[in] srcBLen length of the second input sequence.
03164    * @param[out] *pDst points to the block of output data  Length srcALen+srcBLen-1.
03165    * @return none.
03166    */
03167 
03168   void arm_conv_q31(
03169   q31_t * pSrcA,
03170   uint32_t srcALen,
03171   q31_t * pSrcB,
03172   uint32_t srcBLen,
03173   q31_t * pDst);
03174 
03175   /**
03176    * @brief Convolution of Q31 sequences (fast version) for Cortex-M3 and Cortex-M4
03177    * @param[in] *pSrcA points to the first input sequence.
03178    * @param[in] srcALen length of the first input sequence.
03179    * @param[in] *pSrcB points to the second input sequence.
03180    * @param[in] srcBLen length of the second input sequence.
03181    * @param[out] *pDst points to the block of output data  Length srcALen+srcBLen-1.
03182    * @return none.
03183    */
03184 
03185   void arm_conv_fast_q31(
03186   q31_t * pSrcA,
03187   uint32_t srcALen,
03188   q31_t * pSrcB,
03189   uint32_t srcBLen,
03190   q31_t * pDst);
03191 
03192 
03193     /**
03194    * @brief Convolution of Q7 sequences.
03195    * @param[in] *pSrcA points to the first input sequence.
03196    * @param[in] srcALen length of the first input sequence.
03197    * @param[in] *pSrcB points to the second input sequence.
03198    * @param[in] srcBLen length of the second input sequence.
03199    * @param[out] *pDst points to the block of output data  Length srcALen+srcBLen-1.
03200    * @param[in]  *pScratch1 points to scratch buffer(of type q15_t) of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2.
03201    * @param[in]  *pScratch2 points to scratch buffer (of type q15_t) of size min(srcALen, srcBLen).
03202    * @return none.
03203    */
03204 
03205   void arm_conv_opt_q7(
03206   q7_t * pSrcA,
03207   uint32_t srcALen,
03208   q7_t * pSrcB,
03209   uint32_t srcBLen,
03210   q7_t * pDst,
03211   q15_t * pScratch1,
03212   q15_t * pScratch2);
03213 
03214 
03215 
03216   /**
03217    * @brief Convolution of Q7 sequences.
03218    * @param[in] *pSrcA points to the first input sequence.
03219    * @param[in] srcALen length of the first input sequence.
03220    * @param[in] *pSrcB points to the second input sequence.
03221    * @param[in] srcBLen length of the second input sequence.
03222    * @param[out] *pDst points to the block of output data  Length srcALen+srcBLen-1.
03223    * @return none.
03224    */
03225 
03226   void arm_conv_q7(
03227   q7_t * pSrcA,
03228   uint32_t srcALen,
03229   q7_t * pSrcB,
03230   uint32_t srcBLen,
03231   q7_t * pDst);
03232 
03233 
03234   /**
03235    * @brief Partial convolution of floating-point sequences.
03236    * @param[in]       *pSrcA points to the first input sequence.
03237    * @param[in]       srcALen length of the first input sequence.
03238    * @param[in]       *pSrcB points to the second input sequence.
03239    * @param[in]       srcBLen length of the second input sequence.
03240    * @param[out]      *pDst points to the block of output data
03241    * @param[in]       firstIndex is the first output sample to start with.
03242    * @param[in]       numPoints is the number of output points to be computed.
03243    * @return  Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2].
03244    */
03245 
03246   arm_status arm_conv_partial_f32(
03247   float32_t * pSrcA,
03248   uint32_t srcALen,
03249   float32_t * pSrcB,
03250   uint32_t srcBLen,
03251   float32_t * pDst,
03252   uint32_t firstIndex,
03253   uint32_t numPoints);
03254 
03255     /**
03256    * @brief Partial convolution of Q15 sequences.
03257    * @param[in]       *pSrcA points to the first input sequence.
03258    * @param[in]       srcALen length of the first input sequence.
03259    * @param[in]       *pSrcB points to the second input sequence.
03260    * @param[in]       srcBLen length of the second input sequence.
03261    * @param[out]      *pDst points to the block of output data
03262    * @param[in]       firstIndex is the first output sample to start with.
03263    * @param[in]       numPoints is the number of output points to be computed.
03264    * @param[in]       * pScratch1 points to scratch buffer of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2.
03265    * @param[in]       * pScratch2 points to scratch buffer of size min(srcALen, srcBLen).
03266    * @return  Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2].
03267    */
03268 
03269   arm_status arm_conv_partial_opt_q15(
03270   q15_t * pSrcA,
03271   uint32_t srcALen,
03272   q15_t * pSrcB,
03273   uint32_t srcBLen,
03274   q15_t * pDst,
03275   uint32_t firstIndex,
03276   uint32_t numPoints,
03277   q15_t * pScratch1,
03278   q15_t * pScratch2);
03279 
03280 
03281 /**
03282    * @brief Partial convolution of Q15 sequences.
03283    * @param[in]       *pSrcA points to the first input sequence.
03284    * @param[in]       srcALen length of the first input sequence.
03285    * @param[in]       *pSrcB points to the second input sequence.
03286    * @param[in]       srcBLen length of the second input sequence.
03287    * @param[out]      *pDst points to the block of output data
03288    * @param[in]       firstIndex is the first output sample to start with.
03289    * @param[in]       numPoints is the number of output points to be computed.
03290    * @return  Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2].
03291    */
03292 
03293   arm_status arm_conv_partial_q15(
03294   q15_t * pSrcA,
03295   uint32_t srcALen,
03296   q15_t * pSrcB,
03297   uint32_t srcBLen,
03298   q15_t * pDst,
03299   uint32_t firstIndex,
03300   uint32_t numPoints);
03301 
03302   /**
03303    * @brief Partial convolution of Q15 sequences (fast version) for Cortex-M3 and Cortex-M4
03304    * @param[in]       *pSrcA points to the first input sequence.
03305    * @param[in]       srcALen length of the first input sequence.
03306    * @param[in]       *pSrcB points to the second input sequence.
03307    * @param[in]       srcBLen length of the second input sequence.
03308    * @param[out]      *pDst points to the block of output data
03309    * @param[in]       firstIndex is the first output sample to start with.
03310    * @param[in]       numPoints is the number of output points to be computed.
03311    * @return  Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2].
03312    */
03313 
03314   arm_status arm_conv_partial_fast_q15(
03315                         q15_t * pSrcA,
03316                        uint32_t srcALen,
03317                         q15_t * pSrcB,
03318                        uint32_t srcBLen,
03319                        q15_t * pDst,
03320                        uint32_t firstIndex,
03321                        uint32_t numPoints);
03322 
03323 
03324   /**
03325    * @brief Partial convolution of Q15 sequences (fast version) for Cortex-M3 and Cortex-M4
03326    * @param[in]       *pSrcA points to the first input sequence.
03327    * @param[in]       srcALen length of the first input sequence.
03328    * @param[in]       *pSrcB points to the second input sequence.
03329    * @param[in]       srcBLen length of the second input sequence.
03330    * @param[out]      *pDst points to the block of output data
03331    * @param[in]       firstIndex is the first output sample to start with.
03332    * @param[in]       numPoints is the number of output points to be computed.
03333    * @param[in]       * pScratch1 points to scratch buffer of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2.
03334    * @param[in]       * pScratch2 points to scratch buffer of size min(srcALen, srcBLen).
03335    * @return  Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2].
03336    */
03337 
03338   arm_status arm_conv_partial_fast_opt_q15(
03339   q15_t * pSrcA,
03340   uint32_t srcALen,
03341   q15_t * pSrcB,
03342   uint32_t srcBLen,
03343   q15_t * pDst,
03344   uint32_t firstIndex,
03345   uint32_t numPoints,
03346   q15_t * pScratch1,
03347   q15_t * pScratch2);
03348 
03349 
03350   /**
03351    * @brief Partial convolution of Q31 sequences.
03352    * @param[in]       *pSrcA points to the first input sequence.
03353    * @param[in]       srcALen length of the first input sequence.
03354    * @param[in]       *pSrcB points to the second input sequence.
03355    * @param[in]       srcBLen length of the second input sequence.
03356    * @param[out]      *pDst points to the block of output data
03357    * @param[in]       firstIndex is the first output sample to start with.
03358    * @param[in]       numPoints is the number of output points to be computed.
03359    * @return  Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2].
03360    */
03361 
03362   arm_status arm_conv_partial_q31(
03363   q31_t * pSrcA,
03364   uint32_t srcALen,
03365   q31_t * pSrcB,
03366   uint32_t srcBLen,
03367   q31_t * pDst,
03368   uint32_t firstIndex,
03369   uint32_t numPoints);
03370 
03371 
03372   /**
03373    * @brief Partial convolution of Q31 sequences (fast version) for Cortex-M3 and Cortex-M4
03374    * @param[in]       *pSrcA points to the first input sequence.
03375    * @param[in]       srcALen length of the first input sequence.
03376    * @param[in]       *pSrcB points to the second input sequence.
03377    * @param[in]       srcBLen length of the second input sequence.
03378    * @param[out]      *pDst points to the block of output data
03379    * @param[in]       firstIndex is the first output sample to start with.
03380    * @param[in]       numPoints is the number of output points to be computed.
03381    * @return  Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2].
03382    */
03383 
03384   arm_status arm_conv_partial_fast_q31(
03385   q31_t * pSrcA,
03386   uint32_t srcALen,
03387   q31_t * pSrcB,
03388   uint32_t srcBLen,
03389   q31_t * pDst,
03390   uint32_t firstIndex,
03391   uint32_t numPoints);
03392 
03393 
03394   /**
03395    * @brief Partial convolution of Q7 sequences
03396    * @param[in]       *pSrcA points to the first input sequence.
03397    * @param[in]       srcALen length of the first input sequence.
03398    * @param[in]       *pSrcB points to the second input sequence.
03399    * @param[in]       srcBLen length of the second input sequence.
03400    * @param[out]      *pDst points to the block of output data
03401    * @param[in]       firstIndex is the first output sample to start with.
03402    * @param[in]       numPoints is the number of output points to be computed.
03403    * @param[in]  *pScratch1 points to scratch buffer(of type q15_t) of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2.
03404    * @param[in]  *pScratch2 points to scratch buffer (of type q15_t) of size min(srcALen, srcBLen).
03405    * @return  Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2].
03406    */
03407 
03408   arm_status arm_conv_partial_opt_q7(
03409   q7_t * pSrcA,
03410   uint32_t srcALen,
03411   q7_t * pSrcB,
03412   uint32_t srcBLen,
03413   q7_t * pDst,
03414   uint32_t firstIndex,
03415   uint32_t numPoints,
03416   q15_t * pScratch1,
03417   q15_t * pScratch2);
03418 
03419 
03420 /**
03421    * @brief Partial convolution of Q7 sequences.
03422    * @param[in]       *pSrcA points to the first input sequence.
03423    * @param[in]       srcALen length of the first input sequence.
03424    * @param[in]       *pSrcB points to the second input sequence.
03425    * @param[in]       srcBLen length of the second input sequence.
03426    * @param[out]      *pDst points to the block of output data
03427    * @param[in]       firstIndex is the first output sample to start with.
03428    * @param[in]       numPoints is the number of output points to be computed.
03429    * @return  Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2].
03430    */
03431 
03432   arm_status arm_conv_partial_q7(
03433   q7_t * pSrcA,
03434   uint32_t srcALen,
03435   q7_t * pSrcB,
03436   uint32_t srcBLen,
03437   q7_t * pDst,
03438   uint32_t firstIndex,
03439   uint32_t numPoints);
03440 
03441 
03442 
03443   /**
03444    * @brief Instance structure for the Q15 FIR decimator.
03445    */
03446 
03447   typedef struct
03448   {
03449     uint8_t M;                      /**< decimation factor. */
03450     uint16_t numTaps;               /**< number of coefficients in the filter. */
03451     q15_t *pCoeffs;                  /**< points to the coefficient array. The array is of length numTaps.*/
03452     q15_t *pState;                   /**< points to the state variable array. The array is of length numTaps+blockSize-1. */
03453   } arm_fir_decimate_instance_q15;
03454 
03455   /**
03456    * @brief Instance structure for the Q31 FIR decimator.
03457    */
03458 
03459   typedef struct
03460   {
03461     uint8_t M;                  /**< decimation factor. */
03462     uint16_t numTaps;           /**< number of coefficients in the filter. */
03463     q31_t *pCoeffs;              /**< points to the coefficient array. The array is of length numTaps.*/
03464     q31_t *pState;               /**< points to the state variable array. The array is of length numTaps+blockSize-1. */
03465 
03466   } arm_fir_decimate_instance_q31;
03467 
03468   /**
03469    * @brief Instance structure for the floating-point FIR decimator.
03470    */
03471 
03472   typedef struct
03473   {
03474     uint8_t M;                          /**< decimation factor. */
03475     uint16_t numTaps;                   /**< number of coefficients in the filter. */
03476     float32_t *pCoeffs;                  /**< points to the coefficient array. The array is of length numTaps.*/
03477     float32_t *pState;                   /**< points to the state variable array. The array is of length numTaps+blockSize-1. */
03478 
03479   } arm_fir_decimate_instance_f32;
03480 
03481 
03482 
03483   /**
03484    * @brief Processing function for the floating-point FIR decimator.
03485    * @param[in] *S points to an instance of the floating-point FIR decimator structure.
03486    * @param[in] *pSrc points to the block of input data.
03487    * @param[out] *pDst points to the block of output data
03488    * @param[in] blockSize number of input samples to process per call.
03489    * @return none
03490    */
03491 
03492   void arm_fir_decimate_f32(
03493   const arm_fir_decimate_instance_f32 * S,
03494   float32_t * pSrc,
03495   float32_t * pDst,
03496   uint32_t blockSize);
03497 
03498 
03499   /**
03500    * @brief  Initialization function for the floating-point FIR decimator.
03501    * @param[in,out] *S points to an instance of the floating-point FIR decimator structure.
03502    * @param[in] numTaps  number of coefficients in the filter.
03503    * @param[in] M  decimation factor.
03504    * @param[in] *pCoeffs points to the filter coefficients.
03505    * @param[in] *pState points to the state buffer.
03506    * @param[in] blockSize number of input samples to process per call.
03507    * @return    The function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_LENGTH_ERROR if
03508    * <code>blockSize</code> is not a multiple of <code>M</code>.
03509    */
03510 
03511   arm_status arm_fir_decimate_init_f32(
03512   arm_fir_decimate_instance_f32 * S,
03513   uint16_t numTaps,
03514   uint8_t M,
03515   float32_t * pCoeffs,
03516   float32_t * pState,
03517   uint32_t blockSize);
03518 
03519   /**
03520    * @brief Processing function for the Q15 FIR decimator.
03521    * @param[in] *S points to an instance of the Q15 FIR decimator structure.
03522    * @param[in] *pSrc points to the block of input data.
03523    * @param[out] *pDst points to the block of output data
03524    * @param[in] blockSize number of input samples to process per call.
03525    * @return none
03526    */
03527 
03528   void arm_fir_decimate_q15(
03529   const arm_fir_decimate_instance_q15 * S,
03530   q15_t * pSrc,
03531   q15_t * pDst,
03532   uint32_t blockSize);
03533 
03534   /**
03535    * @brief Processing function for the Q15 FIR decimator (fast variant) for Cortex-M3 and Cortex-M4.
03536    * @param[in] *S points to an instance of the Q15 FIR decimator structure.
03537    * @param[in] *pSrc points to the block of input data.
03538    * @param[out] *pDst points to the block of output data
03539    * @param[in] blockSize number of input samples to process per call.
03540    * @return none
03541    */
03542 
03543   void arm_fir_decimate_fast_q15(
03544   const arm_fir_decimate_instance_q15 * S,
03545   q15_t * pSrc,
03546   q15_t * pDst,
03547   uint32_t blockSize);
03548 
03549 
03550 
03551   /**
03552    * @brief  Initialization function for the Q15 FIR decimator.
03553    * @param[in,out] *S points to an instance of the Q15 FIR decimator structure.
03554    * @param[in] numTaps  number of coefficients in the filter.
03555    * @param[in] M  decimation factor.
03556    * @param[in] *pCoeffs points to the filter coefficients.
03557    * @param[in] *pState points to the state buffer.
03558    * @param[in] blockSize number of input samples to process per call.
03559    * @return    The function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_LENGTH_ERROR if
03560    * <code>blockSize</code> is not a multiple of <code>M</code>.
03561    */
03562 
03563   arm_status arm_fir_decimate_init_q15(
03564   arm_fir_decimate_instance_q15 * S,
03565   uint16_t numTaps,
03566   uint8_t M,
03567   q15_t * pCoeffs,
03568   q15_t * pState,
03569   uint32_t blockSize);
03570 
03571   /**
03572    * @brief Processing function for the Q31 FIR decimator.
03573    * @param[in] *S points to an instance of the Q31 FIR decimator structure.
03574    * @param[in] *pSrc points to the block of input data.
03575    * @param[out] *pDst points to the block of output data
03576    * @param[in] blockSize number of input samples to process per call.
03577    * @return none
03578    */
03579 
03580   void arm_fir_decimate_q31(
03581   const arm_fir_decimate_instance_q31 * S,
03582   q31_t * pSrc,
03583   q31_t * pDst,
03584   uint32_t blockSize);
03585 
03586   /**
03587    * @brief Processing function for the Q31 FIR decimator (fast variant) for Cortex-M3 and Cortex-M4.
03588    * @param[in] *S points to an instance of the Q31 FIR decimator structure.
03589    * @param[in] *pSrc points to the block of input data.
03590    * @param[out] *pDst points to the block of output data
03591    * @param[in] blockSize number of input samples to process per call.
03592    * @return none
03593    */
03594 
03595   void arm_fir_decimate_fast_q31(
03596   arm_fir_decimate_instance_q31 * S,
03597   q31_t * pSrc,
03598   q31_t * pDst,
03599   uint32_t blockSize);
03600 
03601 
03602   /**
03603    * @brief  Initialization function for the Q31 FIR decimator.
03604    * @param[in,out] *S points to an instance of the Q31 FIR decimator structure.
03605    * @param[in] numTaps  number of coefficients in the filter.
03606    * @param[in] M  decimation factor.
03607    * @param[in] *pCoeffs points to the filter coefficients.
03608    * @param[in] *pState points to the state buffer.
03609    * @param[in] blockSize number of input samples to process per call.
03610    * @return    The function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_LENGTH_ERROR if
03611    * <code>blockSize</code> is not a multiple of <code>M</code>.
03612    */
03613 
03614   arm_status arm_fir_decimate_init_q31(
03615   arm_fir_decimate_instance_q31 * S,
03616   uint16_t numTaps,
03617   uint8_t M,
03618   q31_t * pCoeffs,
03619   q31_t * pState,
03620   uint32_t blockSize);
03621 
03622 
03623 
03624   /**
03625    * @brief Instance structure for the Q15 FIR interpolator.
03626    */
03627 
03628   typedef struct
03629   {
03630     uint8_t L;                      /**< upsample factor. */
03631     uint16_t phaseLength;           /**< length of each polyphase filter component. */
03632     q15_t *pCoeffs;                 /**< points to the coefficient array. The array is of length L*phaseLength. */
03633     q15_t *pState;                  /**< points to the state variable array. The array is of length blockSize+phaseLength-1. */
03634   } arm_fir_interpolate_instance_q15;
03635 
03636   /**
03637    * @brief Instance structure for the Q31 FIR interpolator.
03638    */
03639 
03640   typedef struct
03641   {
03642     uint8_t L;                      /**< upsample factor. */
03643     uint16_t phaseLength;           /**< length of each polyphase filter component. */
03644     q31_t *pCoeffs;                  /**< points to the coefficient array. The array is of length L*phaseLength. */
03645     q31_t *pState;                   /**< points to the state variable array. The array is of length blockSize+phaseLength-1. */
03646   } arm_fir_interpolate_instance_q31;
03647 
03648   /**
03649    * @brief Instance structure for the floating-point FIR interpolator.
03650    */
03651 
03652   typedef struct
03653   {
03654     uint8_t L;                     /**< upsample factor. */
03655     uint16_t phaseLength;          /**< length of each polyphase filter component. */
03656     float32_t *pCoeffs;             /**< points to the coefficient array. The array is of length L*phaseLength. */
03657     float32_t *pState;              /**< points to the state variable array. The array is of length phaseLength+numTaps-1. */
03658   } arm_fir_interpolate_instance_f32;
03659 
03660 
03661   /**
03662    * @brief Processing function for the Q15 FIR interpolator.
03663    * @param[in] *S        points to an instance of the Q15 FIR interpolator structure.
03664    * @param[in] *pSrc     points to the block of input data.
03665    * @param[out] *pDst    points to the block of output data.
03666    * @param[in] blockSize number of input samples to process per call.
03667    * @return none.
03668    */
03669 
03670   void arm_fir_interpolate_q15(
03671   const arm_fir_interpolate_instance_q15 * S,
03672   q15_t * pSrc,
03673   q15_t * pDst,
03674   uint32_t blockSize);
03675 
03676 
03677   /**
03678    * @brief  Initialization function for the Q15 FIR interpolator.
03679    * @param[in,out] *S        points to an instance of the Q15 FIR interpolator structure.
03680    * @param[in]     L         upsample factor.
03681    * @param[in]     numTaps   number of filter coefficients in the filter.
03682    * @param[in]     *pCoeffs  points to the filter coefficient buffer.
03683    * @param[in]     *pState   points to the state buffer.
03684    * @param[in]     blockSize number of input samples to process per call.
03685    * @return        The function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_LENGTH_ERROR if
03686    * the filter length <code>numTaps</code> is not a multiple of the interpolation factor <code>L</code>.
03687    */
03688 
03689   arm_status arm_fir_interpolate_init_q15(
03690   arm_fir_interpolate_instance_q15 * S,
03691   uint8_t L,
03692   uint16_t numTaps,
03693   q15_t * pCoeffs,
03694   q15_t * pState,
03695   uint32_t blockSize);
03696 
03697   /**
03698    * @brief Processing function for the Q31 FIR interpolator.
03699    * @param[in] *S        points to an instance of the Q15 FIR interpolator structure.
03700    * @param[in] *pSrc     points to the block of input data.
03701    * @param[out] *pDst    points to the block of output data.
03702    * @param[in] blockSize number of input samples to process per call.
03703    * @return none.
03704    */
03705 
03706   void arm_fir_interpolate_q31(
03707   const arm_fir_interpolate_instance_q31 * S,
03708   q31_t * pSrc,
03709   q31_t * pDst,
03710   uint32_t blockSize);
03711 
03712   /**
03713    * @brief  Initialization function for the Q31 FIR interpolator.
03714    * @param[in,out] *S        points to an instance of the Q31 FIR interpolator structure.
03715    * @param[in]     L         upsample factor.
03716    * @param[in]     numTaps   number of filter coefficients in the filter.
03717    * @param[in]     *pCoeffs  points to the filter coefficient buffer.
03718    * @param[in]     *pState   points to the state buffer.
03719    * @param[in]     blockSize number of input samples to process per call.
03720    * @return        The function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_LENGTH_ERROR if
03721    * the filter length <code>numTaps</code> is not a multiple of the interpolation factor <code>L</code>.
03722    */
03723 
03724   arm_status arm_fir_interpolate_init_q31(
03725   arm_fir_interpolate_instance_q31 * S,
03726   uint8_t L,
03727   uint16_t numTaps,
03728   q31_t * pCoeffs,
03729   q31_t * pState,
03730   uint32_t blockSize);
03731 
03732 
03733   /**
03734    * @brief Processing function for the floating-point FIR interpolator.
03735    * @param[in] *S        points to an instance of the floating-point FIR interpolator structure.
03736    * @param[in] *pSrc     points to the block of input data.
03737    * @param[out] *pDst    points to the block of output data.
03738    * @param[in] blockSize number of input samples to process per call.
03739    * @return none.
03740    */
03741 
03742   void arm_fir_interpolate_f32(
03743   const arm_fir_interpolate_instance_f32 * S,
03744   float32_t * pSrc,
03745   float32_t * pDst,
03746   uint32_t blockSize);
03747 
03748   /**
03749    * @brief  Initialization function for the floating-point FIR interpolator.
03750    * @param[in,out] *S        points to an instance of the floating-point FIR interpolator structure.
03751    * @param[in]     L         upsample factor.
03752    * @param[in]     numTaps   number of filter coefficients in the filter.
03753    * @param[in]     *pCoeffs  points to the filter coefficient buffer.
03754    * @param[in]     *pState   points to the state buffer.
03755    * @param[in]     blockSize number of input samples to process per call.
03756    * @return        The function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_LENGTH_ERROR if
03757    * the filter length <code>numTaps</code> is not a multiple of the interpolation factor <code>L</code>.
03758    */
03759 
03760   arm_status arm_fir_interpolate_init_f32(
03761   arm_fir_interpolate_instance_f32 * S,
03762   uint8_t L,
03763   uint16_t numTaps,
03764   float32_t * pCoeffs,
03765   float32_t * pState,
03766   uint32_t blockSize);
03767 
03768   /**
03769    * @brief Instance structure for the high precision Q31 Biquad cascade filter.
03770    */
03771 
03772   typedef struct
03773   {
03774     uint8_t numStages;       /**< number of 2nd order stages in the filter.  Overall order is 2*numStages. */
03775     q63_t *pState;           /**< points to the array of state coefficients.  The array is of length 4*numStages. */
03776     q31_t *pCoeffs;          /**< points to the array of coefficients.  The array is of length 5*numStages. */
03777     uint8_t postShift;       /**< additional shift, in bits, applied to each output sample. */
03778 
03779   } arm_biquad_cas_df1_32x64_ins_q31;
03780 
03781 
03782   /**
03783    * @param[in]  *S        points to an instance of the high precision Q31 Biquad cascade filter structure.
03784    * @param[in]  *pSrc     points to the block of input data.
03785    * @param[out] *pDst     points to the block of output data
03786    * @param[in]  blockSize number of samples to process.
03787    * @return none.
03788    */
03789 
03790   void arm_biquad_cas_df1_32x64_q31(
03791   const arm_biquad_cas_df1_32x64_ins_q31 * S,
03792   q31_t * pSrc,
03793   q31_t * pDst,
03794   uint32_t blockSize);
03795 
03796 
03797   /**
03798    * @param[in,out] *S           points to an instance of the high precision Q31 Biquad cascade filter structure.
03799    * @param[in]     numStages    number of 2nd order stages in the filter.
03800    * @param[in]     *pCoeffs     points to the filter coefficients.
03801    * @param[in]     *pState      points to the state buffer.
03802    * @param[in]     postShift    shift to be applied to the output. Varies according to the coefficients format
03803    * @return        none
03804    */
03805 
03806   void arm_biquad_cas_df1_32x64_init_q31(
03807   arm_biquad_cas_df1_32x64_ins_q31 * S,
03808   uint8_t numStages,
03809   q31_t * pCoeffs,
03810   q63_t * pState,
03811   uint8_t postShift);
03812 
03813 
03814 
03815   /**
03816    * @brief Instance structure for the floating-point transposed direct form II Biquad cascade filter.
03817    */
03818 
03819   typedef struct
03820   {
03821     uint8_t numStages;         /**< number of 2nd order stages in the filter.  Overall order is 2*numStages. */
03822     float32_t *pState;         /**< points to the array of state coefficients.  The array is of length 2*numStages. */
03823     float32_t *pCoeffs;        /**< points to the array of coefficients.  The array is of length 5*numStages. */
03824   } arm_biquad_cascade_df2T_instance_f32;
03825 
03826 
03827 
03828   /**
03829    * @brief Instance structure for the floating-point transposed direct form II Biquad cascade filter.
03830    */
03831 
03832   typedef struct
03833   {
03834     uint8_t numStages;         /**< number of 2nd order stages in the filter.  Overall order is 2*numStages. */
03835     float32_t *pState;         /**< points to the array of state coefficients.  The array is of length 4*numStages. */
03836     float32_t *pCoeffs;        /**< points to the array of coefficients.  The array is of length 5*numStages. */
03837   } arm_biquad_cascade_stereo_df2T_instance_f32;
03838 
03839 
03840 
03841   /**
03842    * @brief Instance structure for the floating-point transposed direct form II Biquad cascade filter.
03843    */
03844 
03845   typedef struct
03846   {
03847     uint8_t numStages;         /**< number of 2nd order stages in the filter.  Overall order is 2*numStages. */
03848     float64_t *pState;         /**< points to the array of state coefficients.  The array is of length 2*numStages. */
03849     float64_t *pCoeffs;        /**< points to the array of coefficients.  The array is of length 5*numStages. */
03850   } arm_biquad_cascade_df2T_instance_f64;
03851 
03852 
03853   /**
03854    * @brief Processing function for the floating-point transposed direct form II Biquad cascade filter.
03855    * @param[in]  *S        points to an instance of the filter data structure.
03856    * @param[in]  *pSrc     points to the block of input data.
03857    * @param[out] *pDst     points to the block of output data
03858    * @param[in]  blockSize number of samples to process.
03859    * @return none.
03860    */
03861 
03862   void arm_biquad_cascade_df2T_f32(
03863   const arm_biquad_cascade_df2T_instance_f32 * S,
03864   float32_t * pSrc,
03865   float32_t * pDst,
03866   uint32_t blockSize);
03867 
03868 
03869   /**
03870    * @brief Processing function for the floating-point transposed direct form II Biquad cascade filter. 2 channels
03871    * @param[in]  *S        points to an instance of the filter data structure.
03872    * @param[in]  *pSrc     points to the block of input data.
03873    * @param[out] *pDst     points to the block of output data
03874    * @param[in]  blockSize number of samples to process.
03875    * @return none.
03876    */
03877 
03878   void arm_biquad_cascade_stereo_df2T_f32(
03879   const arm_biquad_cascade_stereo_df2T_instance_f32 * S,
03880   float32_t * pSrc,
03881   float32_t * pDst,
03882   uint32_t blockSize);
03883 
03884   /**
03885    * @brief Processing function for the floating-point transposed direct form II Biquad cascade filter.
03886    * @param[in]  *S        points to an instance of the filter data structure.
03887    * @param[in]  *pSrc     points to the block of input data.
03888    * @param[out] *pDst     points to the block of output data
03889    * @param[in]  blockSize number of samples to process.
03890    * @return none.
03891    */
03892 
03893   void arm_biquad_cascade_df2T_f64(
03894   const arm_biquad_cascade_df2T_instance_f64 * S,
03895   float64_t * pSrc,
03896   float64_t * pDst,
03897   uint32_t blockSize);
03898 
03899 
03900   /**
03901    * @brief  Initialization function for the floating-point transposed direct form II Biquad cascade filter.
03902    * @param[in,out] *S           points to an instance of the filter data structure.
03903    * @param[in]     numStages    number of 2nd order stages in the filter.
03904    * @param[in]     *pCoeffs     points to the filter coefficients.
03905    * @param[in]     *pState      points to the state buffer.
03906    * @return        none
03907    */
03908 
03909   void arm_biquad_cascade_df2T_init_f32(
03910   arm_biquad_cascade_df2T_instance_f32 * S,
03911   uint8_t numStages,
03912   float32_t * pCoeffs,
03913   float32_t * pState);
03914 
03915 
03916   /**
03917    * @brief  Initialization function for the floating-point transposed direct form II Biquad cascade filter.
03918    * @param[in,out] *S           points to an instance of the filter data structure.
03919    * @param[in]     numStages    number of 2nd order stages in the filter.
03920    * @param[in]     *pCoeffs     points to the filter coefficients.
03921    * @param[in]     *pState      points to the state buffer.
03922    * @return        none
03923    */
03924 
03925   void arm_biquad_cascade_stereo_df2T_init_f32(
03926   arm_biquad_cascade_stereo_df2T_instance_f32 * S,
03927   uint8_t numStages,
03928   float32_t * pCoeffs,
03929   float32_t * pState);
03930 
03931 
03932   /**
03933    * @brief  Initialization function for the floating-point transposed direct form II Biquad cascade filter.
03934    * @param[in,out] *S           points to an instance of the filter data structure.
03935    * @param[in]     numStages    number of 2nd order stages in the filter.
03936    * @param[in]     *pCoeffs     points to the filter coefficients.
03937    * @param[in]     *pState      points to the state buffer.
03938    * @return        none
03939    */
03940 
03941   void arm_biquad_cascade_df2T_init_f64(
03942   arm_biquad_cascade_df2T_instance_f64 * S,
03943   uint8_t numStages,
03944   float64_t * pCoeffs,
03945   float64_t * pState);
03946 
03947 
03948 
03949   /**
03950    * @brief Instance structure for the Q15 FIR lattice filter.
03951    */
03952 
03953   typedef struct
03954   {
03955     uint16_t numStages;                          /**< number of filter stages. */
03956     q15_t *pState;                               /**< points to the state variable array. The array is of length numStages. */
03957     q15_t *pCoeffs;                              /**< points to the coefficient array. The array is of length numStages. */
03958   } arm_fir_lattice_instance_q15;
03959 
03960   /**
03961    * @brief Instance structure for the Q31 FIR lattice filter.
03962    */
03963 
03964   typedef struct
03965   {
03966     uint16_t numStages;                          /**< number of filter stages. */
03967     q31_t *pState;                               /**< points to the state variable array. The array is of length numStages. */
03968     q31_t *pCoeffs;                              /**< points to the coefficient array. The array is of length numStages. */
03969   } arm_fir_lattice_instance_q31;
03970 
03971   /**
03972    * @brief Instance structure for the floating-point FIR lattice filter.
03973    */
03974 
03975   typedef struct
03976   {
03977     uint16_t numStages;                  /**< number of filter stages. */
03978     float32_t *pState;                   /**< points to the state variable array. The array is of length numStages. */
03979     float32_t *pCoeffs;                  /**< points to the coefficient array. The array is of length numStages. */
03980   } arm_fir_lattice_instance_f32;
03981 
03982   /**
03983    * @brief Initialization function for the Q15 FIR lattice filter.
03984    * @param[in] *S points to an instance of the Q15 FIR lattice structure.
03985    * @param[in] numStages  number of filter stages.
03986    * @param[in] *pCoeffs points to the coefficient buffer.  The array is of length numStages.
03987    * @param[in] *pState points to the state buffer.  The array is of length numStages.
03988    * @return none.
03989    */
03990 
03991   void arm_fir_lattice_init_q15(
03992   arm_fir_lattice_instance_q15 * S,
03993   uint16_t numStages,
03994   q15_t * pCoeffs,
03995   q15_t * pState);
03996 
03997 
03998   /**
03999    * @brief Processing function for the Q15 FIR lattice filter.
04000    * @param[in] *S points to an instance of the Q15 FIR lattice structure.
04001    * @param[in] *pSrc points to the block of input data.
04002    * @param[out] *pDst points to the block of output data.
04003    * @param[in] blockSize number of samples to process.
04004    * @return none.
04005    */
04006   void arm_fir_lattice_q15(
04007   const arm_fir_lattice_instance_q15 * S,
04008   q15_t * pSrc,
04009   q15_t * pDst,
04010   uint32_t blockSize);
04011 
04012   /**
04013    * @brief Initialization function for the Q31 FIR lattice filter.
04014    * @param[in] *S points to an instance of the Q31 FIR lattice structure.
04015    * @param[in] numStages  number of filter stages.
04016    * @param[in] *pCoeffs points to the coefficient buffer.  The array is of length numStages.
04017    * @param[in] *pState points to the state buffer.   The array is of length numStages.
04018    * @return none.
04019    */
04020 
04021   void arm_fir_lattice_init_q31(
04022   arm_fir_lattice_instance_q31 * S,
04023   uint16_t numStages,
04024   q31_t * pCoeffs,
04025   q31_t * pState);
04026 
04027 
04028   /**
04029    * @brief Processing function for the Q31 FIR lattice filter.
04030    * @param[in]  *S        points to an instance of the Q31 FIR lattice structure.
04031    * @param[in]  *pSrc     points to the block of input data.
04032    * @param[out] *pDst     points to the block of output data
04033    * @param[in]  blockSize number of samples to process.
04034    * @return none.
04035    */
04036 
04037   void arm_fir_lattice_q31(
04038   const arm_fir_lattice_instance_q31 * S,
04039   q31_t * pSrc,
04040   q31_t * pDst,
04041   uint32_t blockSize);
04042 
04043 /**
04044  * @brief Initialization function for the floating-point FIR lattice filter.
04045  * @param[in] *S points to an instance of the floating-point FIR lattice structure.
04046  * @param[in] numStages  number of filter stages.
04047  * @param[in] *pCoeffs points to the coefficient buffer.  The array is of length numStages.
04048  * @param[in] *pState points to the state buffer.  The array is of length numStages.
04049  * @return none.
04050  */
04051 
04052   void arm_fir_lattice_init_f32(
04053   arm_fir_lattice_instance_f32 * S,
04054   uint16_t numStages,
04055   float32_t * pCoeffs,
04056   float32_t * pState);
04057 
04058   /**
04059    * @brief Processing function for the floating-point FIR lattice filter.
04060    * @param[in]  *S        points to an instance of the floating-point FIR lattice structure.
04061    * @param[in]  *pSrc     points to the block of input data.
04062    * @param[out] *pDst     points to the block of output data
04063    * @param[in]  blockSize number of samples to process.
04064    * @return none.
04065    */
04066 
04067   void arm_fir_lattice_f32(
04068   const arm_fir_lattice_instance_f32 * S,
04069   float32_t * pSrc,
04070   float32_t * pDst,
04071   uint32_t blockSize);
04072 
04073   /**
04074    * @brief Instance structure for the Q15 IIR lattice filter.
04075    */
04076   typedef struct
04077   {
04078     uint16_t numStages;                         /**< number of stages in the filter. */
04079     q15_t *pState;                              /**< points to the state variable array. The array is of length numStages+blockSize. */
04080     q15_t *pkCoeffs;                            /**< points to the reflection coefficient array. The array is of length numStages. */
04081     q15_t *pvCoeffs;                            /**< points to the ladder coefficient array. The array is of length numStages+1. */
04082   } arm_iir_lattice_instance_q15;
04083 
04084   /**
04085    * @brief Instance structure for the Q31 IIR lattice filter.
04086    */
04087   typedef struct
04088   {
04089     uint16_t numStages;                         /**< number of stages in the filter. */
04090     q31_t *pState;                              /**< points to the state variable array. The array is of length numStages+blockSize. */
04091     q31_t *pkCoeffs;                            /**< points to the reflection coefficient array. The array is of length numStages. */
04092     q31_t *pvCoeffs;                            /**< points to the ladder coefficient array. The array is of length numStages+1. */
04093   } arm_iir_lattice_instance_q31;
04094 
04095   /**
04096    * @brief Instance structure for the floating-point IIR lattice filter.
04097    */
04098   typedef struct
04099   {
04100     uint16_t numStages;                         /**< number of stages in the filter. */
04101     float32_t *pState;                          /**< points to the state variable array. The array is of length numStages+blockSize. */
04102     float32_t *pkCoeffs;                        /**< points to the reflection coefficient array. The array is of length numStages. */
04103     float32_t *pvCoeffs;                        /**< points to the ladder coefficient array. The array is of length numStages+1. */
04104   } arm_iir_lattice_instance_f32;
04105 
04106   /**
04107    * @brief Processing function for the floating-point IIR lattice filter.
04108    * @param[in] *S points to an instance of the floating-point IIR lattice structure.
04109    * @param[in] *pSrc points to the block of input data.
04110    * @param[out] *pDst points to the block of output data.
04111    * @param[in] blockSize number of samples to process.
04112    * @return none.
04113    */
04114 
04115   void arm_iir_lattice_f32(
04116   const arm_iir_lattice_instance_f32 * S,
04117   float32_t * pSrc,
04118   float32_t * pDst,
04119   uint32_t blockSize);
04120 
04121   /**
04122    * @brief Initialization function for the floating-point IIR lattice filter.
04123    * @param[in] *S points to an instance of the floating-point IIR lattice structure.
04124    * @param[in] numStages number of stages in the filter.
04125    * @param[in] *pkCoeffs points to the reflection coefficient buffer.  The array is of length numStages.
04126    * @param[in] *pvCoeffs points to the ladder coefficient buffer.  The array is of length numStages+1.
04127    * @param[in] *pState points to the state buffer.  The array is of length numStages+blockSize-1.
04128    * @param[in] blockSize number of samples to process.
04129    * @return none.
04130    */
04131 
04132   void arm_iir_lattice_init_f32(
04133   arm_iir_lattice_instance_f32 * S,
04134   uint16_t numStages,
04135   float32_t * pkCoeffs,
04136   float32_t * pvCoeffs,
04137   float32_t * pState,
04138   uint32_t blockSize);
04139 
04140 
04141   /**
04142    * @brief Processing function for the Q31 IIR lattice filter.
04143    * @param[in] *S points to an instance of the Q31 IIR lattice structure.
04144    * @param[in] *pSrc points to the block of input data.
04145    * @param[out] *pDst points to the block of output data.
04146    * @param[in] blockSize number of samples to process.
04147    * @return none.
04148    */
04149 
04150   void arm_iir_lattice_q31(
04151   const arm_iir_lattice_instance_q31 * S,
04152   q31_t * pSrc,
04153   q31_t * pDst,
04154   uint32_t blockSize);
04155 
04156 
04157   /**
04158    * @brief Initialization function for the Q31 IIR lattice filter.
04159    * @param[in] *S points to an instance of the Q31 IIR lattice structure.
04160    * @param[in] numStages number of stages in the filter.
04161    * @param[in] *pkCoeffs points to the reflection coefficient buffer.  The array is of length numStages.
04162    * @param[in] *pvCoeffs points to the ladder coefficient buffer.  The array is of length numStages+1.
04163    * @param[in] *pState points to the state buffer.  The array is of length numStages+blockSize.
04164    * @param[in] blockSize number of samples to process.
04165    * @return none.
04166    */
04167 
04168   void arm_iir_lattice_init_q31(
04169   arm_iir_lattice_instance_q31 * S,
04170   uint16_t numStages,
04171   q31_t * pkCoeffs,
04172   q31_t * pvCoeffs,
04173   q31_t * pState,
04174   uint32_t blockSize);
04175 
04176 
04177   /**
04178    * @brief Processing function for the Q15 IIR lattice filter.
04179    * @param[in] *S points to an instance of the Q15 IIR lattice structure.
04180    * @param[in] *pSrc points to the block of input data.
04181    * @param[out] *pDst points to the block of output data.
04182    * @param[in] blockSize number of samples to process.
04183    * @return none.
04184    */
04185 
04186   void arm_iir_lattice_q15(
04187   const arm_iir_lattice_instance_q15 * S,
04188   q15_t * pSrc,
04189   q15_t * pDst,
04190   uint32_t blockSize);
04191 
04192 
04193 /**
04194  * @brief Initialization function for the Q15 IIR lattice filter.
04195  * @param[in] *S points to an instance of the fixed-point Q15 IIR lattice structure.
04196  * @param[in] numStages  number of stages in the filter.
04197  * @param[in] *pkCoeffs points to reflection coefficient buffer.  The array is of length numStages.
04198  * @param[in] *pvCoeffs points to ladder coefficient buffer.  The array is of length numStages+1.
04199  * @param[in] *pState points to state buffer.  The array is of length numStages+blockSize.
04200  * @param[in] blockSize number of samples to process per call.
04201  * @return none.
04202  */
04203 
04204   void arm_iir_lattice_init_q15(
04205   arm_iir_lattice_instance_q15 * S,
04206   uint16_t numStages,
04207   q15_t * pkCoeffs,
04208   q15_t * pvCoeffs,
04209   q15_t * pState,
04210   uint32_t blockSize);
04211 
04212   /**
04213    * @brief Instance structure for the floating-point LMS filter.
04214    */
04215 
04216   typedef struct
04217   {
04218     uint16_t numTaps;    /**< number of coefficients in the filter. */
04219     float32_t *pState;   /**< points to the state variable array. The array is of length numTaps+blockSize-1. */
04220     float32_t *pCoeffs;  /**< points to the coefficient array. The array is of length numTaps. */
04221     float32_t mu;        /**< step size that controls filter coefficient updates. */
04222   } arm_lms_instance_f32;
04223 
04224   /**
04225    * @brief Processing function for floating-point LMS filter.
04226    * @param[in]  *S points to an instance of the floating-point LMS filter structure.
04227    * @param[in]  *pSrc points to the block of input data.
04228    * @param[in]  *pRef points to the block of reference data.
04229    * @param[out] *pOut points to the block of output data.
04230    * @param[out] *pErr points to the block of error data.
04231    * @param[in]  blockSize number of samples to process.
04232    * @return     none.
04233    */
04234 
04235   void arm_lms_f32(
04236   const arm_lms_instance_f32 * S,
04237   float32_t * pSrc,
04238   float32_t * pRef,
04239   float32_t * pOut,
04240   float32_t * pErr,
04241   uint32_t blockSize);
04242 
04243   /**
04244    * @brief Initialization function for floating-point LMS filter.
04245    * @param[in] *S points to an instance of the floating-point LMS filter structure.
04246    * @param[in] numTaps  number of filter coefficients.
04247    * @param[in] *pCoeffs points to the coefficient buffer.
04248    * @param[in] *pState points to state buffer.
04249    * @param[in] mu step size that controls filter coefficient updates.
04250    * @param[in] blockSize number of samples to process.
04251    * @return none.
04252    */
04253 
04254   void arm_lms_init_f32(
04255   arm_lms_instance_f32 * S,
04256   uint16_t numTaps,
04257   float32_t * pCoeffs,
04258   float32_t * pState,
04259   float32_t mu,
04260   uint32_t blockSize);
04261 
04262   /**
04263    * @brief Instance structure for the Q15 LMS filter.
04264    */
04265 
04266   typedef struct
04267   {
04268     uint16_t numTaps;    /**< number of coefficients in the filter. */
04269     q15_t *pState;       /**< points to the state variable array. The array is of length numTaps+blockSize-1. */
04270     q15_t *pCoeffs;      /**< points to the coefficient array. The array is of length numTaps. */
04271     q15_t mu;            /**< step size that controls filter coefficient updates. */
04272     uint32_t postShift;  /**< bit shift applied to coefficients. */
04273   } arm_lms_instance_q15;
04274 
04275 
04276   /**
04277    * @brief Initialization function for the Q15 LMS filter.
04278    * @param[in] *S points to an instance of the Q15 LMS filter structure.
04279    * @param[in] numTaps  number of filter coefficients.
04280    * @param[in] *pCoeffs points to the coefficient buffer.
04281    * @param[in] *pState points to the state buffer.
04282    * @param[in] mu step size that controls filter coefficient updates.
04283    * @param[in] blockSize number of samples to process.
04284    * @param[in] postShift bit shift applied to coefficients.
04285    * @return    none.
04286    */
04287 
04288   void arm_lms_init_q15(
04289   arm_lms_instance_q15 * S,
04290   uint16_t numTaps,
04291   q15_t * pCoeffs,
04292   q15_t * pState,
04293   q15_t mu,
04294   uint32_t blockSize,
04295   uint32_t postShift);
04296 
04297   /**
04298    * @brief Processing function for Q15 LMS filter.
04299    * @param[in] *S points to an instance of the Q15 LMS filter structure.
04300    * @param[in] *pSrc points to the block of input data.
04301    * @param[in] *pRef points to the block of reference data.
04302    * @param[out] *pOut points to the block of output data.
04303    * @param[out] *pErr points to the block of error data.
04304    * @param[in] blockSize number of samples to process.
04305    * @return none.
04306    */
04307 
04308   void arm_lms_q15(
04309   const arm_lms_instance_q15 * S,
04310   q15_t * pSrc,
04311   q15_t * pRef,
04312   q15_t * pOut,
04313   q15_t * pErr,
04314   uint32_t blockSize);
04315 
04316 
04317   /**
04318    * @brief Instance structure for the Q31 LMS filter.
04319    */
04320 
04321   typedef struct
04322   {
04323     uint16_t numTaps;    /**< number of coefficients in the filter. */
04324     q31_t *pState;       /**< points to the state variable array. The array is of length numTaps+blockSize-1. */
04325     q31_t *pCoeffs;      /**< points to the coefficient array. The array is of length numTaps. */
04326     q31_t mu;            /**< step size that controls filter coefficient updates. */
04327     uint32_t postShift;  /**< bit shift applied to coefficients. */
04328 
04329   } arm_lms_instance_q31;
04330 
04331   /**
04332    * @brief Processing function for Q31 LMS filter.
04333    * @param[in]  *S points to an instance of the Q15 LMS filter structure.
04334    * @param[in]  *pSrc points to the block of input data.
04335    * @param[in]  *pRef points to the block of reference data.
04336    * @param[out] *pOut points to the block of output data.
04337    * @param[out] *pErr points to the block of error data.
04338    * @param[in]  blockSize number of samples to process.
04339    * @return     none.
04340    */
04341 
04342   void arm_lms_q31(
04343   const arm_lms_instance_q31 * S,
04344   q31_t * pSrc,
04345   q31_t * pRef,
04346   q31_t * pOut,
04347   q31_t * pErr,
04348   uint32_t blockSize);
04349 
04350   /**
04351    * @brief Initialization function for Q31 LMS filter.
04352    * @param[in] *S points to an instance of the Q31 LMS filter structure.
04353    * @param[in] numTaps  number of filter coefficients.
04354    * @param[in] *pCoeffs points to coefficient buffer.
04355    * @param[in] *pState points to state buffer.
04356    * @param[in] mu step size that controls filter coefficient updates.
04357    * @param[in] blockSize number of samples to process.
04358    * @param[in] postShift bit shift applied to coefficients.
04359    * @return none.
04360    */
04361 
04362   void arm_lms_init_q31(
04363   arm_lms_instance_q31 * S,
04364   uint16_t numTaps,
04365   q31_t * pCoeffs,
04366   q31_t * pState,
04367   q31_t mu,
04368   uint32_t blockSize,
04369   uint32_t postShift);
04370 
04371   /**
04372    * @brief Instance structure for the floating-point normalized LMS filter.
04373    */
04374 
04375   typedef struct
04376   {
04377     uint16_t numTaps;     /**< number of coefficients in the filter. */
04378     float32_t *pState;    /**< points to the state variable array. The array is of length numTaps+blockSize-1. */
04379     float32_t *pCoeffs;   /**< points to the coefficient array. The array is of length numTaps. */
04380     float32_t mu;        /**< step size that control filter coefficient updates. */
04381     float32_t energy;    /**< saves previous frame energy. */
04382     float32_t x0;        /**< saves previous input sample. */
04383   } arm_lms_norm_instance_f32;
04384 
04385   /**
04386    * @brief Processing function for floating-point normalized LMS filter.
04387    * @param[in] *S points to an instance of the floating-point normalized LMS filter structure.
04388    * @param[in] *pSrc points to the block of input data.
04389    * @param[in] *pRef points to the block of reference data.
04390    * @param[out] *pOut points to the block of output data.
04391    * @param[out] *pErr points to the block of error data.
04392    * @param[in] blockSize number of samples to process.
04393    * @return none.
04394    */
04395 
04396   void arm_lms_norm_f32(
04397   arm_lms_norm_instance_f32 * S,
04398   float32_t * pSrc,
04399   float32_t * pRef,
04400   float32_t * pOut,
04401   float32_t * pErr,
04402   uint32_t blockSize);
04403 
04404   /**
04405    * @brief Initialization function for floating-point normalized LMS filter.
04406    * @param[in] *S points to an instance of the floating-point LMS filter structure.
04407    * @param[in] numTaps  number of filter coefficients.
04408    * @param[in] *pCoeffs points to coefficient buffer.
04409    * @param[in] *pState points to state buffer.
04410    * @param[in] mu step size that controls filter coefficient updates.
04411    * @param[in] blockSize number of samples to process.
04412    * @return none.
04413    */
04414 
04415   void arm_lms_norm_init_f32(
04416   arm_lms_norm_instance_f32 * S,
04417   uint16_t numTaps,
04418   float32_t * pCoeffs,
04419   float32_t * pState,
04420   float32_t mu,
04421   uint32_t blockSize);
04422 
04423 
04424   /**
04425    * @brief Instance structure for the Q31 normalized LMS filter.
04426    */
04427   typedef struct
04428   {
04429     uint16_t numTaps;     /**< number of coefficients in the filter. */
04430     q31_t *pState;        /**< points to the state variable array. The array is of length numTaps+blockSize-1. */
04431     q31_t *pCoeffs;       /**< points to the coefficient array. The array is of length numTaps. */
04432     q31_t mu;             /**< step size that controls filter coefficient updates. */
04433     uint8_t postShift;    /**< bit shift applied to coefficients. */
04434     q31_t *recipTable;    /**< points to the reciprocal initial value table. */
04435     q31_t energy;         /**< saves previous frame energy. */
04436     q31_t x0;             /**< saves previous input sample. */
04437   } arm_lms_norm_instance_q31;
04438 
04439   /**
04440    * @brief Processing function for Q31 normalized LMS filter.
04441    * @param[in] *S points to an instance of the Q31 normalized LMS filter structure.
04442    * @param[in] *pSrc points to the block of input data.
04443    * @param[in] *pRef points to the block of reference data.
04444    * @param[out] *pOut points to the block of output data.
04445    * @param[out] *pErr points to the block of error data.
04446    * @param[in] blockSize number of samples to process.
04447    * @return none.
04448    */
04449 
04450   void arm_lms_norm_q31(
04451   arm_lms_norm_instance_q31 * S,
04452   q31_t * pSrc,
04453   q31_t * pRef,
04454   q31_t * pOut,
04455   q31_t * pErr,
04456   uint32_t blockSize);
04457 
04458   /**
04459    * @brief Initialization function for Q31 normalized LMS filter.
04460    * @param[in] *S points to an instance of the Q31 normalized LMS filter structure.
04461    * @param[in] numTaps  number of filter coefficients.
04462    * @param[in] *pCoeffs points to coefficient buffer.
04463    * @param[in] *pState points to state buffer.
04464    * @param[in] mu step size that controls filter coefficient updates.
04465    * @param[in] blockSize number of samples to process.
04466    * @param[in] postShift bit shift applied to coefficients.
04467    * @return none.
04468    */
04469 
04470   void arm_lms_norm_init_q31(
04471   arm_lms_norm_instance_q31 * S,
04472   uint16_t numTaps,
04473   q31_t * pCoeffs,
04474   q31_t * pState,
04475   q31_t mu,
04476   uint32_t blockSize,
04477   uint8_t postShift);
04478 
04479   /**
04480    * @brief Instance structure for the Q15 normalized LMS filter.
04481    */
04482 
04483   typedef struct
04484   {
04485     uint16_t numTaps;    /**< Number of coefficients in the filter. */
04486     q15_t *pState;        /**< points to the state variable array. The array is of length numTaps+blockSize-1. */
04487     q15_t *pCoeffs;       /**< points to the coefficient array. The array is of length numTaps. */
04488     q15_t mu;            /**< step size that controls filter coefficient updates. */
04489     uint8_t postShift;   /**< bit shift applied to coefficients. */
04490     q15_t *recipTable;   /**< Points to the reciprocal initial value table. */
04491     q15_t energy;        /**< saves previous frame energy. */
04492     q15_t x0;            /**< saves previous input sample. */
04493   } arm_lms_norm_instance_q15;
04494 
04495   /**
04496    * @brief Processing function for Q15 normalized LMS filter.
04497    * @param[in] *S points to an instance of the Q15 normalized LMS filter structure.
04498    * @param[in] *pSrc points to the block of input data.
04499    * @param[in] *pRef points to the block of reference data.
04500    * @param[out] *pOut points to the block of output data.
04501    * @param[out] *pErr points to the block of error data.
04502    * @param[in] blockSize number of samples to process.
04503    * @return none.
04504    */
04505 
04506   void arm_lms_norm_q15(
04507   arm_lms_norm_instance_q15 * S,
04508   q15_t * pSrc,
04509   q15_t * pRef,
04510   q15_t * pOut,
04511   q15_t * pErr,
04512   uint32_t blockSize);
04513 
04514 
04515   /**
04516    * @brief Initialization function for Q15 normalized LMS filter.
04517    * @param[in] *S points to an instance of the Q15 normalized LMS filter structure.
04518    * @param[in] numTaps  number of filter coefficients.
04519    * @param[in] *pCoeffs points to coefficient buffer.
04520    * @param[in] *pState points to state buffer.
04521    * @param[in] mu step size that controls filter coefficient updates.
04522    * @param[in] blockSize number of samples to process.
04523    * @param[in] postShift bit shift applied to coefficients.
04524    * @return none.
04525    */
04526 
04527   void arm_lms_norm_init_q15(
04528   arm_lms_norm_instance_q15 * S,
04529   uint16_t numTaps,
04530   q15_t * pCoeffs,
04531   q15_t * pState,
04532   q15_t mu,
04533   uint32_t blockSize,
04534   uint8_t postShift);
04535 
04536   /**
04537    * @brief Correlation of floating-point sequences.
04538    * @param[in] *pSrcA points to the first input sequence.
04539    * @param[in] srcALen length of the first input sequence.
04540    * @param[in] *pSrcB points to the second input sequence.
04541    * @param[in] srcBLen length of the second input sequence.
04542    * @param[out] *pDst points to the block of output data  Length 2 * max(srcALen, srcBLen) - 1.
04543    * @return none.
04544    */
04545 
04546   void arm_correlate_f32(
04547   float32_t * pSrcA,
04548   uint32_t srcALen,
04549   float32_t * pSrcB,
04550   uint32_t srcBLen,
04551   float32_t * pDst);
04552 
04553 
04554    /**
04555    * @brief Correlation of Q15 sequences
04556    * @param[in] *pSrcA points to the first input sequence.
04557    * @param[in] srcALen length of the first input sequence.
04558    * @param[in] *pSrcB points to the second input sequence.
04559    * @param[in] srcBLen length of the second input sequence.
04560    * @param[out] *pDst points to the block of output data  Length 2 * max(srcALen, srcBLen) - 1.
04561    * @param[in]  *pScratch points to scratch buffer of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2.
04562    * @return none.
04563    */
04564   void arm_correlate_opt_q15(
04565   q15_t * pSrcA,
04566   uint32_t srcALen,
04567   q15_t * pSrcB,
04568   uint32_t srcBLen,
04569   q15_t * pDst,
04570   q15_t * pScratch);
04571 
04572 
04573   /**
04574    * @brief Correlation of Q15 sequences.
04575    * @param[in] *pSrcA points to the first input sequence.
04576    * @param[in] srcALen length of the first input sequence.
04577    * @param[in] *pSrcB points to the second input sequence.
04578    * @param[in] srcBLen length of the second input sequence.
04579    * @param[out] *pDst points to the block of output data  Length 2 * max(srcALen, srcBLen) - 1.
04580    * @return none.
04581    */
04582 
04583   void arm_correlate_q15(
04584   q15_t * pSrcA,
04585   uint32_t srcALen,
04586   q15_t * pSrcB,
04587   uint32_t srcBLen,
04588   q15_t * pDst);
04589 
04590   /**
04591    * @brief Correlation of Q15 sequences (fast version) for Cortex-M3 and Cortex-M4.
04592    * @param[in] *pSrcA points to the first input sequence.
04593    * @param[in] srcALen length of the first input sequence.
04594    * @param[in] *pSrcB points to the second input sequence.
04595    * @param[in] srcBLen length of the second input sequence.
04596    * @param[out] *pDst points to the block of output data  Length 2 * max(srcALen, srcBLen) - 1.
04597    * @return none.
04598    */
04599 
04600   void arm_correlate_fast_q15(
04601                    q15_t * pSrcA,
04602                   uint32_t srcALen,
04603                    q15_t * pSrcB,
04604                   uint32_t srcBLen,
04605                   q15_t * pDst);
04606 
04607 
04608 
04609   /**
04610    * @brief Correlation of Q15 sequences (fast version) for Cortex-M3 and Cortex-M4.
04611    * @param[in] *pSrcA points to the first input sequence.
04612    * @param[in] srcALen length of the first input sequence.
04613    * @param[in] *pSrcB points to the second input sequence.
04614    * @param[in] srcBLen length of the second input sequence.
04615    * @param[out] *pDst points to the block of output data  Length 2 * max(srcALen, srcBLen) - 1.
04616    * @param[in]  *pScratch points to scratch buffer of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2.
04617    * @return none.
04618    */
04619 
04620   void arm_correlate_fast_opt_q15(
04621   q15_t * pSrcA,
04622   uint32_t srcALen,
04623   q15_t * pSrcB,
04624   uint32_t srcBLen,
04625   q15_t * pDst,
04626   q15_t * pScratch);
04627 
04628   /**
04629    * @brief Correlation of Q31 sequences.
04630    * @param[in] *pSrcA points to the first input sequence.
04631    * @param[in] srcALen length of the first input sequence.
04632    * @param[in] *pSrcB points to the second input sequence.
04633    * @param[in] srcBLen length of the second input sequence.
04634    * @param[out] *pDst points to the block of output data  Length 2 * max(srcALen, srcBLen) - 1.
04635    * @return none.
04636    */
04637 
04638   void arm_correlate_q31(
04639   q31_t * pSrcA,
04640   uint32_t srcALen,
04641   q31_t * pSrcB,
04642   uint32_t srcBLen,
04643   q31_t * pDst);
04644 
04645   /**
04646    * @brief Correlation of Q31 sequences (fast version) for Cortex-M3 and Cortex-M4
04647    * @param[in] *pSrcA points to the first input sequence.
04648    * @param[in] srcALen length of the first input sequence.
04649    * @param[in] *pSrcB points to the second input sequence.
04650    * @param[in] srcBLen length of the second input sequence.
04651    * @param[out] *pDst points to the block of output data  Length 2 * max(srcALen, srcBLen) - 1.
04652    * @return none.
04653    */
04654 
04655   void arm_correlate_fast_q31(
04656   q31_t * pSrcA,
04657   uint32_t srcALen,
04658   q31_t * pSrcB,
04659   uint32_t srcBLen,
04660   q31_t * pDst);
04661 
04662 
04663 
04664  /**
04665    * @brief Correlation of Q7 sequences.
04666    * @param[in] *pSrcA points to the first input sequence.
04667    * @param[in] srcALen length of the first input sequence.
04668    * @param[in] *pSrcB points to the second input sequence.
04669    * @param[in] srcBLen length of the second input sequence.
04670    * @param[out] *pDst points to the block of output data  Length 2 * max(srcALen, srcBLen) - 1.
04671    * @param[in]  *pScratch1 points to scratch buffer(of type q15_t) of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2.
04672    * @param[in]  *pScratch2 points to scratch buffer (of type q15_t) of size min(srcALen, srcBLen).
04673    * @return none.
04674    */
04675 
04676   void arm_correlate_opt_q7(
04677   q7_t * pSrcA,
04678   uint32_t srcALen,
04679   q7_t * pSrcB,
04680   uint32_t srcBLen,
04681   q7_t * pDst,
04682   q15_t * pScratch1,
04683   q15_t * pScratch2);
04684 
04685 
04686   /**
04687    * @brief Correlation of Q7 sequences.
04688    * @param[in] *pSrcA points to the first input sequence.
04689    * @param[in] srcALen length of the first input sequence.
04690    * @param[in] *pSrcB points to the second input sequence.
04691    * @param[in] srcBLen length of the second input sequence.
04692    * @param[out] *pDst points to the block of output data  Length 2 * max(srcALen, srcBLen) - 1.
04693    * @return none.
04694    */
04695 
04696   void arm_correlate_q7(
04697   q7_t * pSrcA,
04698   uint32_t srcALen,
04699   q7_t * pSrcB,
04700   uint32_t srcBLen,
04701   q7_t * pDst);
04702 
04703 
04704   /**
04705    * @brief Instance structure for the floating-point sparse FIR filter.
04706    */
04707   typedef struct
04708   {
04709     uint16_t numTaps;             /**< number of coefficients in the filter. */
04710     uint16_t stateIndex;          /**< state buffer index.  Points to the oldest sample in the state buffer. */
04711     float32_t *pState;            /**< points to the state buffer array. The array is of length maxDelay+blockSize-1. */
04712     float32_t *pCoeffs;           /**< points to the coefficient array. The array is of length numTaps.*/
04713     uint16_t maxDelay;            /**< maximum offset specified by the pTapDelay array. */
04714     int32_t *pTapDelay;           /**< points to the array of delay values.  The array is of length numTaps. */
04715   } arm_fir_sparse_instance_f32;
04716 
04717   /**
04718    * @brief Instance structure for the Q31 sparse FIR filter.
04719    */
04720 
04721   typedef struct
04722   {
04723     uint16_t numTaps;             /**< number of coefficients in the filter. */
04724     uint16_t stateIndex;          /**< state buffer index.  Points to the oldest sample in the state buffer. */
04725     q31_t *pState;                /**< points to the state buffer array. The array is of length maxDelay+blockSize-1. */
04726     q31_t *pCoeffs;               /**< points to the coefficient array. The array is of length numTaps.*/
04727     uint16_t maxDelay;            /**< maximum offset specified by the pTapDelay array. */
04728     int32_t *pTapDelay;           /**< points to the array of delay values.  The array is of length numTaps. */
04729   } arm_fir_sparse_instance_q31;
04730 
04731   /**
04732    * @brief Instance structure for the Q15 sparse FIR filter.
04733    */
04734 
04735   typedef struct
04736   {
04737     uint16_t numTaps;             /**< number of coefficients in the filter. */
04738     uint16_t stateIndex;          /**< state buffer index.  Points to the oldest sample in the state buffer. */
04739     q15_t *pState;                /**< points to the state buffer array. The array is of length maxDelay+blockSize-1. */
04740     q15_t *pCoeffs;               /**< points to the coefficient array. The array is of length numTaps.*/
04741     uint16_t maxDelay;            /**< maximum offset specified by the pTapDelay array. */
04742     int32_t *pTapDelay;           /**< points to the array of delay values.  The array is of length numTaps. */
04743   } arm_fir_sparse_instance_q15;
04744 
04745   /**
04746    * @brief Instance structure for the Q7 sparse FIR filter.
04747    */
04748 
04749   typedef struct
04750   {
04751     uint16_t numTaps;             /**< number of coefficients in the filter. */
04752     uint16_t stateIndex;          /**< state buffer index.  Points to the oldest sample in the state buffer. */
04753     q7_t *pState;                 /**< points to the state buffer array. The array is of length maxDelay+blockSize-1. */
04754     q7_t *pCoeffs;                /**< points to the coefficient array. The array is of length numTaps.*/
04755     uint16_t maxDelay;            /**< maximum offset specified by the pTapDelay array. */
04756     int32_t *pTapDelay;           /**< points to the array of delay values.  The array is of length numTaps. */
04757   } arm_fir_sparse_instance_q7;
04758 
04759   /**
04760    * @brief Processing function for the floating-point sparse FIR filter.
04761    * @param[in]  *S          points to an instance of the floating-point sparse FIR structure.
04762    * @param[in]  *pSrc       points to the block of input data.
04763    * @param[out] *pDst       points to the block of output data
04764    * @param[in]  *pScratchIn points to a temporary buffer of size blockSize.
04765    * @param[in]  blockSize   number of input samples to process per call.
04766    * @return none.
04767    */
04768 
04769   void arm_fir_sparse_f32(
04770   arm_fir_sparse_instance_f32 * S,
04771   float32_t * pSrc,
04772   float32_t * pDst,
04773   float32_t * pScratchIn,
04774   uint32_t blockSize);
04775 
04776   /**
04777    * @brief  Initialization function for the floating-point sparse FIR filter.
04778    * @param[in,out] *S         points to an instance of the floating-point sparse FIR structure.
04779    * @param[in]     numTaps    number of nonzero coefficients in the filter.
04780    * @param[in]     *pCoeffs   points to the array of filter coefficients.
04781    * @param[in]     *pState    points to the state buffer.
04782    * @param[in]     *pTapDelay points to the array of offset times.
04783    * @param[in]     maxDelay   maximum offset time supported.
04784    * @param[in]     blockSize  number of samples that will be processed per block.
04785    * @return none
04786    */
04787 
04788   void arm_fir_sparse_init_f32(
04789   arm_fir_sparse_instance_f32 * S,
04790   uint16_t numTaps,
04791   float32_t * pCoeffs,
04792   float32_t * pState,
04793   int32_t * pTapDelay,
04794   uint16_t maxDelay,
04795   uint32_t blockSize);
04796 
04797   /**
04798    * @brief Processing function for the Q31 sparse FIR filter.
04799    * @param[in]  *S          points to an instance of the Q31 sparse FIR structure.
04800    * @param[in]  *pSrc       points to the block of input data.
04801    * @param[out] *pDst       points to the block of output data
04802    * @param[in]  *pScratchIn points to a temporary buffer of size blockSize.
04803    * @param[in]  blockSize   number of input samples to process per call.
04804    * @return none.
04805    */
04806 
04807   void arm_fir_sparse_q31(
04808   arm_fir_sparse_instance_q31 * S,
04809   q31_t * pSrc,
04810   q31_t * pDst,
04811   q31_t * pScratchIn,
04812   uint32_t blockSize);
04813 
04814   /**
04815    * @brief  Initialization function for the Q31 sparse FIR filter.
04816    * @param[in,out] *S         points to an instance of the Q31 sparse FIR structure.
04817    * @param[in]     numTaps    number of nonzero coefficients in the filter.
04818    * @param[in]     *pCoeffs   points to the array of filter coefficients.
04819    * @param[in]     *pState    points to the state buffer.
04820    * @param[in]     *pTapDelay points to the array of offset times.
04821    * @param[in]     maxDelay   maximum offset time supported.
04822    * @param[in]     blockSize  number of samples that will be processed per block.
04823    * @return none
04824    */
04825 
04826   void arm_fir_sparse_init_q31(
04827   arm_fir_sparse_instance_q31 * S,
04828   uint16_t numTaps,
04829   q31_t * pCoeffs,
04830   q31_t * pState,
04831   int32_t * pTapDelay,
04832   uint16_t maxDelay,
04833   uint32_t blockSize);
04834 
04835   /**
04836    * @brief Processing function for the Q15 sparse FIR filter.
04837    * @param[in]  *S           points to an instance of the Q15 sparse FIR structure.
04838    * @param[in]  *pSrc        points to the block of input data.
04839    * @param[out] *pDst        points to the block of output data
04840    * @param[in]  *pScratchIn  points to a temporary buffer of size blockSize.
04841    * @param[in]  *pScratchOut points to a temporary buffer of size blockSize.
04842    * @param[in]  blockSize    number of input samples to process per call.
04843    * @return none.
04844    */
04845 
04846   void arm_fir_sparse_q15(
04847   arm_fir_sparse_instance_q15 * S,
04848   q15_t * pSrc,
04849   q15_t * pDst,
04850   q15_t * pScratchIn,
04851   q31_t * pScratchOut,
04852   uint32_t blockSize);
04853 
04854 
04855   /**
04856    * @brief  Initialization function for the Q15 sparse FIR filter.
04857    * @param[in,out] *S         points to an instance of the Q15 sparse FIR structure.
04858    * @param[in]     numTaps    number of nonzero coefficients in the filter.
04859    * @param[in]     *pCoeffs   points to the array of filter coefficients.
04860    * @param[in]     *pState    points to the state buffer.
04861    * @param[in]     *pTapDelay points to the array of offset times.
04862    * @param[in]     maxDelay   maximum offset time supported.
04863    * @param[in]     blockSize  number of samples that will be processed per block.
04864    * @return none
04865    */
04866 
04867   void arm_fir_sparse_init_q15(
04868   arm_fir_sparse_instance_q15 * S,
04869   uint16_t numTaps,
04870   q15_t * pCoeffs,
04871   q15_t * pState,
04872   int32_t * pTapDelay,
04873   uint16_t maxDelay,
04874   uint32_t blockSize);
04875 
04876   /**
04877    * @brief Processing function for the Q7 sparse FIR filter.
04878    * @param[in]  *S           points to an instance of the Q7 sparse FIR structure.
04879    * @param[in]  *pSrc        points to the block of input data.
04880    * @param[out] *pDst        points to the block of output data
04881    * @param[in]  *pScratchIn  points to a temporary buffer of size blockSize.
04882    * @param[in]  *pScratchOut points to a temporary buffer of size blockSize.
04883    * @param[in]  blockSize    number of input samples to process per call.
04884    * @return none.
04885    */
04886 
04887   void arm_fir_sparse_q7(
04888   arm_fir_sparse_instance_q7 * S,
04889   q7_t * pSrc,
04890   q7_t * pDst,
04891   q7_t * pScratchIn,
04892   q31_t * pScratchOut,
04893   uint32_t blockSize);
04894 
04895   /**
04896    * @brief  Initialization function for the Q7 sparse FIR filter.
04897    * @param[in,out] *S         points to an instance of the Q7 sparse FIR structure.
04898    * @param[in]     numTaps    number of nonzero coefficients in the filter.
04899    * @param[in]     *pCoeffs   points to the array of filter coefficients.
04900    * @param[in]     *pState    points to the state buffer.
04901    * @param[in]     *pTapDelay points to the array of offset times.
04902    * @param[in]     maxDelay   maximum offset time supported.
04903    * @param[in]     blockSize  number of samples that will be processed per block.
04904    * @return none
04905    */
04906 
04907   void arm_fir_sparse_init_q7(
04908   arm_fir_sparse_instance_q7 * S,
04909   uint16_t numTaps,
04910   q7_t * pCoeffs,
04911   q7_t * pState,
04912   int32_t * pTapDelay,
04913   uint16_t maxDelay,
04914   uint32_t blockSize);
04915 
04916 
04917   /*
04918    * @brief  Floating-point sin_cos function.
04919    * @param[in]  theta    input value in degrees
04920    * @param[out] *pSinVal points to the processed sine output.
04921    * @param[out] *pCosVal points to the processed cos output.
04922    * @return none.
04923    */
04924 
04925   void arm_sin_cos_f32(
04926   float32_t theta,
04927   float32_t * pSinVal,
04928   float32_t * pCcosVal);
04929 
04930   /*
04931    * @brief  Q31 sin_cos function.
04932    * @param[in]  theta    scaled input value in degrees
04933    * @param[out] *pSinVal points to the processed sine output.
04934    * @param[out] *pCosVal points to the processed cosine output.
04935    * @return none.
04936    */
04937 
04938   void arm_sin_cos_q31(
04939   q31_t theta,
04940   q31_t * pSinVal,
04941   q31_t * pCosVal);
04942 
04943 
04944   /**
04945    * @brief  Floating-point complex conjugate.
04946    * @param[in]  *pSrc points to the input vector
04947    * @param[out]  *pDst points to the output vector
04948    * @param[in]  numSamples number of complex samples in each vector
04949    * @return none.
04950    */
04951 
04952   void arm_cmplx_conj_f32(
04953   float32_t * pSrc,
04954   float32_t * pDst,
04955   uint32_t numSamples);
04956 
04957   /**
04958    * @brief  Q31 complex conjugate.
04959    * @param[in]  *pSrc points to the input vector
04960    * @param[out]  *pDst points to the output vector
04961    * @param[in]  numSamples number of complex samples in each vector
04962    * @return none.
04963    */
04964 
04965   void arm_cmplx_conj_q31(
04966   q31_t * pSrc,
04967   q31_t * pDst,
04968   uint32_t numSamples);
04969 
04970   /**
04971    * @brief  Q15 complex conjugate.
04972    * @param[in]  *pSrc points to the input vector
04973    * @param[out]  *pDst points to the output vector
04974    * @param[in]  numSamples number of complex samples in each vector
04975    * @return none.
04976    */
04977 
04978   void arm_cmplx_conj_q15(
04979   q15_t * pSrc,
04980   q15_t * pDst,
04981   uint32_t numSamples);
04982 
04983 
04984 
04985   /**
04986    * @brief  Floating-point complex magnitude squared
04987    * @param[in]  *pSrc points to the complex input vector
04988    * @param[out]  *pDst points to the real output vector
04989    * @param[in]  numSamples number of complex samples in the input vector
04990    * @return none.
04991    */
04992 
04993   void arm_cmplx_mag_squared_f32(
04994   float32_t * pSrc,
04995   float32_t * pDst,
04996   uint32_t numSamples);
04997 
04998   /**
04999    * @brief  Q31 complex magnitude squared
05000    * @param[in]  *pSrc points to the complex input vector
05001    * @param[out]  *pDst points to the real output vector
05002    * @param[in]  numSamples number of complex samples in the input vector
05003    * @return none.
05004    */
05005 
05006   void arm_cmplx_mag_squared_q31(
05007   q31_t * pSrc,
05008   q31_t * pDst,
05009   uint32_t numSamples);
05010 
05011   /**
05012    * @brief  Q15 complex magnitude squared
05013    * @param[in]  *pSrc points to the complex input vector
05014    * @param[out]  *pDst points to the real output vector
05015    * @param[in]  numSamples number of complex samples in the input vector
05016    * @return none.
05017    */
05018 
05019   void arm_cmplx_mag_squared_q15(
05020   q15_t * pSrc,
05021   q15_t * pDst,
05022   uint32_t numSamples);
05023 
05024 
05025  /**
05026    * @ingroup groupController
05027    */
05028 
05029   /**
05030    * @defgroup PID PID Motor Control
05031    *
05032    * A Proportional Integral Derivative (PID) controller is a generic feedback control
05033    * loop mechanism widely used in industrial control systems.
05034    * A PID controller is the most commonly used type of feedback controller.
05035    *
05036    * This set of functions implements (PID) controllers
05037    * for Q15, Q31, and floating-point data types.  The functions operate on a single sample
05038    * of data and each call to the function returns a single processed value.
05039    * <code>S</code> points to an instance of the PID control data structure.  <code>in</code>
05040    * is the input sample value. The functions return the output value.
05041    *
05042    * \par Algorithm:
05043    * <pre>
05044    *    y[n] = y[n-1] + A0 * x[n] + A1 * x[n-1] + A2 * x[n-2]
05045    *    A0 = Kp + Ki + Kd
05046    *    A1 = (-Kp ) - (2 * Kd )
05047    *    A2 = Kd  </pre>
05048    *
05049    * \par
05050    * where \c Kp is proportional constant, \c Ki is Integral constant and \c Kd is Derivative constant
05051    *
05052    * \par
05053    * \image html PID.gif "Proportional Integral Derivative Controller"
05054    *
05055    * \par
05056    * The PID controller calculates an "error" value as the difference between
05057    * the measured output and the reference input.
05058    * The controller attempts to minimize the error by adjusting the process control inputs.
05059    * The proportional value determines the reaction to the current error,
05060    * the integral value determines the reaction based on the sum of recent errors,
05061    * and the derivative value determines the reaction based on the rate at which the error has been changing.
05062    *
05063    * \par Instance Structure
05064    * The Gains A0, A1, A2 and state variables for a PID controller are stored together in an instance data structure.
05065    * A separate instance structure must be defined for each PID Controller.
05066    * There are separate instance structure declarations for each of the 3 supported data types.
05067    *
05068    * \par Reset Functions
05069    * There is also an associated reset function for each data type which clears the state array.
05070    *
05071    * \par Initialization Functions
05072    * There is also an associated initialization function for each data type.
05073    * The initialization function performs the following operations:
05074    * - Initializes the Gains A0, A1, A2 from Kp,Ki, Kd gains.
05075    * - Zeros out the values in the state buffer.
05076    *
05077    * \par
05078    * Instance structure cannot be placed into a const data section and it is recommended to use the initialization function.
05079    *
05080    * \par Fixed-Point Behavior
05081    * Care must be taken when using the fixed-point versions of the PID Controller functions.
05082    * In particular, the overflow and saturation behavior of the accumulator used in each function must be considered.
05083    * Refer to the function specific documentation below for usage guidelines.
05084    */
05085 
05086   /**
05087    * @addtogroup PID
05088    * @{
05089    */
05090 
05091   /**
05092    * @brief  Process function for the floating-point PID Control.
05093    * @param[in,out] *S is an instance of the floating-point PID Control structure
05094    * @param[in] in input sample to process
05095    * @return out processed output sample.
05096    */
05097 
05098 
05099   static __INLINE float32_t arm_pid_f32(
05100   arm_pid_instance_f32 * S,
05101   float32_t in)
05102   {
05103     float32_t out;
05104 
05105     /* y[n] = y[n-1] + A0 * x[n] + A1 * x[n-1] + A2 * x[n-2]  */
05106     out = (S->A0 * in) +
05107       (S->A1 * S->state[0]) + (S->A2 * S->state[1]) + (S->state[2]);
05108 
05109     /* Update state */
05110     S->state[1] = S->state[0];
05111     S->state[0] = in;
05112     S->state[2] = out;
05113 
05114     /* return to application */
05115     return (out);
05116 
05117   }
05118 
05119   /**
05120    * @brief  Process function for the Q31 PID Control.
05121    * @param[in,out] *S points to an instance of the Q31 PID Control structure
05122    * @param[in] in input sample to process
05123    * @return out processed output sample.
05124    *
05125    * <b>Scaling and Overflow Behavior:</b>
05126    * \par
05127    * The function is implemented using an internal 64-bit accumulator.
05128    * The accumulator has a 2.62 format and maintains full precision of the intermediate multiplication results but provides only a single guard bit.
05129    * Thus, if the accumulator result overflows it wraps around rather than clip.
05130    * In order to avoid overflows completely the input signal must be scaled down by 2 bits as there are four additions.
05131    * After all multiply-accumulates are performed, the 2.62 accumulator is truncated to 1.32 format and then saturated to 1.31 format.
05132    */
05133 
05134   static __INLINE q31_t arm_pid_q31(
05135   arm_pid_instance_q31 * S,
05136   q31_t in)
05137   {
05138     q63_t acc;
05139     q31_t out;
05140 
05141     /* acc = A0 * x[n]  */
05142     acc = (q63_t) S->A0 * in;
05143 
05144     /* acc += A1 * x[n-1] */
05145     acc += (q63_t) S->A1 * S->state[0];
05146 
05147     /* acc += A2 * x[n-2]  */
05148     acc += (q63_t) S->A2 * S->state[1];
05149 
05150     /* convert output to 1.31 format to add y[n-1] */
05151     out = (q31_t) (acc >> 31u);
05152 
05153     /* out += y[n-1] */
05154     out += S->state[2];
05155 
05156     /* Update state */
05157     S->state[1] = S->state[0];
05158     S->state[0] = in;
05159     S->state[2] = out;
05160 
05161     /* return to application */
05162     return (out);
05163 
05164   }
05165 
05166   /**
05167    * @brief  Process function for the Q15 PID Control.
05168    * @param[in,out] *S points to an instance of the Q15 PID Control structure
05169    * @param[in] in input sample to process
05170    * @return out processed output sample.
05171    *
05172    * <b>Scaling and Overflow Behavior:</b>
05173    * \par
05174    * The function is implemented using a 64-bit internal accumulator.
05175    * Both Gains and state variables are represented in 1.15 format and multiplications yield a 2.30 result.
05176    * The 2.30 intermediate results are accumulated in a 64-bit accumulator in 34.30 format.
05177    * There is no risk of internal overflow with this approach and the full precision of intermediate multiplications is preserved.
05178    * After all additions have been performed, the accumulator is truncated to 34.15 format by discarding low 15 bits.
05179    * Lastly, the accumulator is saturated to yield a result in 1.15 format.
05180    */
05181 
05182   static __INLINE q15_t arm_pid_q15(
05183   arm_pid_instance_q15 * S,
05184   q15_t in)
05185   {
05186     q63_t acc;
05187     q15_t out;
05188 
05189 #ifndef ARM_MATH_CM0_FAMILY
05190     __SIMD32_TYPE *vstate;
05191 
05192     /* Implementation of PID controller */
05193 
05194     /* acc = A0 * x[n]  */
05195     acc = (q31_t) __SMUAD(S->A0, in);
05196 
05197     /* acc += A1 * x[n-1] + A2 * x[n-2]  */
05198     vstate = __SIMD32_CONST(S->state);
05199     acc = __SMLALD(S->A1, (q31_t) *vstate, acc);
05200 
05201 #else
05202     /* acc = A0 * x[n]  */
05203     acc = ((q31_t) S->A0) * in;
05204 
05205     /* acc += A1 * x[n-1] + A2 * x[n-2]  */
05206     acc += (q31_t) S->A1 * S->state[0];
05207     acc += (q31_t) S->A2 * S->state[1];
05208 
05209 #endif
05210 
05211     /* acc += y[n-1] */
05212     acc += (q31_t) S->state[2] << 15;
05213 
05214     /* saturate the output */
05215     out = (q15_t) (__SSAT((acc >> 15), 16));
05216 
05217     /* Update state */
05218     S->state[1] = S->state[0];
05219     S->state[0] = in;
05220     S->state[2] = out;
05221 
05222     /* return to application */
05223     return (out);
05224 
05225   }
05226 
05227   /**
05228    * @} end of PID group
05229    */
05230 
05231 
05232   /**
05233    * @brief Floating-point matrix inverse.
05234    * @param[in]  *src points to the instance of the input floating-point matrix structure.
05235    * @param[out] *dst points to the instance of the output floating-point matrix structure.
05236    * @return The function returns ARM_MATH_SIZE_MISMATCH, if the dimensions do not match.
05237    * If the input matrix is singular (does not have an inverse), then the algorithm terminates and returns error status ARM_MATH_SINGULAR.
05238    */
05239 
05240   arm_status arm_mat_inverse_f32(
05241   const arm_matrix_instance_f32 * src,
05242   arm_matrix_instance_f32 * dst);
05243 
05244 
05245   /**
05246    * @brief Floating-point matrix inverse.
05247    * @param[in]  *src points to the instance of the input floating-point matrix structure.
05248    * @param[out] *dst points to the instance of the output floating-point matrix structure.
05249    * @return The function returns ARM_MATH_SIZE_MISMATCH, if the dimensions do not match.
05250    * If the input matrix is singular (does not have an inverse), then the algorithm terminates and returns error status ARM_MATH_SINGULAR.
05251    */
05252 
05253   arm_status arm_mat_inverse_f64(
05254   const arm_matrix_instance_f64 * src,
05255   arm_matrix_instance_f64 * dst);
05256 
05257 
05258 
05259   /**
05260    * @ingroup groupController
05261    */
05262 
05263 
05264   /**
05265    * @defgroup clarke Vector Clarke Transform
05266    * Forward Clarke transform converts the instantaneous stator phases into a two-coordinate time invariant vector.
05267    * Generally the Clarke transform uses three-phase currents <code>Ia, Ib and Ic</code> to calculate currents
05268    * in the two-phase orthogonal stator axis <code>Ialpha</code> and <code>Ibeta</code>.
05269    * When <code>Ialpha</code> is superposed with <code>Ia</code> as shown in the figure below
05270    * \image html clarke.gif Stator current space vector and its components in (a,b).
05271    * and <code>Ia + Ib + Ic = 0</code>, in this condition <code>Ialpha</code> and <code>Ibeta</code>
05272    * can be calculated using only <code>Ia</code> and <code>Ib</code>.
05273    *
05274    * The function operates on a single sample of data and each call to the function returns the processed output.
05275    * The library provides separate functions for Q31 and floating-point data types.
05276    * \par Algorithm
05277    * \image html clarkeFormula.gif
05278    * where <code>Ia</code> and <code>Ib</code> are the instantaneous stator phases and
05279    * <code>pIalpha</code> and <code>pIbeta</code> are the two coordinates of time invariant vector.
05280    * \par Fixed-Point Behavior
05281    * Care must be taken when using the Q31 version of the Clarke transform.
05282    * In particular, the overflow and saturation behavior of the accumulator used must be considered.
05283    * Refer to the function specific documentation below for usage guidelines.
05284    */
05285 
05286   /**
05287    * @addtogroup clarke
05288    * @{
05289    */
05290 
05291   /**
05292    *
05293    * @brief  Floating-point Clarke transform
05294    * @param[in]       Ia       input three-phase coordinate <code>a</code>
05295    * @param[in]       Ib       input three-phase coordinate <code>b</code>
05296    * @param[out]      *pIalpha points to output two-phase orthogonal vector axis alpha
05297    * @param[out]      *pIbeta  points to output two-phase orthogonal vector axis beta
05298    * @return none.
05299    */
05300 
05301   static __INLINE void arm_clarke_f32(
05302   float32_t Ia,
05303   float32_t Ib,
05304   float32_t * pIalpha,
05305   float32_t * pIbeta)
05306   {
05307     /* Calculate pIalpha using the equation, pIalpha = Ia */
05308     *pIalpha = Ia;
05309 
05310     /* Calculate pIbeta using the equation, pIbeta = (1/sqrt(3)) * Ia + (2/sqrt(3)) * Ib */
05311     *pIbeta =
05312       ((float32_t) 0.57735026919 * Ia + (float32_t) 1.15470053838 * Ib);
05313 
05314   }
05315 
05316   /**
05317    * @brief  Clarke transform for Q31 version
05318    * @param[in]       Ia       input three-phase coordinate <code>a</code>
05319    * @param[in]       Ib       input three-phase coordinate <code>b</code>
05320    * @param[out]      *pIalpha points to output two-phase orthogonal vector axis alpha
05321    * @param[out]      *pIbeta  points to output two-phase orthogonal vector axis beta
05322    * @return none.
05323    *
05324    * <b>Scaling and Overflow Behavior:</b>
05325    * \par
05326    * The function is implemented using an internal 32-bit accumulator.
05327    * The accumulator maintains 1.31 format by truncating lower 31 bits of the intermediate multiplication in 2.62 format.
05328    * There is saturation on the addition, hence there is no risk of overflow.
05329    */
05330 
05331   static __INLINE void arm_clarke_q31(
05332   q31_t Ia,
05333   q31_t Ib,
05334   q31_t * pIalpha,
05335   q31_t * pIbeta)
05336   {
05337     q31_t product1, product2;                    /* Temporary variables used to store intermediate results */
05338 
05339     /* Calculating pIalpha from Ia by equation pIalpha = Ia */
05340     *pIalpha = Ia;
05341 
05342     /* Intermediate product is calculated by (1/(sqrt(3)) * Ia) */
05343     product1 = (q31_t) (((q63_t) Ia * 0x24F34E8B) >> 30);
05344 
05345     /* Intermediate product is calculated by (2/sqrt(3) * Ib) */
05346     product2 = (q31_t) (((q63_t) Ib * 0x49E69D16) >> 30);
05347 
05348     /* pIbeta is calculated by adding the intermediate products */
05349     *pIbeta = __QADD(product1, product2);
05350   }
05351 
05352   /**
05353    * @} end of clarke group
05354    */
05355 
05356   /**
05357    * @brief  Converts the elements of the Q7 vector to Q31 vector.
05358    * @param[in]  *pSrc     input pointer
05359    * @param[out]  *pDst    output pointer
05360    * @param[in]  blockSize number of samples to process
05361    * @return none.
05362    */
05363   void arm_q7_to_q31(
05364   q7_t * pSrc,
05365   q31_t * pDst,
05366   uint32_t blockSize);
05367 
05368 
05369 
05370 
05371   /**
05372    * @ingroup groupController
05373    */
05374 
05375   /**
05376    * @defgroup inv_clarke Vector Inverse Clarke Transform
05377    * Inverse Clarke transform converts the two-coordinate time invariant vector into instantaneous stator phases.
05378    *
05379    * The function operates on a single sample of data and each call to the function returns the processed output.
05380    * The library provides separate functions for Q31 and floating-point data types.
05381    * \par Algorithm
05382    * \image html clarkeInvFormula.gif
05383    * where <code>pIa</code> and <code>pIb</code> are the instantaneous stator phases and
05384    * <code>Ialpha</code> and <code>Ibeta</code> are the two coordinates of time invariant vector.
05385    * \par Fixed-Point Behavior
05386    * Care must be taken when using the Q31 version of the Clarke transform.
05387    * In particular, the overflow and saturation behavior of the accumulator used must be considered.
05388    * Refer to the function specific documentation below for usage guidelines.
05389    */
05390 
05391   /**
05392    * @addtogroup inv_clarke
05393    * @{
05394    */
05395 
05396    /**
05397    * @brief  Floating-point Inverse Clarke transform
05398    * @param[in]       Ialpha  input two-phase orthogonal vector axis alpha
05399    * @param[in]       Ibeta   input two-phase orthogonal vector axis beta
05400    * @param[out]      *pIa    points to output three-phase coordinate <code>a</code>
05401    * @param[out]      *pIb    points to output three-phase coordinate <code>b</code>
05402    * @return none.
05403    */
05404 
05405 
05406   static __INLINE void arm_inv_clarke_f32(
05407   float32_t Ialpha,
05408   float32_t Ibeta,
05409   float32_t * pIa,
05410   float32_t * pIb)
05411   {
05412     /* Calculating pIa from Ialpha by equation pIa = Ialpha */
05413     *pIa = Ialpha;
05414 
05415     /* Calculating pIb from Ialpha and Ibeta by equation pIb = -(1/2) * Ialpha + (sqrt(3)/2) * Ibeta */
05416     *pIb = -0.5 * Ialpha + (float32_t) 0.8660254039 *Ibeta;
05417 
05418   }
05419 
05420   /**
05421    * @brief  Inverse Clarke transform for Q31 version
05422    * @param[in]       Ialpha  input two-phase orthogonal vector axis alpha
05423    * @param[in]       Ibeta   input two-phase orthogonal vector axis beta
05424    * @param[out]      *pIa    points to output three-phase coordinate <code>a</code>
05425    * @param[out]      *pIb    points to output three-phase coordinate <code>b</code>
05426    * @return none.
05427    *
05428    * <b>Scaling and Overflow Behavior:</b>
05429    * \par
05430    * The function is implemented using an internal 32-bit accumulator.
05431    * The accumulator maintains 1.31 format by truncating lower 31 bits of the intermediate multiplication in 2.62 format.
05432    * There is saturation on the subtraction, hence there is no risk of overflow.
05433    */
05434 
05435   static __INLINE void arm_inv_clarke_q31(
05436   q31_t Ialpha,
05437   q31_t Ibeta,
05438   q31_t * pIa,
05439   q31_t * pIb)
05440   {
05441     q31_t product1, product2;                    /* Temporary variables used to store intermediate results */
05442 
05443     /* Calculating pIa from Ialpha by equation pIa = Ialpha */
05444     *pIa = Ialpha;
05445 
05446     /* Intermediate product is calculated by (1/(2*sqrt(3)) * Ia) */
05447     product1 = (q31_t) (((q63_t) (Ialpha) * (0x40000000)) >> 31);
05448 
05449     /* Intermediate product is calculated by (1/sqrt(3) * pIb) */
05450     product2 = (q31_t) (((q63_t) (Ibeta) * (0x6ED9EBA1)) >> 31);
05451 
05452     /* pIb is calculated by subtracting the products */
05453     *pIb = __QSUB(product2, product1);
05454 
05455   }
05456 
05457   /**
05458    * @} end of inv_clarke group
05459    */
05460 
05461   /**
05462    * @brief  Converts the elements of the Q7 vector to Q15 vector.
05463    * @param[in]  *pSrc     input pointer
05464    * @param[out] *pDst     output pointer
05465    * @param[in]  blockSize number of samples to process
05466    * @return none.
05467    */
05468   void arm_q7_to_q15(
05469   q7_t * pSrc,
05470   q15_t * pDst,
05471   uint32_t blockSize);
05472 
05473 
05474 
05475   /**
05476    * @ingroup groupController
05477    */
05478 
05479   /**
05480    * @defgroup park Vector Park Transform
05481    *
05482    * Forward Park transform converts the input two-coordinate vector to flux and torque components.
05483    * The Park transform can be used to realize the transformation of the <code>Ialpha</code> and the <code>Ibeta</code> currents
05484    * from the stationary to the moving reference frame and control the spatial relationship between
05485    * the stator vector current and rotor flux vector.
05486    * If we consider the d axis aligned with the rotor flux, the diagram below shows the
05487    * current vector and the relationship from the two reference frames:
05488    * \image html park.gif "Stator current space vector and its component in (a,b) and in the d,q rotating reference frame"
05489    *
05490    * The function operates on a single sample of data and each call to the function returns the processed output.
05491    * The library provides separate functions for Q31 and floating-point data types.
05492    * \par Algorithm
05493    * \image html parkFormula.gif
05494    * where <code>Ialpha</code> and <code>Ibeta</code> are the stator vector components,
05495    * <code>pId</code> and <code>pIq</code> are rotor vector components and <code>cosVal</code> and <code>sinVal</code> are the
05496    * cosine and sine values of theta (rotor flux position).
05497    * \par Fixed-Point Behavior
05498    * Care must be taken when using the Q31 version of the Park transform.
05499    * In particular, the overflow and saturation behavior of the accumulator used must be considered.
05500    * Refer to the function specific documentation below for usage guidelines.
05501    */
05502 
05503   /**
05504    * @addtogroup park
05505    * @{
05506    */
05507 
05508   /**
05509    * @brief Floating-point Park transform
05510    * @param[in]       Ialpha input two-phase vector coordinate alpha
05511    * @param[in]       Ibeta  input two-phase vector coordinate beta
05512    * @param[out]      *pId   points to output   rotor reference frame d
05513    * @param[out]      *pIq   points to output   rotor reference frame q
05514    * @param[in]       sinVal sine value of rotation angle theta
05515    * @param[in]       cosVal cosine value of rotation angle theta
05516    * @return none.
05517    *
05518    * The function implements the forward Park transform.
05519    *
05520    */
05521 
05522   static __INLINE void arm_park_f32(
05523   float32_t Ialpha,
05524   float32_t Ibeta,
05525   float32_t * pId,
05526   float32_t * pIq,
05527   float32_t sinVal,
05528   float32_t cosVal)
05529   {
05530     /* Calculate pId using the equation, pId = Ialpha * cosVal + Ibeta * sinVal */
05531     *pId = Ialpha * cosVal + Ibeta * sinVal;
05532 
05533     /* Calculate pIq using the equation, pIq = - Ialpha * sinVal + Ibeta * cosVal */
05534     *pIq = -Ialpha * sinVal + Ibeta * cosVal;
05535 
05536   }
05537 
05538   /**
05539    * @brief  Park transform for Q31 version
05540    * @param[in]       Ialpha input two-phase vector coordinate alpha
05541    * @param[in]       Ibeta  input two-phase vector coordinate beta
05542    * @param[out]      *pId   points to output rotor reference frame d
05543    * @param[out]      *pIq   points to output rotor reference frame q
05544    * @param[in]       sinVal sine value of rotation angle theta
05545    * @param[in]       cosVal cosine value of rotation angle theta
05546    * @return none.
05547    *
05548    * <b>Scaling and Overflow Behavior:</b>
05549    * \par
05550    * The function is implemented using an internal 32-bit accumulator.
05551    * The accumulator maintains 1.31 format by truncating lower 31 bits of the intermediate multiplication in 2.62 format.
05552    * There is saturation on the addition and subtraction, hence there is no risk of overflow.
05553    */
05554 
05555 
05556   static __INLINE void arm_park_q31(
05557   q31_t Ialpha,
05558   q31_t Ibeta,
05559   q31_t * pId,
05560   q31_t * pIq,
05561   q31_t sinVal,
05562   q31_t cosVal)
05563   {
05564     q31_t product1, product2;                    /* Temporary variables used to store intermediate results */
05565     q31_t product3, product4;                    /* Temporary variables used to store intermediate results */
05566 
05567     /* Intermediate product is calculated by (Ialpha * cosVal) */
05568     product1 = (q31_t) (((q63_t) (Ialpha) * (cosVal)) >> 31);
05569 
05570     /* Intermediate product is calculated by (Ibeta * sinVal) */
05571     product2 = (q31_t) (((q63_t) (Ibeta) * (sinVal)) >> 31);
05572 
05573 
05574     /* Intermediate product is calculated by (Ialpha * sinVal) */
05575     product3 = (q31_t) (((q63_t) (Ialpha) * (sinVal)) >> 31);
05576 
05577     /* Intermediate product is calculated by (Ibeta * cosVal) */
05578     product4 = (q31_t) (((q63_t) (Ibeta) * (cosVal)) >> 31);
05579 
05580     /* Calculate pId by adding the two intermediate products 1 and 2 */
05581     *pId = __QADD(product1, product2);
05582 
05583     /* Calculate pIq by subtracting the two intermediate products 3 from 4 */
05584     *pIq = __QSUB(product4, product3);
05585   }
05586 
05587   /**
05588    * @} end of park group
05589    */
05590 
05591   /**
05592    * @brief  Converts the elements of the Q7 vector to floating-point vector.
05593    * @param[in]  *pSrc is input pointer
05594    * @param[out]  *pDst is output pointer
05595    * @param[in]  blockSize is the number of samples to process
05596    * @return none.
05597    */
05598   void arm_q7_to_float(
05599   q7_t * pSrc,
05600   float32_t * pDst,
05601   uint32_t blockSize);
05602 
05603 
05604   /**
05605    * @ingroup groupController
05606    */
05607 
05608   /**
05609    * @defgroup inv_park Vector Inverse Park transform
05610    * Inverse Park transform converts the input flux and torque components to two-coordinate vector.
05611    *
05612    * The function operates on a single sample of data and each call to the function returns the processed output.
05613    * The library provides separate functions for Q31 and floating-point data types.
05614    * \par Algorithm
05615    * \image html parkInvFormula.gif
05616    * where <code>pIalpha</code> and <code>pIbeta</code> are the stator vector components,
05617    * <code>Id</code> and <code>Iq</code> are rotor vector components and <code>cosVal</code> and <code>sinVal</code> are the
05618    * cosine and sine values of theta (rotor flux position).
05619    * \par Fixed-Point Behavior
05620    * Care must be taken when using the Q31 version of the Park transform.
05621    * In particular, the overflow and saturation behavior of the accumulator used must be considered.
05622    * Refer to the function specific documentation below for usage guidelines.
05623    */
05624 
05625   /**
05626    * @addtogroup inv_park
05627    * @{
05628    */
05629 
05630    /**
05631    * @brief  Floating-point Inverse Park transform
05632    * @param[in]       Id        input coordinate of rotor reference frame d
05633    * @param[in]       Iq        input coordinate of rotor reference frame q
05634    * @param[out]      *pIalpha  points to output two-phase orthogonal vector axis alpha
05635    * @param[out]      *pIbeta   points to output two-phase orthogonal vector axis beta
05636    * @param[in]       sinVal    sine value of rotation angle theta
05637    * @param[in]       cosVal    cosine value of rotation angle theta
05638    * @return none.
05639    */
05640 
05641   static __INLINE void arm_inv_park_f32(
05642   float32_t Id,
05643   float32_t Iq,
05644   float32_t * pIalpha,
05645   float32_t * pIbeta,
05646   float32_t sinVal,
05647   float32_t cosVal)
05648   {
05649     /* Calculate pIalpha using the equation, pIalpha = Id * cosVal - Iq * sinVal */
05650     *pIalpha = Id * cosVal - Iq * sinVal;
05651 
05652     /* Calculate pIbeta using the equation, pIbeta = Id * sinVal + Iq * cosVal */
05653     *pIbeta = Id * sinVal + Iq * cosVal;
05654 
05655   }
05656 
05657 
05658   /**
05659    * @brief  Inverse Park transform for Q31 version
05660    * @param[in]       Id        input coordinate of rotor reference frame d
05661    * @param[in]       Iq        input coordinate of rotor reference frame q
05662    * @param[out]      *pIalpha  points to output two-phase orthogonal vector axis alpha
05663    * @param[out]      *pIbeta   points to output two-phase orthogonal vector axis beta
05664    * @param[in]       sinVal    sine value of rotation angle theta
05665    * @param[in]       cosVal    cosine value of rotation angle theta
05666    * @return none.
05667    *
05668    * <b>Scaling and Overflow Behavior:</b>
05669    * \par
05670    * The function is implemented using an internal 32-bit accumulator.
05671    * The accumulator maintains 1.31 format by truncating lower 31 bits of the intermediate multiplication in 2.62 format.
05672    * There is saturation on the addition, hence there is no risk of overflow.
05673    */
05674 
05675 
05676   static __INLINE void arm_inv_park_q31(
05677   q31_t Id,
05678   q31_t Iq,
05679   q31_t * pIalpha,
05680   q31_t * pIbeta,
05681   q31_t sinVal,
05682   q31_t cosVal)
05683   {
05684     q31_t product1, product2;                    /* Temporary variables used to store intermediate results */
05685     q31_t product3, product4;                    /* Temporary variables used to store intermediate results */
05686 
05687     /* Intermediate product is calculated by (Id * cosVal) */
05688     product1 = (q31_t) (((q63_t) (Id) * (cosVal)) >> 31);
05689 
05690     /* Intermediate product is calculated by (Iq * sinVal) */
05691     product2 = (q31_t) (((q63_t) (Iq) * (sinVal)) >> 31);
05692 
05693 
05694     /* Intermediate product is calculated by (Id * sinVal) */
05695     product3 = (q31_t) (((q63_t) (Id) * (sinVal)) >> 31);
05696 
05697     /* Intermediate product is calculated by (Iq * cosVal) */
05698     product4 = (q31_t) (((q63_t) (Iq) * (cosVal)) >> 31);
05699 
05700     /* Calculate pIalpha by using the two intermediate products 1 and 2 */
05701     *pIalpha = __QSUB(product1, product2);
05702 
05703     /* Calculate pIbeta by using the two intermediate products 3 and 4 */
05704     *pIbeta = __QADD(product4, product3);
05705 
05706   }
05707 
05708   /**
05709    * @} end of Inverse park group
05710    */
05711 
05712 
05713   /**
05714    * @brief  Converts the elements of the Q31 vector to floating-point vector.
05715    * @param[in]  *pSrc is input pointer
05716    * @param[out]  *pDst is output pointer
05717    * @param[in]  blockSize is the number of samples to process
05718    * @return none.
05719    */
05720   void arm_q31_to_float(
05721   q31_t * pSrc,
05722   float32_t * pDst,
05723   uint32_t blockSize);
05724 
05725   /**
05726    * @ingroup groupInterpolation
05727    */
05728 
05729   /**
05730    * @defgroup LinearInterpolate Linear Interpolation
05731    *
05732    * Linear interpolation is a method of curve fitting using linear polynomials.
05733    * Linear interpolation works by effectively drawing a straight line between two neighboring samples and returning the appropriate point along that line
05734    *
05735    * \par
05736    * \image html LinearInterp.gif "Linear interpolation"
05737    *
05738    * \par
05739    * A  Linear Interpolate function calculates an output value(y), for the input(x)
05740    * using linear interpolation of the input values x0, x1( nearest input values) and the output values y0 and y1(nearest output values)
05741    *
05742    * \par Algorithm:
05743    * <pre>
05744    *       y = y0 + (x - x0) * ((y1 - y0)/(x1-x0))
05745    *       where x0, x1 are nearest values of input x
05746    *             y0, y1 are nearest values to output y
05747    * </pre>
05748    *
05749    * \par
05750    * This set of functions implements Linear interpolation process
05751    * for Q7, Q15, Q31, and floating-point data types.  The functions operate on a single
05752    * sample of data and each call to the function returns a single processed value.
05753    * <code>S</code> points to an instance of the Linear Interpolate function data structure.
05754    * <code>x</code> is the input sample value. The functions returns the output value.
05755    *
05756    * \par
05757    * if x is outside of the table boundary, Linear interpolation returns first value of the table
05758    * if x is below input range and returns last value of table if x is above range.
05759    */
05760 
05761   /**
05762    * @addtogroup LinearInterpolate
05763    * @{
05764    */
05765 
05766   /**
05767    * @brief  Process function for the floating-point Linear Interpolation Function.
05768    * @param[in,out] *S is an instance of the floating-point Linear Interpolation structure
05769    * @param[in] x input sample to process
05770    * @return y processed output sample.
05771    *
05772    */
05773 
05774   static __INLINE float32_t arm_linear_interp_f32(
05775   arm_linear_interp_instance_f32 * S,
05776   float32_t x)
05777   {
05778 
05779     float32_t y;
05780     float32_t x0, x1;                            /* Nearest input values */
05781     float32_t y0, y1;                            /* Nearest output values */
05782     float32_t xSpacing = S->xSpacing;            /* spacing between input values */
05783     int32_t i;                                   /* Index variable */
05784     float32_t *pYData = S->pYData;               /* pointer to output table */
05785 
05786     /* Calculation of index */
05787     i = (int32_t) ((x - S->x1) / xSpacing);
05788 
05789     if(i < 0)
05790     {
05791       /* Iniatilize output for below specified range as least output value of table */
05792       y = pYData[0];
05793     }
05794     else if((uint32_t)i >= S->nValues)
05795     {
05796       /* Iniatilize output for above specified range as last output value of table */
05797       y = pYData[S->nValues - 1];
05798     }
05799     else
05800     {
05801       /* Calculation of nearest input values */
05802       x0 = S->x1 + i * xSpacing;
05803       x1 = S->x1 + (i + 1) * xSpacing;
05804 
05805       /* Read of nearest output values */
05806       y0 = pYData[i];
05807       y1 = pYData[i + 1];
05808 
05809       /* Calculation of output */
05810       y = y0 + (x - x0) * ((y1 - y0) / (x1 - x0));
05811 
05812     }
05813 
05814     /* returns output value */
05815     return (y);
05816   }
05817 
05818    /**
05819    *
05820    * @brief  Process function for the Q31 Linear Interpolation Function.
05821    * @param[in] *pYData  pointer to Q31 Linear Interpolation table
05822    * @param[in] x input sample to process
05823    * @param[in] nValues number of table values
05824    * @return y processed output sample.
05825    *
05826    * \par
05827    * Input sample <code>x</code> is in 12.20 format which contains 12 bits for table index and 20 bits for fractional part.
05828    * This function can support maximum of table size 2^12.
05829    *
05830    */
05831 
05832 
05833   static __INLINE q31_t arm_linear_interp_q31(
05834   q31_t * pYData,
05835   q31_t x,
05836   uint32_t nValues)
05837   {
05838     q31_t y;                                     /* output */
05839     q31_t y0, y1;                                /* Nearest output values */
05840     q31_t fract;                                 /* fractional part */
05841     int32_t index;                               /* Index to read nearest output values */
05842 
05843     /* Input is in 12.20 format */
05844     /* 12 bits for the table index */
05845     /* Index value calculation */
05846     index = ((x & 0xFFF00000) >> 20);
05847 
05848     if(index >= (int32_t)(nValues - 1))
05849     {
05850       return (pYData[nValues - 1]);
05851     }
05852     else if(index < 0)
05853     {
05854       return (pYData[0]);
05855     }
05856     else
05857     {
05858 
05859       /* 20 bits for the fractional part */
05860       /* shift left by 11 to keep fract in 1.31 format */
05861       fract = (x & 0x000FFFFF) << 11;
05862 
05863       /* Read two nearest output values from the index in 1.31(q31) format */
05864       y0 = pYData[index];
05865       y1 = pYData[index + 1u];
05866 
05867       /* Calculation of y0 * (1-fract) and y is in 2.30 format */
05868       y = ((q31_t) ((q63_t) y0 * (0x7FFFFFFF - fract) >> 32));
05869 
05870       /* Calculation of y0 * (1-fract) + y1 *fract and y is in 2.30 format */
05871       y += ((q31_t) (((q63_t) y1 * fract) >> 32));
05872 
05873       /* Convert y to 1.31 format */
05874       return (y << 1u);
05875 
05876     }
05877 
05878   }
05879 
05880   /**
05881    *
05882    * @brief  Process function for the Q15 Linear Interpolation Function.
05883    * @param[in] *pYData  pointer to Q15 Linear Interpolation table
05884    * @param[in] x input sample to process
05885    * @param[in] nValues number of table values
05886    * @return y processed output sample.
05887    *
05888    * \par
05889    * Input sample <code>x</code> is in 12.20 format which contains 12 bits for table index and 20 bits for fractional part.
05890    * This function can support maximum of table size 2^12.
05891    *
05892    */
05893 
05894 
05895   static __INLINE q15_t arm_linear_interp_q15(
05896   q15_t * pYData,
05897   q31_t x,
05898   uint32_t nValues)
05899   {
05900     q63_t y;                                     /* output */
05901     q15_t y0, y1;                                /* Nearest output values */
05902     q31_t fract;                                 /* fractional part */
05903     int32_t index;                               /* Index to read nearest output values */
05904 
05905     /* Input is in 12.20 format */
05906     /* 12 bits for the table index */
05907     /* Index value calculation */
05908     index = ((x & 0xFFF00000) >> 20u);
05909 
05910     if(index >= (int32_t)(nValues - 1))
05911     {
05912       return (pYData[nValues - 1]);
05913     }
05914     else if(index < 0)
05915     {
05916       return (pYData[0]);
05917     }
05918     else
05919     {
05920       /* 20 bits for the fractional part */
05921       /* fract is in 12.20 format */
05922       fract = (x & 0x000FFFFF);
05923 
05924       /* Read two nearest output values from the index */
05925       y0 = pYData[index];
05926       y1 = pYData[index + 1u];
05927 
05928       /* Calculation of y0 * (1-fract) and y is in 13.35 format */
05929       y = ((q63_t) y0 * (0xFFFFF - fract));
05930 
05931       /* Calculation of (y0 * (1-fract) + y1 * fract) and y is in 13.35 format */
05932       y += ((q63_t) y1 * (fract));
05933 
05934       /* convert y to 1.15 format */
05935       return (y >> 20);
05936     }
05937 
05938 
05939   }
05940 
05941   /**
05942    *
05943    * @brief  Process function for the Q7 Linear Interpolation Function.
05944    * @param[in] *pYData  pointer to Q7 Linear Interpolation table
05945    * @param[in] x input sample to process
05946    * @param[in] nValues number of table values
05947    * @return y processed output sample.
05948    *
05949    * \par
05950    * Input sample <code>x</code> is in 12.20 format which contains 12 bits for table index and 20 bits for fractional part.
05951    * This function can support maximum of table size 2^12.
05952    */
05953 
05954 
05955   static __INLINE q7_t arm_linear_interp_q7(
05956   q7_t * pYData,
05957   q31_t x,
05958   uint32_t nValues)
05959   {
05960     q31_t y;                                     /* output */
05961     q7_t y0, y1;                                 /* Nearest output values */
05962     q31_t fract;                                 /* fractional part */
05963     uint32_t index;                              /* Index to read nearest output values */
05964 
05965     /* Input is in 12.20 format */
05966     /* 12 bits for the table index */
05967     /* Index value calculation */
05968     if (x < 0)
05969     {
05970       return (pYData[0]);
05971     }
05972     index = (x >> 20) & 0xfff;
05973 
05974 
05975     if(index >= (nValues - 1))
05976     {
05977       return (pYData[nValues - 1]);
05978     }
05979     else
05980     {
05981 
05982       /* 20 bits for the fractional part */
05983       /* fract is in 12.20 format */
05984       fract = (x & 0x000FFFFF);
05985 
05986       /* Read two nearest output values from the index and are in 1.7(q7) format */
05987       y0 = pYData[index];
05988       y1 = pYData[index + 1u];
05989 
05990       /* Calculation of y0 * (1-fract ) and y is in 13.27(q27) format */
05991       y = ((y0 * (0xFFFFF - fract)));
05992 
05993       /* Calculation of y1 * fract + y0 * (1-fract) and y is in 13.27(q27) format */
05994       y += (y1 * fract);
05995 
05996       /* convert y to 1.7(q7) format */
05997       return (y >> 20u);
05998 
05999     }
06000 
06001   }
06002   /**
06003    * @} end of LinearInterpolate group
06004    */
06005 
06006   /**
06007    * @brief  Fast approximation to the trigonometric sine function for floating-point data.
06008    * @param[in] x input value in radians.
06009    * @return  sin(x).
06010    */
06011 
06012   float32_t arm_sin_f32(
06013   float32_t x);
06014 
06015   /**
06016    * @brief  Fast approximation to the trigonometric sine function for Q31 data.
06017    * @param[in] x Scaled input value in radians.
06018    * @return  sin(x).
06019    */
06020 
06021   q31_t arm_sin_q31(
06022   q31_t x);
06023 
06024   /**
06025    * @brief  Fast approximation to the trigonometric sine function for Q15 data.
06026    * @param[in] x Scaled input value in radians.
06027    * @return  sin(x).
06028    */
06029 
06030   q15_t arm_sin_q15(
06031   q15_t x);
06032 
06033   /**
06034    * @brief  Fast approximation to the trigonometric cosine function for floating-point data.
06035    * @param[in] x input value in radians.
06036    * @return  cos(x).
06037    */
06038 
06039   float32_t arm_cos_f32(
06040   float32_t x);
06041 
06042   /**
06043    * @brief Fast approximation to the trigonometric cosine function for Q31 data.
06044    * @param[in] x Scaled input value in radians.
06045    * @return  cos(x).
06046    */
06047 
06048   q31_t arm_cos_q31(
06049   q31_t x);
06050 
06051   /**
06052    * @brief  Fast approximation to the trigonometric cosine function for Q15 data.
06053    * @param[in] x Scaled input value in radians.
06054    * @return  cos(x).
06055    */
06056 
06057   q15_t arm_cos_q15(
06058   q15_t x);
06059 
06060 
06061   /**
06062    * @ingroup groupFastMath
06063    */
06064 
06065 
06066   /**
06067    * @defgroup SQRT Square Root
06068    *
06069    * Computes the square root of a number.
06070    * There are separate functions for Q15, Q31, and floating-point data types.
06071    * The square root function is computed using the Newton-Raphson algorithm.
06072    * This is an iterative algorithm of the form:
06073    * <pre>
06074    *      x1 = x0 - f(x0)/f'(x0)
06075    * </pre>
06076    * where <code>x1</code> is the current estimate,
06077    * <code>x0</code> is the previous estimate, and
06078    * <code>f'(x0)</code> is the derivative of <code>f()</code> evaluated at <code>x0</code>.
06079    * For the square root function, the algorithm reduces to:
06080    * <pre>
06081    *     x0 = in/2                         [initial guess]
06082    *     x1 = 1/2 * ( x0 + in / x0)        [each iteration]
06083    * </pre>
06084    */
06085 
06086 
06087   /**
06088    * @addtogroup SQRT
06089    * @{
06090    */
06091 
06092   /**
06093    * @brief  Floating-point square root function.
06094    * @param[in]  in     input value.
06095    * @param[out] *pOut  square root of input value.
06096    * @return The function returns ARM_MATH_SUCCESS if input value is positive value or ARM_MATH_ARGUMENT_ERROR if
06097    * <code>in</code> is negative value and returns zero output for negative values.
06098    */
06099 
06100   static __INLINE arm_status arm_sqrt_f32(
06101   float32_t in,
06102   float32_t * pOut)
06103   {
06104     if(in >= 0.0f)
06105     {
06106 
06107 //      #if __FPU_USED
06108 #if (__FPU_USED == 1) && defined ( __CC_ARM   )
06109       *pOut = __sqrtf(in);
06110 #else
06111       *pOut = sqrtf(in);
06112 #endif
06113 
06114       return (ARM_MATH_SUCCESS);
06115     }
06116     else
06117     {
06118       *pOut = 0.0f;
06119       return (ARM_MATH_ARGUMENT_ERROR);
06120     }
06121 
06122   }
06123 
06124 
06125   /**
06126    * @brief Q31 square root function.
06127    * @param[in]   in    input value.  The range of the input value is [0 +1) or 0x00000000 to 0x7FFFFFFF.
06128    * @param[out]  *pOut square root of input value.
06129    * @return The function returns ARM_MATH_SUCCESS if input value is positive value or ARM_MATH_ARGUMENT_ERROR if
06130    * <code>in</code> is negative value and returns zero output for negative values.
06131    */
06132   arm_status arm_sqrt_q31(
06133   q31_t in,
06134   q31_t * pOut);
06135 
06136   /**
06137    * @brief  Q15 square root function.
06138    * @param[in]   in     input value.  The range of the input value is [0 +1) or 0x0000 to 0x7FFF.
06139    * @param[out]  *pOut  square root of input value.
06140    * @return The function returns ARM_MATH_SUCCESS if input value is positive value or ARM_MATH_ARGUMENT_ERROR if
06141    * <code>in</code> is negative value and returns zero output for negative values.
06142    */
06143   arm_status arm_sqrt_q15(
06144   q15_t in,
06145   q15_t * pOut);
06146 
06147   /**
06148    * @} end of SQRT group
06149    */
06150 
06151 
06152 
06153 
06154 
06155 
06156   /**
06157    * @brief floating-point Circular write function.
06158    */
06159 
06160   static __INLINE void arm_circularWrite_f32(
06161   int32_t * circBuffer,
06162   int32_t L,
06163   uint16_t * writeOffset,
06164   int32_t bufferInc,
06165   const int32_t * src,
06166   int32_t srcInc,
06167   uint32_t blockSize)
06168   {
06169     uint32_t i = 0u;
06170     int32_t wOffset;
06171 
06172     /* Copy the value of Index pointer that points
06173      * to the current location where the input samples to be copied */
06174     wOffset = *writeOffset;
06175 
06176     /* Loop over the blockSize */
06177     i = blockSize;
06178 
06179     while(i > 0u)
06180     {
06181       /* copy the input sample to the circular buffer */
06182       circBuffer[wOffset] = *src;
06183 
06184       /* Update the input pointer */
06185       src += srcInc;
06186 
06187       /* Circularly update wOffset.  Watch out for positive and negative value */
06188       wOffset += bufferInc;
06189       if(wOffset >= L)
06190         wOffset -= L;
06191 
06192       /* Decrement the loop counter */
06193       i--;
06194     }
06195 
06196     /* Update the index pointer */
06197     *writeOffset = wOffset;
06198   }
06199 
06200 
06201 
06202   /**
06203    * @brief floating-point Circular Read function.
06204    */
06205   static __INLINE void arm_circularRead_f32(
06206   int32_t * circBuffer,
06207   int32_t L,
06208   int32_t * readOffset,
06209   int32_t bufferInc,
06210   int32_t * dst,
06211   int32_t * dst_base,
06212   int32_t dst_length,
06213   int32_t dstInc,
06214   uint32_t blockSize)
06215   {
06216     uint32_t i = 0u;
06217     int32_t rOffset, dst_end;
06218 
06219     /* Copy the value of Index pointer that points
06220      * to the current location from where the input samples to be read */
06221     rOffset = *readOffset;
06222     dst_end = (int32_t) (dst_base + dst_length);
06223 
06224     /* Loop over the blockSize */
06225     i = blockSize;
06226 
06227     while(i > 0u)
06228     {
06229       /* copy the sample from the circular buffer to the destination buffer */
06230       *dst = circBuffer[rOffset];
06231 
06232       /* Update the input pointer */
06233       dst += dstInc;
06234 
06235       if(dst == (int32_t *) dst_end)
06236       {
06237         dst = dst_base;
06238       }
06239 
06240       /* Circularly update rOffset.  Watch out for positive and negative value  */
06241       rOffset += bufferInc;
06242 
06243       if(rOffset >= L)
06244       {
06245         rOffset -= L;
06246       }
06247 
06248       /* Decrement the loop counter */
06249       i--;
06250     }
06251 
06252     /* Update the index pointer */
06253     *readOffset = rOffset;
06254   }
06255 
06256   /**
06257    * @brief Q15 Circular write function.
06258    */
06259 
06260   static __INLINE void arm_circularWrite_q15(
06261   q15_t * circBuffer,
06262   int32_t L,
06263   uint16_t * writeOffset,
06264   int32_t bufferInc,
06265   const q15_t * src,
06266   int32_t srcInc,
06267   uint32_t blockSize)
06268   {
06269     uint32_t i = 0u;
06270     int32_t wOffset;
06271 
06272     /* Copy the value of Index pointer that points
06273      * to the current location where the input samples to be copied */
06274     wOffset = *writeOffset;
06275 
06276     /* Loop over the blockSize */
06277     i = blockSize;
06278 
06279     while(i > 0u)
06280     {
06281       /* copy the input sample to the circular buffer */
06282       circBuffer[wOffset] = *src;
06283 
06284       /* Update the input pointer */
06285       src += srcInc;
06286 
06287       /* Circularly update wOffset.  Watch out for positive and negative value */
06288       wOffset += bufferInc;
06289       if(wOffset >= L)
06290         wOffset -= L;
06291 
06292       /* Decrement the loop counter */
06293       i--;
06294     }
06295 
06296     /* Update the index pointer */
06297     *writeOffset = wOffset;
06298   }
06299 
06300 
06301 
06302   /**
06303    * @brief Q15 Circular Read function.
06304    */
06305   static __INLINE void arm_circularRead_q15(
06306   q15_t * circBuffer,
06307   int32_t L,
06308   int32_t * readOffset,
06309   int32_t bufferInc,
06310   q15_t * dst,
06311   q15_t * dst_base,
06312   int32_t dst_length,
06313   int32_t dstInc,
06314   uint32_t blockSize)
06315   {
06316     uint32_t i = 0;
06317     int32_t rOffset, dst_end;
06318 
06319     /* Copy the value of Index pointer that points
06320      * to the current location from where the input samples to be read */
06321     rOffset = *readOffset;
06322 
06323     dst_end = (int32_t) (dst_base + dst_length);
06324 
06325     /* Loop over the blockSize */
06326     i = blockSize;
06327 
06328     while(i > 0u)
06329     {
06330       /* copy the sample from the circular buffer to the destination buffer */
06331       *dst = circBuffer[rOffset];
06332 
06333       /* Update the input pointer */
06334       dst += dstInc;
06335 
06336       if(dst == (q15_t *) dst_end)
06337       {
06338         dst = dst_base;
06339       }
06340 
06341       /* Circularly update wOffset.  Watch out for positive and negative value */
06342       rOffset += bufferInc;
06343 
06344       if(rOffset >= L)
06345       {
06346         rOffset -= L;
06347       }
06348 
06349       /* Decrement the loop counter */
06350       i--;
06351     }
06352 
06353     /* Update the index pointer */
06354     *readOffset = rOffset;
06355   }
06356 
06357 
06358   /**
06359    * @brief Q7 Circular write function.
06360    */
06361 
06362   static __INLINE void arm_circularWrite_q7(
06363   q7_t * circBuffer,
06364   int32_t L,
06365   uint16_t * writeOffset,
06366   int32_t bufferInc,
06367   const q7_t * src,
06368   int32_t srcInc,
06369   uint32_t blockSize)
06370   {
06371     uint32_t i = 0u;
06372     int32_t wOffset;
06373 
06374     /* Copy the value of Index pointer that points
06375      * to the current location where the input samples to be copied */
06376     wOffset = *writeOffset;
06377 
06378     /* Loop over the blockSize */
06379     i = blockSize;
06380 
06381     while(i > 0u)
06382     {
06383       /* copy the input sample to the circular buffer */
06384       circBuffer[wOffset] = *src;
06385 
06386       /* Update the input pointer */
06387       src += srcInc;
06388 
06389       /* Circularly update wOffset.  Watch out for positive and negative value */
06390       wOffset += bufferInc;
06391       if(wOffset >= L)
06392         wOffset -= L;
06393 
06394       /* Decrement the loop counter */
06395       i--;
06396     }
06397 
06398     /* Update the index pointer */
06399     *writeOffset = wOffset;
06400   }
06401 
06402 
06403 
06404   /**
06405    * @brief Q7 Circular Read function.
06406    */
06407   static __INLINE void arm_circularRead_q7(
06408   q7_t * circBuffer,
06409   int32_t L,
06410   int32_t * readOffset,
06411   int32_t bufferInc,
06412   q7_t * dst,
06413   q7_t * dst_base,
06414   int32_t dst_length,
06415   int32_t dstInc,
06416   uint32_t blockSize)
06417   {
06418     uint32_t i = 0;
06419     int32_t rOffset, dst_end;
06420 
06421     /* Copy the value of Index pointer that points
06422      * to the current location from where the input samples to be read */
06423     rOffset = *readOffset;
06424 
06425     dst_end = (int32_t) (dst_base + dst_length);
06426 
06427     /* Loop over the blockSize */
06428     i = blockSize;
06429 
06430     while(i > 0u)
06431     {
06432       /* copy the sample from the circular buffer to the destination buffer */
06433       *dst = circBuffer[rOffset];
06434 
06435       /* Update the input pointer */
06436       dst += dstInc;
06437 
06438       if(dst == (q7_t *) dst_end)
06439       {
06440         dst = dst_base;
06441       }
06442 
06443       /* Circularly update rOffset.  Watch out for positive and negative value */
06444       rOffset += bufferInc;
06445 
06446       if(rOffset >= L)
06447       {
06448         rOffset -= L;
06449       }
06450 
06451       /* Decrement the loop counter */
06452       i--;
06453     }
06454 
06455     /* Update the index pointer */
06456     *readOffset = rOffset;
06457   }
06458 
06459 
06460   /**
06461    * @brief  Sum of the squares of the elements of a Q31 vector.
06462    * @param[in]  *pSrc is input pointer
06463    * @param[in]  blockSize is the number of samples to process
06464    * @param[out]  *pResult is output value.
06465    * @return none.
06466    */
06467 
06468   void arm_power_q31(
06469   q31_t * pSrc,
06470   uint32_t blockSize,
06471   q63_t * pResult);
06472 
06473   /**
06474    * @brief  Sum of the squares of the elements of a floating-point vector.
06475    * @param[in]  *pSrc is input pointer
06476    * @param[in]  blockSize is the number of samples to process
06477    * @param[out]  *pResult is output value.
06478    * @return none.
06479    */
06480 
06481   void arm_power_f32(
06482   float32_t * pSrc,
06483   uint32_t blockSize,
06484   float32_t * pResult);
06485 
06486   /**
06487    * @brief  Sum of the squares of the elements of a Q15 vector.
06488    * @param[in]  *pSrc is input pointer
06489    * @param[in]  blockSize is the number of samples to process
06490    * @param[out]  *pResult is output value.
06491    * @return none.
06492    */
06493 
06494   void arm_power_q15(
06495   q15_t * pSrc,
06496   uint32_t blockSize,
06497   q63_t * pResult);
06498 
06499   /**
06500    * @brief  Sum of the squares of the elements of a Q7 vector.
06501    * @param[in]  *pSrc is input pointer
06502    * @param[in]  blockSize is the number of samples to process
06503    * @param[out]  *pResult is output value.
06504    * @return none.
06505    */
06506 
06507   void arm_power_q7(
06508   q7_t * pSrc,
06509   uint32_t blockSize,
06510   q31_t * pResult);
06511 
06512   /**
06513    * @brief  Mean value of a Q7 vector.
06514    * @param[in]  *pSrc is input pointer
06515    * @param[in]  blockSize is the number of samples to process
06516    * @param[out]  *pResult is output value.
06517    * @return none.
06518    */
06519 
06520   void arm_mean_q7(
06521   q7_t * pSrc,
06522   uint32_t blockSize,
06523   q7_t * pResult);
06524 
06525   /**
06526    * @brief  Mean value of a Q15 vector.
06527    * @param[in]  *pSrc is input pointer
06528    * @param[in]  blockSize is the number of samples to process
06529    * @param[out]  *pResult is output value.
06530    * @return none.
06531    */
06532   void arm_mean_q15(
06533   q15_t * pSrc,
06534   uint32_t blockSize,
06535   q15_t * pResult);
06536 
06537   /**
06538    * @brief  Mean value of a Q31 vector.
06539    * @param[in]  *pSrc is input pointer
06540    * @param[in]  blockSize is the number of samples to process
06541    * @param[out]  *pResult is output value.
06542    * @return none.
06543    */
06544   void arm_mean_q31(
06545   q31_t * pSrc,
06546   uint32_t blockSize,
06547   q31_t * pResult);
06548 
06549   /**
06550    * @brief  Mean value of a floating-point vector.
06551    * @param[in]  *pSrc is input pointer
06552    * @param[in]  blockSize is the number of samples to process
06553    * @param[out]  *pResult is output value.
06554    * @return none.
06555    */
06556   void arm_mean_f32(
06557   float32_t * pSrc,
06558   uint32_t blockSize,
06559   float32_t * pResult);
06560 
06561   /**
06562    * @brief  Variance of the elements of a floating-point vector.
06563    * @param[in]  *pSrc is input pointer
06564    * @param[in]  blockSize is the number of samples to process
06565    * @param[out]  *pResult is output value.
06566    * @return none.
06567    */
06568 
06569   void arm_var_f32(
06570   float32_t * pSrc,
06571   uint32_t blockSize,
06572   float32_t * pResult);
06573 
06574   /**
06575    * @brief  Variance of the elements of a Q31 vector.
06576    * @param[in]  *pSrc is input pointer
06577    * @param[in]  blockSize is the number of samples to process
06578    * @param[out]  *pResult is output value.
06579    * @return none.
06580    */
06581 
06582   void arm_var_q31(
06583   q31_t * pSrc,
06584   uint32_t blockSize,
06585   q31_t * pResult);
06586 
06587   /**
06588    * @brief  Variance of the elements of a Q15 vector.
06589    * @param[in]  *pSrc is input pointer
06590    * @param[in]  blockSize is the number of samples to process
06591    * @param[out]  *pResult is output value.
06592    * @return none.
06593    */
06594 
06595   void arm_var_q15(
06596   q15_t * pSrc,
06597   uint32_t blockSize,
06598   q15_t * pResult);
06599 
06600   /**
06601    * @brief  Root Mean Square of the elements of a floating-point vector.
06602    * @param[in]  *pSrc is input pointer
06603    * @param[in]  blockSize is the number of samples to process
06604    * @param[out]  *pResult is output value.
06605    * @return none.
06606    */
06607 
06608   void arm_rms_f32(
06609   float32_t * pSrc,
06610   uint32_t blockSize,
06611   float32_t * pResult);
06612 
06613   /**
06614    * @brief  Root Mean Square of the elements of a Q31 vector.
06615    * @param[in]  *pSrc is input pointer
06616    * @param[in]  blockSize is the number of samples to process
06617    * @param[out]  *pResult is output value.
06618    * @return none.
06619    */
06620 
06621   void arm_rms_q31(
06622   q31_t * pSrc,
06623   uint32_t blockSize,
06624   q31_t * pResult);
06625 
06626   /**
06627    * @brief  Root Mean Square of the elements of a Q15 vector.
06628    * @param[in]  *pSrc is input pointer
06629    * @param[in]  blockSize is the number of samples to process
06630    * @param[out]  *pResult is output value.
06631    * @return none.
06632    */
06633 
06634   void arm_rms_q15(
06635   q15_t * pSrc,
06636   uint32_t blockSize,
06637   q15_t * pResult);
06638 
06639   /**
06640    * @brief  Standard deviation of the elements of a floating-point vector.
06641    * @param[in]  *pSrc is input pointer
06642    * @param[in]  blockSize is the number of samples to process
06643    * @param[out]  *pResult is output value.
06644    * @return none.
06645    */
06646 
06647   void arm_std_f32(
06648   float32_t * pSrc,
06649   uint32_t blockSize,
06650   float32_t * pResult);
06651 
06652   /**
06653    * @brief  Standard deviation of the elements of a Q31 vector.
06654    * @param[in]  *pSrc is input pointer
06655    * @param[in]  blockSize is the number of samples to process
06656    * @param[out]  *pResult is output value.
06657    * @return none.
06658    */
06659 
06660   void arm_std_q31(
06661   q31_t * pSrc,
06662   uint32_t blockSize,
06663   q31_t * pResult);
06664 
06665   /**
06666    * @brief  Standard deviation of the elements of a Q15 vector.
06667    * @param[in]  *pSrc is input pointer
06668    * @param[in]  blockSize is the number of samples to process
06669    * @param[out]  *pResult is output value.
06670    * @return none.
06671    */
06672 
06673   void arm_std_q15(
06674   q15_t * pSrc,
06675   uint32_t blockSize,
06676   q15_t * pResult);
06677 
06678   /**
06679    * @brief  Floating-point complex magnitude
06680    * @param[in]  *pSrc points to the complex input vector
06681    * @param[out]  *pDst points to the real output vector
06682    * @param[in]  numSamples number of complex samples in the input vector
06683    * @return none.
06684    */
06685 
06686   void arm_cmplx_mag_f32(
06687   float32_t * pSrc,
06688   float32_t * pDst,
06689   uint32_t numSamples);
06690 
06691   /**
06692    * @brief  Q31 complex magnitude
06693    * @param[in]  *pSrc points to the complex input vector
06694    * @param[out]  *pDst points to the real output vector
06695    * @param[in]  numSamples number of complex samples in the input vector
06696    * @return none.
06697    */
06698 
06699   void arm_cmplx_mag_q31(
06700   q31_t * pSrc,
06701   q31_t * pDst,
06702   uint32_t numSamples);
06703 
06704   /**
06705    * @brief  Q15 complex magnitude
06706    * @param[in]  *pSrc points to the complex input vector
06707    * @param[out]  *pDst points to the real output vector
06708    * @param[in]  numSamples number of complex samples in the input vector
06709    * @return none.
06710    */
06711 
06712   void arm_cmplx_mag_q15(
06713   q15_t * pSrc,
06714   q15_t * pDst,
06715   uint32_t numSamples);
06716 
06717   /**
06718    * @brief  Q15 complex dot product
06719    * @param[in]  *pSrcA points to the first input vector
06720    * @param[in]  *pSrcB points to the second input vector
06721    * @param[in]  numSamples number of complex samples in each vector
06722    * @param[out]  *realResult real part of the result returned here
06723    * @param[out]  *imagResult imaginary part of the result returned here
06724    * @return none.
06725    */
06726 
06727   void arm_cmplx_dot_prod_q15(
06728   q15_t * pSrcA,
06729   q15_t * pSrcB,
06730   uint32_t numSamples,
06731   q31_t * realResult,
06732   q31_t * imagResult);
06733 
06734   /**
06735    * @brief  Q31 complex dot product
06736    * @param[in]  *pSrcA points to the first input vector
06737    * @param[in]  *pSrcB points to the second input vector
06738    * @param[in]  numSamples number of complex samples in each vector
06739    * @param[out]  *realResult real part of the result returned here
06740    * @param[out]  *imagResult imaginary part of the result returned here
06741    * @return none.
06742    */
06743 
06744   void arm_cmplx_dot_prod_q31(
06745   q31_t * pSrcA,
06746   q31_t * pSrcB,
06747   uint32_t numSamples,
06748   q63_t * realResult,
06749   q63_t * imagResult);
06750 
06751   /**
06752    * @brief  Floating-point complex dot product
06753    * @param[in]  *pSrcA points to the first input vector
06754    * @param[in]  *pSrcB points to the second input vector
06755    * @param[in]  numSamples number of complex samples in each vector
06756    * @param[out]  *realResult real part of the result returned here
06757    * @param[out]  *imagResult imaginary part of the result returned here
06758    * @return none.
06759    */
06760 
06761   void arm_cmplx_dot_prod_f32(
06762   float32_t * pSrcA,
06763   float32_t * pSrcB,
06764   uint32_t numSamples,
06765   float32_t * realResult,
06766   float32_t * imagResult);
06767 
06768   /**
06769    * @brief  Q15 complex-by-real multiplication
06770    * @param[in]  *pSrcCmplx points to the complex input vector
06771    * @param[in]  *pSrcReal points to the real input vector
06772    * @param[out]  *pCmplxDst points to the complex output vector
06773    * @param[in]  numSamples number of samples in each vector
06774    * @return none.
06775    */
06776 
06777   void arm_cmplx_mult_real_q15(
06778   q15_t * pSrcCmplx,
06779   q15_t * pSrcReal,
06780   q15_t * pCmplxDst,
06781   uint32_t numSamples);
06782 
06783   /**
06784    * @brief  Q31 complex-by-real multiplication
06785    * @param[in]  *pSrcCmplx points to the complex input vector
06786    * @param[in]  *pSrcReal points to the real input vector
06787    * @param[out]  *pCmplxDst points to the complex output vector
06788    * @param[in]  numSamples number of samples in each vector
06789    * @return none.
06790    */
06791 
06792   void arm_cmplx_mult_real_q31(
06793   q31_t * pSrcCmplx,
06794   q31_t * pSrcReal,
06795   q31_t * pCmplxDst,
06796   uint32_t numSamples);
06797 
06798   /**
06799    * @brief  Floating-point complex-by-real multiplication
06800    * @param[in]  *pSrcCmplx points to the complex input vector
06801    * @param[in]  *pSrcReal points to the real input vector
06802    * @param[out]  *pCmplxDst points to the complex output vector
06803    * @param[in]  numSamples number of samples in each vector
06804    * @return none.
06805    */
06806 
06807   void arm_cmplx_mult_real_f32(
06808   float32_t * pSrcCmplx,
06809   float32_t * pSrcReal,
06810   float32_t * pCmplxDst,
06811   uint32_t numSamples);
06812 
06813   /**
06814    * @brief  Minimum value of a Q7 vector.
06815    * @param[in]  *pSrc is input pointer
06816    * @param[in]  blockSize is the number of samples to process
06817    * @param[out]  *result is output pointer
06818    * @param[in]  index is the array index of the minimum value in the input buffer.
06819    * @return none.
06820    */
06821 
06822   void arm_min_q7(
06823   q7_t * pSrc,
06824   uint32_t blockSize,
06825   q7_t * result,
06826   uint32_t * index);
06827 
06828   /**
06829    * @brief  Minimum value of a Q15 vector.
06830    * @param[in]  *pSrc is input pointer
06831    * @param[in]  blockSize is the number of samples to process
06832    * @param[out]  *pResult is output pointer
06833    * @param[in]  *pIndex is the array index of the minimum value in the input buffer.
06834    * @return none.
06835    */
06836 
06837   void arm_min_q15(
06838   q15_t * pSrc,
06839   uint32_t blockSize,
06840   q15_t * pResult,
06841   uint32_t * pIndex);
06842 
06843   /**
06844    * @brief  Minimum value of a Q31 vector.
06845    * @param[in]  *pSrc is input pointer
06846    * @param[in]  blockSize is the number of samples to process
06847    * @param[out]  *pResult is output pointer
06848    * @param[out]  *pIndex is the array index of the minimum value in the input buffer.
06849    * @return none.
06850    */
06851   void arm_min_q31(
06852   q31_t * pSrc,
06853   uint32_t blockSize,
06854   q31_t * pResult,
06855   uint32_t * pIndex);
06856 
06857   /**
06858    * @brief  Minimum value of a floating-point vector.
06859    * @param[in]  *pSrc is input pointer
06860    * @param[in]  blockSize is the number of samples to process
06861    * @param[out]  *pResult is output pointer
06862    * @param[out]  *pIndex is the array index of the minimum value in the input buffer.
06863    * @return none.
06864    */
06865 
06866   void arm_min_f32(
06867   float32_t * pSrc,
06868   uint32_t blockSize,
06869   float32_t * pResult,
06870   uint32_t * pIndex);
06871 
06872 /**
06873  * @brief Maximum value of a Q7 vector.
06874  * @param[in]       *pSrc points to the input buffer
06875  * @param[in]       blockSize length of the input vector
06876  * @param[out]      *pResult maximum value returned here
06877  * @param[out]      *pIndex index of maximum value returned here
06878  * @return none.
06879  */
06880 
06881   void arm_max_q7(
06882   q7_t * pSrc,
06883   uint32_t blockSize,
06884   q7_t * pResult,
06885   uint32_t * pIndex);
06886 
06887 /**
06888  * @brief Maximum value of a Q15 vector.
06889  * @param[in]       *pSrc points to the input buffer
06890  * @param[in]       blockSize length of the input vector
06891  * @param[out]      *pResult maximum value returned here
06892  * @param[out]      *pIndex index of maximum value returned here
06893  * @return none.
06894  */
06895 
06896   void arm_max_q15(
06897   q15_t * pSrc,
06898   uint32_t blockSize,
06899   q15_t * pResult,
06900   uint32_t * pIndex);
06901 
06902 /**
06903  * @brief Maximum value of a Q31 vector.
06904  * @param[in]       *pSrc points to the input buffer
06905  * @param[in]       blockSize length of the input vector
06906  * @param[out]      *pResult maximum value returned here
06907  * @param[out]      *pIndex index of maximum value returned here
06908  * @return none.
06909  */
06910 
06911   void arm_max_q31(
06912   q31_t * pSrc,
06913   uint32_t blockSize,
06914   q31_t * pResult,
06915   uint32_t * pIndex);
06916 
06917 /**
06918  * @brief Maximum value of a floating-point vector.
06919  * @param[in]       *pSrc points to the input buffer
06920  * @param[in]       blockSize length of the input vector
06921  * @param[out]      *pResult maximum value returned here
06922  * @param[out]      *pIndex index of maximum value returned here
06923  * @return none.
06924  */
06925 
06926   void arm_max_f32(
06927   float32_t * pSrc,
06928   uint32_t blockSize,
06929   float32_t * pResult,
06930   uint32_t * pIndex);
06931 
06932   /**
06933    * @brief  Q15 complex-by-complex multiplication
06934    * @param[in]  *pSrcA points to the first input vector
06935    * @param[in]  *pSrcB points to the second input vector
06936    * @param[out]  *pDst  points to the output vector
06937    * @param[in]  numSamples number of complex samples in each vector
06938    * @return none.
06939    */
06940 
06941   void arm_cmplx_mult_cmplx_q15(
06942   q15_t * pSrcA,
06943   q15_t * pSrcB,
06944   q15_t * pDst,
06945   uint32_t numSamples);
06946 
06947   /**
06948    * @brief  Q31 complex-by-complex multiplication
06949    * @param[in]  *pSrcA points to the first input vector
06950    * @param[in]  *pSrcB points to the second input vector
06951    * @param[out]  *pDst  points to the output vector
06952    * @param[in]  numSamples number of complex samples in each vector
06953    * @return none.
06954    */
06955 
06956   void arm_cmplx_mult_cmplx_q31(
06957   q31_t * pSrcA,
06958   q31_t * pSrcB,
06959   q31_t * pDst,
06960   uint32_t numSamples);
06961 
06962   /**
06963    * @brief  Floating-point complex-by-complex multiplication
06964    * @param[in]  *pSrcA points to the first input vector
06965    * @param[in]  *pSrcB points to the second input vector
06966    * @param[out]  *pDst  points to the output vector
06967    * @param[in]  numSamples number of complex samples in each vector
06968    * @return none.
06969    */
06970 
06971   void arm_cmplx_mult_cmplx_f32(
06972   float32_t * pSrcA,
06973   float32_t * pSrcB,
06974   float32_t * pDst,
06975   uint32_t numSamples);
06976 
06977   /**
06978    * @brief Converts the elements of the floating-point vector to Q31 vector.
06979    * @param[in]       *pSrc points to the floating-point input vector
06980    * @param[out]      *pDst points to the Q31 output vector
06981    * @param[in]       blockSize length of the input vector
06982    * @return none.
06983    */
06984   void arm_float_to_q31(
06985   float32_t * pSrc,
06986   q31_t * pDst,
06987   uint32_t blockSize);
06988 
06989   /**
06990    * @brief Converts the elements of the floating-point vector to Q15 vector.
06991    * @param[in]       *pSrc points to the floating-point input vector
06992    * @param[out]      *pDst points to the Q15 output vector
06993    * @param[in]       blockSize length of the input vector
06994    * @return          none
06995    */
06996   void arm_float_to_q15(
06997   float32_t * pSrc,
06998   q15_t * pDst,
06999   uint32_t blockSize);
07000 
07001   /**
07002    * @brief Converts the elements of the floating-point vector to Q7 vector.
07003    * @param[in]       *pSrc points to the floating-point input vector
07004    * @param[out]      *pDst points to the Q7 output vector
07005    * @param[in]       blockSize length of the input vector
07006    * @return          none
07007    */
07008   void arm_float_to_q7(
07009   float32_t * pSrc,
07010   q7_t * pDst,
07011   uint32_t blockSize);
07012 
07013 
07014   /**
07015    * @brief  Converts the elements of the Q31 vector to Q15 vector.
07016    * @param[in]  *pSrc is input pointer
07017    * @param[out]  *pDst is output pointer
07018    * @param[in]  blockSize is the number of samples to process
07019    * @return none.
07020    */
07021   void arm_q31_to_q15(
07022   q31_t * pSrc,
07023   q15_t * pDst,
07024   uint32_t blockSize);
07025 
07026   /**
07027    * @brief  Converts the elements of the Q31 vector to Q7 vector.
07028    * @param[in]  *pSrc is input pointer
07029    * @param[out]  *pDst is output pointer
07030    * @param[in]  blockSize is the number of samples to process
07031    * @return none.
07032    */
07033   void arm_q31_to_q7(
07034   q31_t * pSrc,
07035   q7_t * pDst,
07036   uint32_t blockSize);
07037 
07038   /**
07039    * @brief  Converts the elements of the Q15 vector to floating-point vector.
07040    * @param[in]  *pSrc is input pointer
07041    * @param[out]  *pDst is output pointer
07042    * @param[in]  blockSize is the number of samples to process
07043    * @return none.
07044    */
07045   void arm_q15_to_float(
07046   q15_t * pSrc,
07047   float32_t * pDst,
07048   uint32_t blockSize);
07049 
07050 
07051   /**
07052    * @brief  Converts the elements of the Q15 vector to Q31 vector.
07053    * @param[in]  *pSrc is input pointer
07054    * @param[out]  *pDst is output pointer
07055    * @param[in]  blockSize is the number of samples to process
07056    * @return none.
07057    */
07058   void arm_q15_to_q31(
07059   q15_t * pSrc,
07060   q31_t * pDst,
07061   uint32_t blockSize);
07062 
07063 
07064   /**
07065    * @brief  Converts the elements of the Q15 vector to Q7 vector.
07066    * @param[in]  *pSrc is input pointer
07067    * @param[out]  *pDst is output pointer
07068    * @param[in]  blockSize is the number of samples to process
07069    * @return none.
07070    */
07071   void arm_q15_to_q7(
07072   q15_t * pSrc,
07073   q7_t * pDst,
07074   uint32_t blockSize);
07075 
07076 
07077   /**
07078    * @ingroup groupInterpolation
07079    */
07080 
07081   /**
07082    * @defgroup BilinearInterpolate Bilinear Interpolation
07083    *
07084    * Bilinear interpolation is an extension of linear interpolation applied to a two dimensional grid.
07085    * The underlying function <code>f(x, y)</code> is sampled on a regular grid and the interpolation process
07086    * determines values between the grid points.
07087    * Bilinear interpolation is equivalent to two step linear interpolation, first in the x-dimension and then in the y-dimension.
07088    * Bilinear interpolation is often used in image processing to rescale images.
07089    * The CMSIS DSP library provides bilinear interpolation functions for Q7, Q15, Q31, and floating-point data types.
07090    *
07091    * <b>Algorithm</b>
07092    * \par
07093    * The instance structure used by the bilinear interpolation functions describes a two dimensional data table.
07094    * For floating-point, the instance structure is defined as:
07095    * <pre>
07096    *   typedef struct
07097    *   {
07098    *     uint16_t numRows;
07099    *     uint16_t numCols;
07100    *     float32_t *pData;
07101    * } arm_bilinear_interp_instance_f32;
07102    * </pre>
07103    *
07104    * \par
07105    * where <code>numRows</code> specifies the number of rows in the table;
07106    * <code>numCols</code> specifies the number of columns in the table;
07107    * and <code>pData</code> points to an array of size <code>numRows*numCols</code> values.
07108    * The data table <code>pTable</code> is organized in row order and the supplied data values fall on integer indexes.
07109    * That is, table element (x,y) is located at <code>pTable[x + y*numCols]</code> where x and y are integers.
07110    *
07111    * \par
07112    * Let <code>(x, y)</code> specify the desired interpolation point.  Then define:
07113    * <pre>
07114    *     XF = floor(x)
07115    *     YF = floor(y)
07116    * </pre>
07117    * \par
07118    * The interpolated output point is computed as:
07119    * <pre>
07120    *  f(x, y) = f(XF, YF) * (1-(x-XF)) * (1-(y-YF))
07121    *           + f(XF+1, YF) * (x-XF)*(1-(y-YF))
07122    *           + f(XF, YF+1) * (1-(x-XF))*(y-YF)
07123    *           + f(XF+1, YF+1) * (x-XF)*(y-YF)
07124    * </pre>
07125    * Note that the coordinates (x, y) contain integer and fractional components.
07126    * The integer components specify which portion of the table to use while the
07127    * fractional components control the interpolation processor.
07128    *
07129    * \par
07130    * if (x,y) are outside of the table boundary, Bilinear interpolation returns zero output.
07131    */
07132 
07133   /**
07134    * @addtogroup BilinearInterpolate
07135    * @{
07136    */
07137 
07138   /**
07139   *
07140   * @brief  Floating-point bilinear interpolation.
07141   * @param[in,out] *S points to an instance of the interpolation structure.
07142   * @param[in] X interpolation coordinate.
07143   * @param[in] Y interpolation coordinate.
07144   * @return out interpolated value.
07145   */
07146 
07147 
07148   static __INLINE float32_t arm_bilinear_interp_f32(
07149   const arm_bilinear_interp_instance_f32 * S,
07150   float32_t X,
07151   float32_t Y)
07152   {
07153     float32_t out;
07154     float32_t f00, f01, f10, f11;
07155     float32_t *pData = S->pData;
07156     int32_t xIndex, yIndex, index;
07157     float32_t xdiff, ydiff;
07158     float32_t b1, b2, b3, b4;
07159 
07160     xIndex = (int32_t) X;
07161     yIndex = (int32_t) Y;
07162 
07163     /* Care taken for table outside boundary */
07164     /* Returns zero output when values are outside table boundary */
07165     if(xIndex < 0 || xIndex > (S->numRows - 1) || yIndex < 0
07166        || yIndex > (S->numCols - 1))
07167     {
07168       return (0);
07169     }
07170 
07171     /* Calculation of index for two nearest points in X-direction */
07172     index = (xIndex - 1) + (yIndex - 1) * S->numCols;
07173 
07174 
07175     /* Read two nearest points in X-direction */
07176     f00 = pData[index];
07177     f01 = pData[index + 1];
07178 
07179     /* Calculation of index for two nearest points in Y-direction */
07180     index = (xIndex - 1) + (yIndex) * S->numCols;
07181 
07182 
07183     /* Read two nearest points in Y-direction */
07184     f10 = pData[index];
07185     f11 = pData[index + 1];
07186 
07187     /* Calculation of intermediate values */
07188     b1 = f00;
07189     b2 = f01 - f00;
07190     b3 = f10 - f00;
07191     b4 = f00 - f01 - f10 + f11;
07192 
07193     /* Calculation of fractional part in X */
07194     xdiff = X - xIndex;
07195 
07196     /* Calculation of fractional part in Y */
07197     ydiff = Y - yIndex;
07198 
07199     /* Calculation of bi-linear interpolated output */
07200     out = b1 + b2 * xdiff + b3 * ydiff + b4 * xdiff * ydiff;
07201 
07202     /* return to application */
07203     return (out);
07204 
07205   }
07206 
07207   /**
07208   *
07209   * @brief  Q31 bilinear interpolation.
07210   * @param[in,out] *S points to an instance of the interpolation structure.
07211   * @param[in] X interpolation coordinate in 12.20 format.
07212   * @param[in] Y interpolation coordinate in 12.20 format.
07213   * @return out interpolated value.
07214   */
07215 
07216   static __INLINE q31_t arm_bilinear_interp_q31(
07217   arm_bilinear_interp_instance_q31 * S,
07218   q31_t X,
07219   q31_t Y)
07220   {
07221     q31_t out;                                   /* Temporary output */
07222     q31_t acc = 0;                               /* output */
07223     q31_t xfract, yfract;                        /* X, Y fractional parts */
07224     q31_t x1, x2, y1, y2;                        /* Nearest output values */
07225     int32_t rI, cI;                              /* Row and column indices */
07226     q31_t *pYData = S->pData;                    /* pointer to output table values */
07227     uint32_t nCols = S->numCols;                 /* num of rows */
07228 
07229 
07230     /* Input is in 12.20 format */
07231     /* 12 bits for the table index */
07232     /* Index value calculation */
07233     rI = ((X & 0xFFF00000) >> 20u);
07234 
07235     /* Input is in 12.20 format */
07236     /* 12 bits for the table index */
07237     /* Index value calculation */
07238     cI = ((Y & 0xFFF00000) >> 20u);
07239 
07240     /* Care taken for table outside boundary */
07241     /* Returns zero output when values are outside table boundary */
07242     if(rI < 0 || rI > (S->numRows - 1) || cI < 0 || cI > (S->numCols - 1))
07243     {
07244       return (0);
07245     }
07246 
07247     /* 20 bits for the fractional part */
07248     /* shift left xfract by 11 to keep 1.31 format */
07249     xfract = (X & 0x000FFFFF) << 11u;
07250 
07251     /* Read two nearest output values from the index */
07252     x1 = pYData[(rI) + nCols * (cI)];
07253     x2 = pYData[(rI) + nCols * (cI) + 1u];
07254 
07255     /* 20 bits for the fractional part */
07256     /* shift left yfract by 11 to keep 1.31 format */
07257     yfract = (Y & 0x000FFFFF) << 11u;
07258 
07259     /* Read two nearest output values from the index */
07260     y1 = pYData[(rI) + nCols * (cI + 1)];
07261     y2 = pYData[(rI) + nCols * (cI + 1) + 1u];
07262 
07263     /* Calculation of x1 * (1-xfract ) * (1-yfract) and acc is in 3.29(q29) format */
07264     out = ((q31_t) (((q63_t) x1 * (0x7FFFFFFF - xfract)) >> 32));
07265     acc = ((q31_t) (((q63_t) out * (0x7FFFFFFF - yfract)) >> 32));
07266 
07267     /* x2 * (xfract) * (1-yfract)  in 3.29(q29) and adding to acc */
07268     out = ((q31_t) ((q63_t) x2 * (0x7FFFFFFF - yfract) >> 32));
07269     acc += ((q31_t) ((q63_t) out * (xfract) >> 32));
07270 
07271     /* y1 * (1 - xfract) * (yfract)  in 3.29(q29) and adding to acc */
07272     out = ((q31_t) ((q63_t) y1 * (0x7FFFFFFF - xfract) >> 32));
07273     acc += ((q31_t) ((q63_t) out * (yfract) >> 32));
07274 
07275     /* y2 * (xfract) * (yfract)  in 3.29(q29) and adding to acc */
07276     out = ((q31_t) ((q63_t) y2 * (xfract) >> 32));
07277     acc += ((q31_t) ((q63_t) out * (yfract) >> 32));
07278 
07279     /* Convert acc to 1.31(q31) format */
07280     return (acc << 2u);
07281 
07282   }
07283 
07284   /**
07285   * @brief  Q15 bilinear interpolation.
07286   * @param[in,out] *S points to an instance of the interpolation structure.
07287   * @param[in] X interpolation coordinate in 12.20 format.
07288   * @param[in] Y interpolation coordinate in 12.20 format.
07289   * @return out interpolated value.
07290   */
07291 
07292   static __INLINE q15_t arm_bilinear_interp_q15(
07293   arm_bilinear_interp_instance_q15 * S,
07294   q31_t X,
07295   q31_t Y)
07296   {
07297     q63_t acc = 0;                               /* output */
07298     q31_t out;                                   /* Temporary output */
07299     q15_t x1, x2, y1, y2;                        /* Nearest output values */
07300     q31_t xfract, yfract;                        /* X, Y fractional parts */
07301     int32_t rI, cI;                              /* Row and column indices */
07302     q15_t *pYData = S->pData;                    /* pointer to output table values */
07303     uint32_t nCols = S->numCols;                 /* num of rows */
07304 
07305     /* Input is in 12.20 format */
07306     /* 12 bits for the table index */
07307     /* Index value calculation */
07308     rI = ((X & 0xFFF00000) >> 20);
07309 
07310     /* Input is in 12.20 format */
07311     /* 12 bits for the table index */
07312     /* Index value calculation */
07313     cI = ((Y & 0xFFF00000) >> 20);
07314 
07315     /* Care taken for table outside boundary */
07316     /* Returns zero output when values are outside table boundary */
07317     if(rI < 0 || rI > (S->numRows - 1) || cI < 0 || cI > (S->numCols - 1))
07318     {
07319       return (0);
07320     }
07321 
07322     /* 20 bits for the fractional part */
07323     /* xfract should be in 12.20 format */
07324     xfract = (X & 0x000FFFFF);
07325 
07326     /* Read two nearest output values from the index */
07327     x1 = pYData[(rI) + nCols * (cI)];
07328     x2 = pYData[(rI) + nCols * (cI) + 1u];
07329 
07330 
07331     /* 20 bits for the fractional part */
07332     /* yfract should be in 12.20 format */
07333     yfract = (Y & 0x000FFFFF);
07334 
07335     /* Read two nearest output values from the index */
07336     y1 = pYData[(rI) + nCols * (cI + 1)];
07337     y2 = pYData[(rI) + nCols * (cI + 1) + 1u];
07338 
07339     /* Calculation of x1 * (1-xfract ) * (1-yfract) and acc is in 13.51 format */
07340 
07341     /* x1 is in 1.15(q15), xfract in 12.20 format and out is in 13.35 format */
07342     /* convert 13.35 to 13.31 by right shifting  and out is in 1.31 */
07343     out = (q31_t) (((q63_t) x1 * (0xFFFFF - xfract)) >> 4u);
07344     acc = ((q63_t) out * (0xFFFFF - yfract));
07345 
07346     /* x2 * (xfract) * (1-yfract)  in 1.51 and adding to acc */
07347     out = (q31_t) (((q63_t) x2 * (0xFFFFF - yfract)) >> 4u);
07348     acc += ((q63_t) out * (xfract));
07349 
07350     /* y1 * (1 - xfract) * (yfract)  in 1.51 and adding to acc */
07351     out = (q31_t) (((q63_t) y1 * (0xFFFFF - xfract)) >> 4u);
07352     acc += ((q63_t) out * (yfract));
07353 
07354     /* y2 * (xfract) * (yfract)  in 1.51 and adding to acc */
07355     out = (q31_t) (((q63_t) y2 * (xfract)) >> 4u);
07356     acc += ((q63_t) out * (yfract));
07357 
07358     /* acc is in 13.51 format and down shift acc by 36 times */
07359     /* Convert out to 1.15 format */
07360     return (acc >> 36);
07361 
07362   }
07363 
07364   /**
07365   * @brief  Q7 bilinear interpolation.
07366   * @param[in,out] *S points to an instance of the interpolation structure.
07367   * @param[in] X interpolation coordinate in 12.20 format.
07368   * @param[in] Y interpolation coordinate in 12.20 format.
07369   * @return out interpolated value.
07370   */
07371 
07372   static __INLINE q7_t arm_bilinear_interp_q7(
07373   arm_bilinear_interp_instance_q7 * S,
07374   q31_t X,
07375   q31_t Y)
07376   {
07377     q63_t acc = 0;                               /* output */
07378     q31_t out;                                   /* Temporary output */
07379     q31_t xfract, yfract;                        /* X, Y fractional parts */
07380     q7_t x1, x2, y1, y2;                         /* Nearest output values */
07381     int32_t rI, cI;                              /* Row and column indices */
07382     q7_t *pYData = S->pData;                     /* pointer to output table values */
07383     uint32_t nCols = S->numCols;                 /* num of rows */
07384 
07385     /* Input is in 12.20 format */
07386     /* 12 bits for the table index */
07387     /* Index value calculation */
07388     rI = ((X & 0xFFF00000) >> 20);
07389 
07390     /* Input is in 12.20 format */
07391     /* 12 bits for the table index */
07392     /* Index value calculation */
07393     cI = ((Y & 0xFFF00000) >> 20);
07394 
07395     /* Care taken for table outside boundary */
07396     /* Returns zero output when values are outside table boundary */
07397     if(rI < 0 || rI > (S->numRows - 1) || cI < 0 || cI > (S->numCols - 1))
07398     {
07399       return (0);
07400     }
07401 
07402     /* 20 bits for the fractional part */
07403     /* xfract should be in 12.20 format */
07404     xfract = (X & 0x000FFFFF);
07405 
07406     /* Read two nearest output values from the index */
07407     x1 = pYData[(rI) + nCols * (cI)];
07408     x2 = pYData[(rI) + nCols * (cI) + 1u];
07409 
07410 
07411     /* 20 bits for the fractional part */
07412     /* yfract should be in 12.20 format */
07413     yfract = (Y & 0x000FFFFF);
07414 
07415     /* Read two nearest output values from the index */
07416     y1 = pYData[(rI) + nCols * (cI + 1)];
07417     y2 = pYData[(rI) + nCols * (cI + 1) + 1u];
07418 
07419     /* Calculation of x1 * (1-xfract ) * (1-yfract) and acc is in 16.47 format */
07420     out = ((x1 * (0xFFFFF - xfract)));
07421     acc = (((q63_t) out * (0xFFFFF - yfract)));
07422 
07423     /* x2 * (xfract) * (1-yfract)  in 2.22 and adding to acc */
07424     out = ((x2 * (0xFFFFF - yfract)));
07425     acc += (((q63_t) out * (xfract)));
07426 
07427     /* y1 * (1 - xfract) * (yfract)  in 2.22 and adding to acc */
07428     out = ((y1 * (0xFFFFF - xfract)));
07429     acc += (((q63_t) out * (yfract)));
07430 
07431     /* y2 * (xfract) * (yfract)  in 2.22 and adding to acc */
07432     out = ((y2 * (yfract)));
07433     acc += (((q63_t) out * (xfract)));
07434 
07435     /* acc in 16.47 format and down shift by 40 to convert to 1.7 format */
07436     return (acc >> 40);
07437 
07438   }
07439 
07440   /**
07441    * @} end of BilinearInterpolate group
07442    */
07443    
07444 
07445 //SMMLAR
07446 #define multAcc_32x32_keep32_R(a, x, y) \
07447     a = (q31_t) (((((q63_t) a) << 32) + ((q63_t) x * y) + 0x80000000LL ) >> 32)
07448 
07449 //SMMLSR
07450 #define multSub_32x32_keep32_R(a, x, y) \
07451     a = (q31_t) (((((q63_t) a) << 32) - ((q63_t) x * y) + 0x80000000LL ) >> 32)
07452 
07453 //SMMULR
07454 #define mult_32x32_keep32_R(a, x, y) \
07455     a = (q31_t) (((q63_t) x * y + 0x80000000LL ) >> 32)
07456 
07457 //SMMLA
07458 #define multAcc_32x32_keep32(a, x, y) \
07459     a += (q31_t) (((q63_t) x * y) >> 32)
07460 
07461 //SMMLS
07462 #define multSub_32x32_keep32(a, x, y) \
07463     a -= (q31_t) (((q63_t) x * y) >> 32)
07464 
07465 //SMMUL
07466 #define mult_32x32_keep32(a, x, y) \
07467     a = (q31_t) (((q63_t) x * y ) >> 32)
07468 
07469 
07470 #if defined ( __CC_ARM ) //Keil
07471 
07472 //Enter low optimization region - place directly above function definition
07473     #ifdef ARM_MATH_CM4
07474       #define LOW_OPTIMIZATION_ENTER \
07475          _Pragma ("push")         \
07476          _Pragma ("O1")
07477     #else
07478       #define LOW_OPTIMIZATION_ENTER 
07479     #endif
07480 
07481 //Exit low optimization region - place directly after end of function definition
07482     #ifdef ARM_MATH_CM4
07483       #define LOW_OPTIMIZATION_EXIT \
07484          _Pragma ("pop")
07485     #else
07486       #define LOW_OPTIMIZATION_EXIT  
07487     #endif
07488 
07489 //Enter low optimization region - place directly above function definition
07490   #define IAR_ONLY_LOW_OPTIMIZATION_ENTER
07491 
07492 //Exit low optimization region - place directly after end of function definition
07493   #define IAR_ONLY_LOW_OPTIMIZATION_EXIT
07494 
07495 #elif defined(__ICCARM__) //IAR
07496 
07497 //Enter low optimization region - place directly above function definition
07498     #ifdef ARM_MATH_CM4
07499       #define LOW_OPTIMIZATION_ENTER \
07500          _Pragma ("optimize=low")
07501     #else
07502       #define LOW_OPTIMIZATION_ENTER   
07503     #endif
07504 
07505 //Exit low optimization region - place directly after end of function definition
07506   #define LOW_OPTIMIZATION_EXIT
07507 
07508 //Enter low optimization region - place directly above function definition
07509     #ifdef ARM_MATH_CM4
07510       #define IAR_ONLY_LOW_OPTIMIZATION_ENTER \
07511          _Pragma ("optimize=low")
07512     #else
07513       #define IAR_ONLY_LOW_OPTIMIZATION_ENTER   
07514     #endif
07515 
07516 //Exit low optimization region - place directly after end of function definition
07517   #define IAR_ONLY_LOW_OPTIMIZATION_EXIT
07518 
07519 #elif defined(__GNUC__)
07520 
07521   #define LOW_OPTIMIZATION_ENTER __attribute__(( optimize("-O1") ))
07522 
07523   #define LOW_OPTIMIZATION_EXIT
07524 
07525   #define IAR_ONLY_LOW_OPTIMIZATION_ENTER
07526 
07527   #define IAR_ONLY_LOW_OPTIMIZATION_EXIT
07528 
07529 #elif defined(__CSMC__)     // Cosmic
07530 
07531 #define LOW_OPTIMIZATION_ENTER
07532 #define LOW_OPTIMIZATION_EXIT
07533 #define IAR_ONLY_LOW_OPTIMIZATION_ENTER
07534 #define IAR_ONLY_LOW_OPTIMIZATION_EXIT
07535 
07536 #elif defined(__TASKING__)      // TASKING
07537 
07538 #define LOW_OPTIMIZATION_ENTER
07539 #define LOW_OPTIMIZATION_EXIT
07540 #define IAR_ONLY_LOW_OPTIMIZATION_ENTER
07541 #define IAR_ONLY_LOW_OPTIMIZATION_EXIT
07542 
07543 #endif
07544 
07545 
07546 #ifdef  __cplusplus
07547 }
07548 #endif
07549 
07550 
07551 #endif /* _ARM_MATH_H */
07552 
07553 /**
07554  *
07555  * End of file.
07556  */