Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024 #include "arm_math.h"
00025
00059 arm_status arm_fir_decimate_init_q15(
00060 arm_fir_decimate_instance_q15 * S,
00061 uint16_t numTaps,
00062 uint8_t M,
00063 q15_t * pCoeffs,
00064 q15_t * pState,
00065 uint32_t blockSize)
00066 {
00067
00068 arm_status status;
00069
00070
00071 if((blockSize % M) != 0u)
00072 {
00073
00074 status = ARM_MATH_LENGTH_ERROR;
00075 }
00076 else
00077 {
00078
00079 S->numTaps = numTaps;
00080
00081
00082 S->pCoeffs = pCoeffs;
00083
00084
00085 memset(pState, 0, (numTaps + (blockSize - 1u)) * sizeof(q15_t));
00086
00087
00088 S->pState = pState;
00089
00090
00091 S->M = M;
00092
00093 status = ARM_MATH_SUCCESS;
00094 }
00095
00096 return (status);
00097
00098 }
00099