From 4f46ab9a9a04c0ff9ed67381d81400df11e8a15c Mon Sep 17 00:00:00 2001 From: ta264 Date: Fri, 4 Feb 2022 19:57:24 +0000 Subject: [PATCH] Speed up FuzzyContains a bit more --- .../Extensions/FuzzyContains.cs | 24 ++++++++++++------- 1 file changed, 16 insertions(+), 8 deletions(-) diff --git a/src/NzbDrone.Common/Extensions/FuzzyContains.cs b/src/NzbDrone.Common/Extensions/FuzzyContains.cs index 6a3bddec6..443184591 100644 --- a/src/NzbDrone.Common/Extensions/FuzzyContains.cs +++ b/src/NzbDrone.Common/Extensions/FuzzyContains.cs @@ -107,12 +107,24 @@ namespace NzbDrone.Common.Extensions var adjustForWordBoundary = wordDelimiters != null; + var start = 1; + var finish = text.Length + pattern.Length; + var charMatches = new T[finish]; + + for (var c = start; c <= finish; c++) + { + if (text.Length <= c - 1 || !s.TryGetValue(text[c - 1], out var mask)) + { + // Out of range. + mask = allOnes; + } + + charMatches[c - 1] = mask; + } + for (var d = 0; d < pattern.Length; d++) { // Scan for the best match; each iteration allows for one more error. - var start = 1; - var finish = text.Length + pattern.Length; - var rd = new T[finish + 2]; rd[finish + 1] = calculator.BitwiseComplement(calculator.Subtract(calculator.LeftShift(one, d), one)); @@ -124,11 +136,7 @@ namespace NzbDrone.Common.Extensions for (var j = finish; j >= start; j--) { - if (text.Length <= j - 1 || !s.TryGetValue(text[j - 1], out var charMatch)) - { - // Out of range. - charMatch = allOnes; - } + T charMatch = charMatches[j - 1]; if (d == 0) {