Functions

Vector Multiplication
[Basic Math Functions]

Functions

void arm_mult_f32 (float32_t *pSrcA, float32_t *pSrcB, float32_t *pDst, uint32_t blockSize)
void arm_mult_q31 (q31_t *pSrcA, q31_t *pSrcB, q31_t *pDst, uint32_t blockSize)
void arm_mult_q15 (q15_t *pSrcA, q15_t *pSrcB, q15_t *pDst, uint32_t blockSize)
void arm_mult_q7 (q7_t *pSrcA, q7_t *pSrcB, q7_t *pDst, uint32_t blockSize)

Detailed Description

Element-by-element multiplication of two vectors.

      
     pDst[n] = pSrcA[n] * pSrcB[n],   0 <= n < blockSize.      
 

There are separate functions for floating-point, Q7, Q15, and Q31 data types.


Function Documentation

void arm_mult_f32 ( float32_t *  pSrcA,
float32_t *  pSrcB,
float32_t *  pDst,
uint32_t  blockSize 
)

Floating-point vector multiplication.

Parameters:
[in]*pSrcApoints to the first input vector
[in]*pSrcBpoints to the second input vector
[out]*pDstpoints to the output vector
[in]blockSizenumber of samples in each vector
Returns:
none.
Examples:
arm_dotproduct_example_f32.c, arm_sin_cos_example_f32.c, and arm_variance_example_f32.c.

Definition at line 57 of file arm_mult_f32.c.

void arm_mult_q31 ( q31_t *  pSrcA,
q31_t *  pSrcB,
q31_t *  pDst,
uint32_t  blockSize 
)

Q31 vector multiplication.

Parameters:
[in]*pSrcApoints to the first input vector
[in]*pSrcBpoints to the second input vector
[out]*pDstpoints to the output vector
[in]blockSizenumber of samples in each vector
Returns:
none.

Scaling and Overflow Behavior:

The function uses saturating arithmetic. Results outside of the allowable Q31 range[0x80000000 0x7FFFFFFF] will be saturated.

Definition at line 50 of file arm_mult_q31.c.

void arm_mult_q15 ( q15_t *  pSrcA,
q15_t *  pSrcB,
q15_t *  pDst,
uint32_t  blockSize 
)

Q15 vector multiplication.

Parameters:
[in]*pSrcApoints to the first input vector
[in]*pSrcBpoints to the second input vector
[out]*pDstpoints to the output vector
[in]blockSizenumber of samples in each vector
Returns:
none.
Conditions for optimum performance
Input and output buffers should be aligned by 32-bit

Scaling and Overflow Behavior:

The function uses saturating arithmetic. Results outside of the allowable Q15 range [0x8000 0x7FFF] will be saturated.

Definition at line 55 of file arm_mult_q15.c.

void arm_mult_q7 ( q7_t *  pSrcA,
q7_t *  pSrcB,
q7_t *  pDst,
uint32_t  blockSize 
)

Q7 vector multiplication.

Parameters:
[in]*pSrcApoints to the first input vector
[in]*pSrcBpoints to the second input vector
[out]*pDstpoints to the output vector
[in]blockSizenumber of samples in each vector
Returns:
none.
Conditions for optimum performance
Input and output buffers should be aligned by 32-bit

Scaling and Overflow Behavior:

The function uses saturating arithmetic. Results outside of the allowable Q7 range [0x80 0x7F] will be saturated.

Definition at line 53 of file arm_mult_q7.c.

 All Data Structures Files Functions Variables Enumerations Enumerator Defines