mirror of
https://gitlab.freedesktop.org/pipewire/pipewire.git
synced 2025-10-29 05:40:27 -04:00
Including C headers inside of `extern "C"` breaks use from C++. Hoist the includes of standard C headers above the block so we don't try to mangle the stdlib. I initially tried to scope this with a targeted change but it's too hard to do correctly that way. This way, we avoid whack-a-mole. Firefox is working around this in their e21461b7b8b39cc31ba53c47d4f6f310c673ff2f commit. Bug: https://bugzilla.mozilla.org/1953080
56 lines
1 KiB
C
56 lines
1 KiB
C
/* Hilbert function */
|
|
/* SPDX-FileCopyrightText: Copyright © 2021 Wim Taymans */
|
|
/* SPDX-License-Identifier: MIT */
|
|
|
|
#ifndef HILBERT_H
|
|
#define HILBERT_H
|
|
|
|
#include <errno.h>
|
|
#include <stddef.h>
|
|
#include <math.h>
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
static inline void blackman_window(float *taps, int n_taps)
|
|
{
|
|
int n;
|
|
for (n = 0; n < n_taps; n++) {
|
|
float w = 2.0f * (float)M_PI * n / (n_taps-1);
|
|
taps[n] = 0.3635819f - 0.4891775f * cosf(w)
|
|
+ 0.1365995f * cosf(2 * w) - 0.0106411f * cosf(3 * w);
|
|
}
|
|
}
|
|
|
|
static inline int hilbert_generate(float *taps, int n_taps)
|
|
{
|
|
int i;
|
|
|
|
if ((n_taps & 1) == 0)
|
|
return -EINVAL;
|
|
|
|
for (i = 0; i < n_taps; i++) {
|
|
int k = -(n_taps / 2) + i;
|
|
if (k & 1) {
|
|
float pk = (float)M_PI * k;
|
|
taps[i] *= (1.0f - cosf(pk)) / pk;
|
|
} else {
|
|
taps[i] = 0.0f;
|
|
}
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
static inline void reverse_taps(float *taps, int n_taps)
|
|
{
|
|
int i;
|
|
for (i = 0; i < n_taps/2; i++)
|
|
SPA_SWAP(taps[i], taps[n_taps-1-i]);
|
|
}
|
|
|
|
#ifdef __cplusplus
|
|
} /* extern "C" */
|
|
#endif
|
|
|
|
#endif /* HILBERT_H */
|