Zephyr API Documentation 4.0.0-rc2
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
Vector Multiplication

Functions

void zdsp_mult_q7 (const q7_t *src_a, const q7_t *src_b, q7_t *dst, uint32_t block_size)
 Q7 vector multiplication.
 
void zdsp_mult_q15 (const q15_t *src_a, const q15_t *src_b, q15_t *dst, uint32_t block_size)
 Q15 vector multiplication.
 
void zdsp_mult_q31 (const q31_t *src_a, const q31_t *src_b, q31_t *dst, uint32_t block_size)
 Q31 vector multiplication.
 
void zdsp_mult_f32 (const float32_t *src_a, const float32_t *src_b, float32_t *dst, uint32_t block_size)
 Floating-point vector multiplication.
 
DSP_FUNC_SCOPE void zdsp_mult_f16 (const float16_t *src_a, const float16_t *src_b, float16_t *dst, uint32_t block_size)
 Floating-point vector multiplication.
 

Detailed Description

Element-by-element multiplication of two vectors.

    dst[n] = src_a[n] * src_b[n],   0 <= n < block_size.

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

Function Documentation

◆ zdsp_mult_f16()

DSP_FUNC_SCOPE void zdsp_mult_f16 ( const float16_t * src_a,
const float16_t * src_b,
float16_t * dst,
uint32_t block_size )

#include <zephyr/dsp/basicmath_f16.h>

Floating-point vector multiplication.

Parameters
[in]src_apoints to the first input vector
[in]src_bpoints to the second input vector
[out]dstpoints to the output vector
[in]block_sizenumber of samples in each vector

◆ zdsp_mult_f32()

void zdsp_mult_f32 ( const float32_t * src_a,
const float32_t * src_b,
float32_t * dst,
uint32_t block_size )

#include <zephyr/dsp/basicmath.h>

Floating-point vector multiplication.

Parameters
[in]src_apoints to the first input vector
[in]src_bpoints to the second input vector
[out]dstpoints to the output vector
[in]block_sizenumber of samples in each vector

◆ zdsp_mult_q15()

void zdsp_mult_q15 ( const q15_t * src_a,
const q15_t * src_b,
q15_t * dst,
uint32_t block_size )

#include <zephyr/dsp/basicmath.h>

Q15 vector multiplication.

Scaling and Overflow Behavior
The function uses saturating arithmetic. Results outside of the allowable Q15 range [0x8000 0x7FFF] are saturated.
Parameters
[in]src_apoints to the first input vector
[in]src_bpoints to the second input vector
[out]dstpoints to the output vector
[in]block_sizenumber of samples in each vector

◆ zdsp_mult_q31()

void zdsp_mult_q31 ( const q31_t * src_a,
const q31_t * src_b,
q31_t * dst,
uint32_t block_size )

#include <zephyr/dsp/basicmath.h>

Q31 vector multiplication.

Scaling and Overflow Behavior
The function uses saturating arithmetic. Results outside of the allowable Q31 range[0x80000000 0x7FFFFFFF] are saturated.
Parameters
[in]src_apoints to the first input vector
[in]src_bpoints to the second input vector
[out]dstpoints to the output vector
[in]block_sizenumber of samples in each vector

◆ zdsp_mult_q7()

void zdsp_mult_q7 ( const q7_t * src_a,
const q7_t * src_b,
q7_t * dst,
uint32_t block_size )

#include <zephyr/dsp/basicmath.h>

Q7 vector multiplication.

Scaling and Overflow Behavior
The function uses saturating arithmetic. Results outside of the allowable Q7 range [0x80 0x7F] are saturated.
Parameters
[in]src_apoints to the first input vector
[in]src_bpoints to the second input vector
[out]dstpoints to the output vector
[in]block_sizenumber of samples in each vector