You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
CrowdControl/Assets/BuildReport/Scripts/Editor/FuzzyString/LevenshteinDistance.cs

55 lines
1.9 KiB
C#

4 months ago
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace FuzzyString
{
public static partial class ComparisonMetrics
{
public static int LevenshteinDistance(this string source, string target)
{
if (source.Length == 0) { return target.Length; }
if (target.Length == 0) { return source.Length; }
int distance = 0;
if (source[source.Length - 1] == target[target.Length - 1]) { distance = 0; }
else { distance = 1; }
return Math.Min(Math.Min(LevenshteinDistance(source.Substring(0, source.Length - 1), target) + 1,
LevenshteinDistance(source, target.Substring(0, target.Length - 1))) + 1,
LevenshteinDistance(source.Substring(0, source.Length - 1), target.Substring(0, target.Length - 1)) + distance);
}
public static double NormalizedLevenshteinDistance(this string source, string target)
{
int unnormalizedLevenshteinDistance = source.LevenshteinDistance(target);
return unnormalizedLevenshteinDistance - source.LevenshteinDistanceLowerBounds(target);
}
public static int LevenshteinDistanceUpperBounds(this string source, string target)
{
// If the two strings are the same length then the Hamming Distance is the upper bounds of the Levenshtien Distance.
if (source.Length == target.Length) { return source.HammingDistance(target); }
// Otherwise, the upper bound is the length of the longer string.
else if (source.Length > target.Length) { return source.Length; }
else if (target.Length > source.Length) { return target.Length; }
return 9999;
}
public static int LevenshteinDistanceLowerBounds(this string source, string target)
{
// If the two strings are the same length then the lower bound is zero.
if (source.Length == target.Length) { return 0; }
// If the two strings are different lengths then the lower bounds is the difference in length.
else { return Math.Abs(source.Length - target.Length); }
}
}
}