pipewire/spa/plugins/audioconvert/hilbert.h
Sam James b943c31fd8
*: don't include standard C headers inside of extern "C"
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
2025-05-30 09:48:28 +01:00

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 */