diff options
author | Chris Robinson <[email protected]> | 2020-08-30 04:41:19 -0700 |
---|---|---|
committer | Chris Robinson <[email protected]> | 2020-08-30 04:41:19 -0700 |
commit | 88425becb2a68653466b43ac9f43b899a594998c (patch) | |
tree | 1d9a8612bead7b023f0ede04c5c0816511308d8e /alc/effects/convolution.cpp | |
parent | 82873486b7227c628fe4860e90700216bb909114 (diff) |
Remove a couple unnecessary pointers
Diffstat (limited to 'alc/effects/convolution.cpp')
-rw-r--r-- | alc/effects/convolution.cpp | 23 |
1 files changed, 8 insertions, 15 deletions
diff --git a/alc/effects/convolution.cpp b/alc/effects/convolution.cpp index 9924bc81..42c180d8 100644 --- a/alc/effects/convolution.cpp +++ b/alc/effects/convolution.cpp @@ -101,16 +101,14 @@ constexpr size_t ConvolveUpdateSamples{ConvolveUpdateSize / 2}; struct ConvolutionFilter final : public EffectBufferBase { - size_t mCurrentSegment{0}; - size_t mNumConvolveSegs{0}; - complex_d *mInputHistory{}; - complex_d *mConvolveFilter[MAX_FILTER_CHANNELS]{}; - FmtChannels mChannels{}; AmbiLayout mAmbiLayout{}; AmbiScaling mAmbiScaling{}; ALuint mAmbiOrder{}; + size_t mCurrentSegment{0}; + size_t mNumConvolveSegs{0}; + struct ChannelData { alignas(16) FloatBufferLine mBuffer{}; float mHfScale{}; @@ -227,11 +225,6 @@ EffectBufferBase *ConvolutionState::createBuffer(const ALCdevice *device, filter->mComplexData = std::make_unique<complex_d[]>(complex_length); std::fill_n(filter->mComplexData.get(), complex_length, complex_d{}); - filter->mInputHistory = filter->mComplexData.get(); - filter->mConvolveFilter[0] = filter->mInputHistory + filter->mNumConvolveSegs*m; - for(size_t c{1};c < numChannels;++c) - filter->mConvolveFilter[c] = filter->mConvolveFilter[c-1] + filter->mNumConvolveSegs*m; - filter->mChannels = buffer.mChannels; filter->mAmbiLayout = buffer.mAmbiLayout; filter->mAmbiScaling = buffer.mAmbiScaling; @@ -239,6 +232,7 @@ EffectBufferBase *ConvolutionState::createBuffer(const ALCdevice *device, auto fftbuffer = std::make_unique<std::array<complex_d,ConvolveUpdateSize>>(); auto srcsamples = std::make_unique<double[]>(maxz(buffer.mSampleLen, resampledCount)); + complex_d *filteriter = filter->mComplexData.get() + filter->mNumConvolveSegs*m; for(size_t c{0};c < numChannels;++c) { /* Load the samples from the buffer, and resample to match the device. */ @@ -249,7 +243,6 @@ EffectBufferBase *ConvolutionState::createBuffer(const ALCdevice *device, srcsamples.get()); size_t done{0}; - complex_d *filteriter = filter->mConvolveFilter[c]; for(size_t s{0};s < filter->mNumConvolveSegs;++s) { const size_t todo{minz(resampledCount-done, ConvolveUpdateSamples)}; @@ -377,22 +370,22 @@ void ConvolutionState::process(const size_t samplesToDo, */ complex_fft(mFftBuffer, -1.0); - std::copy_n(mFftBuffer.begin(), m, &mFilter->mInputHistory[curseg*m]); + std::copy_n(mFftBuffer.begin(), m, &mFilter->mComplexData[curseg*m]); mFftBuffer.fill(complex_d{}); + const complex_d *RESTRICT filter{mFilter->mComplexData.get() + mFilter->mNumConvolveSegs*m}; for(size_t c{0};c < chans.size();++c) { /* Convolve each input segment with its IR filter counterpart * (aligned in time). */ - const complex_d *RESTRICT filter{mFilter->mConvolveFilter[c]}; - const complex_d *RESTRICT input{&mFilter->mInputHistory[curseg*m]}; + const complex_d *RESTRICT input{&mFilter->mComplexData[curseg*m]}; for(size_t s{curseg};s < mFilter->mNumConvolveSegs;++s) { for(size_t i{0};i < m;++i,++input,++filter) mFftBuffer[i] += *input * *filter; } - input = mFilter->mInputHistory; + input = mFilter->mComplexData.get(); for(size_t s{0};s < curseg;++s) { for(size_t i{0};i < m;++i,++input,++filter) |