Zephyr Project API
4.4.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
utils.h
Go to the documentation of this file.
1
/*
2
* Copyright (C) 2024 OWL Services LLC. All rights reserved.
3
*
4
* SPDX-License-Identifier: Apache-2.0
5
*/
6
12
13
#ifndef INCLUDE_ZEPHYR_DSP_UTILS_H_
14
#define INCLUDE_ZEPHYR_DSP_UTILS_H_
15
16
#include <
stdint.h
>
17
#include <
zephyr/sys/minmax.h
>
18
#include <
zephyr/kernel.h
>
19
#include <
zephyr/dsp/types.h
>
20
21
#ifdef __cplusplus
22
extern
"C"
{
23
#endif
24
33
43
51
#define Z_SHIFT_Q7_TO_F32(src, m) ((float32_t)(((src << m)) / (float32_t)(1U << 7)))
52
60
#define Z_SHIFT_Q15_TO_F32(src, m) ((float32_t)((src << m) / (float32_t)(1U << 15)))
61
69
#define Z_SHIFT_Q31_TO_F32(src, m) ((float32_t)(((int64_t)src) << m) / (float32_t)(1U << 31))
70
78
#define Z_SHIFT_Q7_TO_F64(src, m) (((float64_t)(src << m)) / (1U << 7))
79
87
#define Z_SHIFT_Q15_TO_F64(src, m) (((float64_t)(src << m)) / (1UL << 15))
88
96
#define Z_SHIFT_Q31_TO_F64(src, m) ((float64_t)(((int64_t)src) << m) / (1ULL << 31))
97
101
111
119
#define Z_SHIFT_F32_TO_Q7(src, m) \
120
((q7_t)clamp((int32_t)(src * (1U << 7)) >> m, INT8_MIN, INT8_MAX))
121
129
#define Z_SHIFT_F32_TO_Q15(src, m) \
130
((q15_t)clamp((int32_t)(src * (1U << 15)) >> m, INT16_MIN, INT16_MAX))
131
139
#define Z_SHIFT_F32_TO_Q31(src, m) \
140
((q31_t)clamp((int64_t)(src * (1U << 31)) >> m, INT32_MIN, INT32_MAX))
141
149
#define Z_SHIFT_F64_TO_Q7(src, m) \
150
((q7_t)clamp((int32_t)(src * (1U << 7)) >> m, INT8_MIN, INT8_MAX))
151
159
#define Z_SHIFT_F64_TO_Q15(src, m) \
160
((q15_t)clamp((int32_t)(src * (1U << 15)) >> m, INT16_MIN, INT16_MAX))
161
169
#define Z_SHIFT_F64_TO_Q31(src, m) \
170
((q31_t)clamp((int64_t)(src * (1U << 31)) >> m, INT32_MIN, INT32_MAX))
171
175
179
180
#ifdef __cplusplus
181
}
182
#endif
183
184
#endif
/* INCLUDE_ZEPHYR_DSP_UTILS_H_ */
types.h
kernel.h
Public kernel APIs.
minmax.h
Lowercase min/max/clamp helpers.
stdint.h
include
zephyr
dsp
utils.h
Generated on
for Zephyr Project API by
1.16.1