3#ifndef QAMBISONICDECODER_P_H
4#define QAMBISONICDECODER_P_H
17#include <QtSpatialAudio/private/qtspatialaudioglobal_p.h>
18#include <QtMultimedia/qaudioformat.h>
19#include <QtCore/qspan.h>
25struct QAmbisonicDecoderData;
47 int outputSize(
int nSamples)
const {
return outputChannels * nSamples; }
50 void processBuffer(QSpan<
const float *> input, QSpan<
float> output);
51 void processBuffer(QSpan<
const float *> input, QSpan<
short> output);
60 QAudioFormat::ChannelConfig channelConfig;
62 int inputChannels = 0;
63 int outputChannels = 0;
64 const QAmbisonicDecoderData *decoderData =
nullptr;
65 std::unique_ptr<QAmbisonicDecoderFilter[]> filters;
66 std::unique_ptr<
float[]> simpleDecoderFactors;
68 const float *reverbFactors =
nullptr;
69 std::unique_ptr<
float[]> m_reverbFactorsOwned;
QAmbisonicDecoderFilter()=default
void configure(float sampleRate, float cutoffFrequency=380)
static constexpr int maxAmbisonicOrder
void processBuffer(QSpan< const float * > input, QSpan< float > output)
int nInputChannels() const
QAmbisonicDecoder(AmbisonicOrder ambisonicOrder, const QAudioFormat &format)
static constexpr int maxAmbisonicChannels
int nOutputChannels() const
int outputSize(int nSamples) const
bool hasValidConfig() const
void processBufferWithReverb(QSpan< const float * > input, QSpan< const float *, 2 > reverb, QSpan< short > output)
static constexpr QAmbisonicDecoderData decoderMap[]
constexpr float reverb_x_1[]
constexpr float reverb_x_0[]