From 6e16a66a1b1c562d8613856bdd8367b8b2b493ca Mon Sep 17 00:00:00 2001 From: Paul Walker Date: Mon, 3 May 2021 14:01:59 -0400 Subject: [PATCH] Fix an Lanczos Index edge Case Closes #4465 --- src/common/dsp/LanczosResampler.cpp | 4 ++-- src/common/dsp/LanczosResampler.h | 11 ++++++++--- 2 files changed, 10 insertions(+), 5 deletions(-) diff --git a/src/common/dsp/LanczosResampler.cpp b/src/common/dsp/LanczosResampler.cpp index 492f5c69547..9a02751cc77 100644 --- a/src/common/dsp/LanczosResampler.cpp +++ b/src/common/dsp/LanczosResampler.cpp @@ -16,9 +16,9 @@ #include "LanczosResampler.h" float LanczosResampler::lanczosTable alignas( - 16)[LanczosResampler::tableObs][LanczosResampler::filterWidth]; + 16)[LanczosResampler::tableObs + 1][LanczosResampler::filterWidth]; float LanczosResampler::lanczosTableDX alignas( - 16)[LanczosResampler::tableObs][LanczosResampler::filterWidth]; + 16)[LanczosResampler::tableObs + 1][LanczosResampler::filterWidth]; bool LanczosResampler::tablesInitialized = false; diff --git a/src/common/dsp/LanczosResampler.h b/src/common/dsp/LanczosResampler.h index cf19017d4c0..fc2a889d441 100644 --- a/src/common/dsp/LanczosResampler.h +++ b/src/common/dsp/LanczosResampler.h @@ -37,8 +37,8 @@ struct LanczosResampler static constexpr double dx = 1.0 / (tableObs); // Fixme: Make this static and shared - static float lanczosTable alignas(16)[tableObs][filterWidth], lanczosTableDX - alignas(16)[tableObs][filterWidth]; + static float lanczosTable alignas(16)[tableObs + 1][filterWidth], lanczosTableDX + alignas(16)[tableObs + 1][filterWidth]; static bool tablesInitialized; // This is a stereo resampler @@ -65,7 +65,7 @@ struct LanczosResampler memset(input, 0, 2 * BUFFER_SZ * sizeof(float)); if (!tablesInitialized) { - for (int t = 0; t < tableObs; ++t) + for (int t = 0; t < tableObs + 1; ++t) { double x0 = dx * t; for (int i = 0; i < filterWidth; ++i) @@ -82,6 +82,11 @@ struct LanczosResampler lanczosTable[(t + 1) & (tableObs - 1)][i] - lanczosTable[t][i]; } } + for (int i = 0; i < filterWidth; ++i) + { + // Wrap at the end - deriv is the same + lanczosTableDX[tableObs][i] = lanczosTable[0][i]; + } tablesInitialized = true; } }