mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-10-27 20:25:44 +00:00
80 lines
2.1 KiB
C
80 lines
2.1 KiB
C
|
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
||
|
/* vim:set ts=2 sw=2 sts=2 et cindent: */
|
||
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
||
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||
|
|
||
|
#ifndef FFTBlock_h_
|
||
|
#define FFTBlock_h_
|
||
|
|
||
|
#include "nsTArray.h"
|
||
|
#include "AudioNodeEngine.h"
|
||
|
#include "kiss_fft/kiss_fftr.h"
|
||
|
|
||
|
namespace mozilla {
|
||
|
|
||
|
// This class defines an FFT block, loosely modeled after Blink's FFTFrame
|
||
|
// class to make sharing code with Blink easy.
|
||
|
// Currently it's implemented on top of KissFFT on all platforms.
|
||
|
class FFTBlock {
|
||
|
public:
|
||
|
explicit FFTBlock(uint32_t aFFTSize)
|
||
|
: mFFTSize(aFFTSize)
|
||
|
{
|
||
|
mOutputBuffer.SetLength(aFFTSize / 2 + 1);
|
||
|
PodZero(mOutputBuffer.Elements(), aFFTSize / 2 + 1);
|
||
|
}
|
||
|
|
||
|
void PerformFFT(const float* aData)
|
||
|
{
|
||
|
kiss_fftr_cfg fft = kiss_fftr_alloc(mFFTSize, 0, nullptr, nullptr);
|
||
|
kiss_fftr(fft, aData, mOutputBuffer.Elements());
|
||
|
free(fft);
|
||
|
}
|
||
|
void PerformInverseFFT(float* aData) const
|
||
|
{
|
||
|
kiss_fftr_cfg fft = kiss_fftr_alloc(mFFTSize, 1, nullptr, nullptr);
|
||
|
kiss_fftri(fft, mOutputBuffer.Elements(), aData);
|
||
|
free(fft);
|
||
|
for (uint32_t i = 0; i < mFFTSize; ++i) {
|
||
|
aData[i] /= mFFTSize;
|
||
|
}
|
||
|
}
|
||
|
void Multiply(const FFTBlock& aFrame)
|
||
|
{
|
||
|
BufferComplexMultiply(reinterpret_cast<const float*>(mOutputBuffer.Elements()),
|
||
|
reinterpret_cast<const float*>(aFrame.mOutputBuffer.Elements()),
|
||
|
reinterpret_cast<float*>(mOutputBuffer.Elements()),
|
||
|
mFFTSize / 2 + 1);
|
||
|
}
|
||
|
|
||
|
void SetFFTSize(uint32_t aSize)
|
||
|
{
|
||
|
mFFTSize = aSize;
|
||
|
mOutputBuffer.SetLength(aSize / 2 + 1);
|
||
|
PodZero(mOutputBuffer.Elements(), aSize / 2 + 1);
|
||
|
}
|
||
|
|
||
|
float FFTSize() const
|
||
|
{
|
||
|
return mFFTSize;
|
||
|
}
|
||
|
float RealData(uint32_t aIndex) const
|
||
|
{
|
||
|
return mOutputBuffer[aIndex].r;
|
||
|
}
|
||
|
float ImagData(uint32_t aIndex) const
|
||
|
{
|
||
|
return mOutputBuffer[aIndex].i;
|
||
|
}
|
||
|
|
||
|
private:
|
||
|
nsTArray<kiss_fft_cpx> mOutputBuffer;
|
||
|
uint32_t mFFTSize;
|
||
|
};
|
||
|
|
||
|
}
|
||
|
|
||
|
#endif
|
||
|
|