1 /* Copyright (C) 2010-2021 ARM Limited or its affiliates. All rights reserved.
2  * SPDX-License-Identifier: Apache-2.0
3  */
4 
5 /**
6  * @file zephyr/dsp/basicmath_f16.h
7  *
8  * @brief Public APIs for DSP basicmath for 16 bit floating point
9  */
10 
11 #ifndef ZEPHYR_INCLUDE_DSP_BASICMATH_F16_H_
12 #define ZEPHYR_INCLUDE_DSP_BASICMATH_F16_H_
13 
14 #ifndef CONFIG_FP16
15 #error "Cannot use float16 DSP functionality without CONFIG_FP16 enabled"
16 #endif /* CONFIG_FP16 */
17 
18 #include <zephyr/dsp/dsp.h>
19 
20 #ifdef __cplusplus
21 extern "C" {
22 #endif
23 
24 /**
25  * @ingroup math_dsp_basic_mult
26  * @brief Floating-point vector multiplication.
27  * @param[in]  src_a      points to the first input vector
28  * @param[in]  src_b      points to the second input vector
29  * @param[out] dst        points to the output vector
30  * @param[in]  block_size number of samples in each vector
31  */
32 DSP_FUNC_SCOPE void zdsp_mult_f16(const float16_t *src_a, const float16_t *src_b, float16_t *dst,
33 				  uint32_t block_size);
34 
35 /**
36  * @ingroup math_dsp_basic_add
37  * @brief Floating-point vector addition.
38  * @param[in]  src_a      points to the first input vector
39  * @param[in]  src_b      points to the second input vector
40  * @param[out] dst        points to the output vector
41  * @param[in]  block_size number of samples in each vector
42  */
43 DSP_FUNC_SCOPE void zdsp_add_f16(const float16_t *src_a, const float16_t *src_b, float16_t *dst,
44 				 uint32_t block_size);
45 
46 /**
47  * @ingroup math_dsp_basic_sub
48  * @brief Floating-point vector subtraction.
49  * @param[in]  src_a      points to the first input vector
50  * @param[in]  src_b      points to the second input vector
51  * @param[out] dst        points to the output vector
52  * @param[in]  block_size number of samples in each vector
53  */
54 DSP_FUNC_SCOPE void zdsp_sub_f16(const float16_t *src_a, const float16_t *src_b, float16_t *dst,
55 				 uint32_t block_size);
56 
57 /**
58  * @ingroup math_dsp_basic_scale
59  * @brief Multiplies a floating-point vector by a scalar.
60  * @param[in]  src        points to the input vector
61  * @param[in]  scale      scale factor to be applied
62  * @param[out] dst        points to the output vector
63  * @param[in]  block_size number of samples in the vector
64  */
65 DSP_FUNC_SCOPE void zdsp_scale_f16(const float16_t *src, float16_t scale, float16_t *dst,
66 				   uint32_t block_size);
67 
68 /**
69  * @ingroup math_dsp_basic_abs
70  * @brief Floating-point vector absolute value.
71  * @param[in]  src        points to the input buffer
72  * @param[out] dst        points to the output buffer
73  * @param[in]  block_size number of samples in each vector
74  */
75 DSP_FUNC_SCOPE void zdsp_abs_f16(const float16_t *src, float16_t *dst, uint32_t block_size);
76 
77 /**
78  * @ingroup math_dsp_basic_dot
79  * @brief Dot product of floating-point vectors.
80  * @param[in]  src_a      points to the first input vector
81  * @param[in]  src_b      points to the second input vector
82  * @param[in]  block_size number of samples in each vector
83  * @param[out] result     output result returned here
84  */
85 DSP_FUNC_SCOPE void zdsp_dot_prod_f16(const float16_t *src_a, const float16_t *src_b,
86 				      uint32_t block_size, float16_t *result);
87 
88 /**
89  * @ingroup math_dsp_basic_offset
90  * @brief  Adds a constant offset to a floating-point vector.
91  * @param[in]  src       points to the input vector
92  * @param[in]  offset     is the offset to be added
93  * @param[out] dst       points to the output vector
94  * @param[in]  block_size  number of samples in the vector
95  */
96 DSP_FUNC_SCOPE void zdsp_offset_f16(const float16_t *src, float16_t offset, float16_t *dst,
97 				    uint32_t block_size);
98 
99 /**
100  * @ingroup math_dsp_basic_negate
101  * @brief  Negates the elements of a floating-point vector.
102  * @param[in]  src        points to the input vector
103  * @param[out] dst        points to the output vector
104  * @param[in]  block_size number of samples in the vector
105  */
106 DSP_FUNC_SCOPE void zdsp_negate_f16(const float16_t *src, float16_t *dst, uint32_t block_size);
107 
108 /**
109  * @ingroup math_dsp_basic_clip
110  * @brief         Elementwise floating-point clipping
111  * @param[in]     src          points to input values
112  * @param[out]    dst          points to output clipped values
113  * @param[in]     low          lower bound
114  * @param[in]     high         higher bound
115  * @param[in]     num_samples  number of samples to clip
116  */
117 DSP_FUNC_SCOPE void zdsp_clip_f16(const float16_t *src, float16_t *dst, float16_t low,
118 				  float16_t high, uint32_t num_samples);
119 
120 #ifdef __cplusplus
121 }
122 #endif
123 
124 #endif /* ZEPHYR_INCLUDE_DSP_BASICMATH_F16_H_ */
125