diff options
author | Jon Bratseth <bratseth@yahoo-inc.com> | 2016-06-15 23:09:44 +0200 |
---|---|---|
committer | Jon Bratseth <bratseth@yahoo-inc.com> | 2016-06-15 23:09:44 +0200 |
commit | 72231250ed81e10d66bfe70701e64fa5fe50f712 (patch) | |
tree | 2728bba1131a6f6e5bdf95afec7d7ff9358dac50 /searchlib/src/test/java/com/yahoo/searchlib/ranking/features/fieldmatch/reference/TextbookLevenshteinDistance.java |
Publish
Diffstat (limited to 'searchlib/src/test/java/com/yahoo/searchlib/ranking/features/fieldmatch/reference/TextbookLevenshteinDistance.java')
-rw-r--r-- | searchlib/src/test/java/com/yahoo/searchlib/ranking/features/fieldmatch/reference/TextbookLevenshteinDistance.java | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/searchlib/src/test/java/com/yahoo/searchlib/ranking/features/fieldmatch/reference/TextbookLevenshteinDistance.java b/searchlib/src/test/java/com/yahoo/searchlib/ranking/features/fieldmatch/reference/TextbookLevenshteinDistance.java new file mode 100644 index 00000000000..5ad3449a9d3 --- /dev/null +++ b/searchlib/src/test/java/com/yahoo/searchlib/ranking/features/fieldmatch/reference/TextbookLevenshteinDistance.java @@ -0,0 +1,38 @@ +// Copyright 2016 Yahoo Inc. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root. +package com.yahoo.searchlib.ranking.features.fieldmatch.reference; + +/** + * Textbook implementation from + * <a href="http://en.wikibooks.org/wiki/Algorithm_implementation/Strings/Levenshtein_distance#Java"> + * Wikipedia algorithms</a> + * Licensed under the Creative Commons Attribution-ShareAlike License + */ +public class TextbookLevenshteinDistance { + + private static int minimum(int a, int b, int c){ + if (a<=b && a<=c) + return a; + if (b<=a && b<=c) + return b; + return c; + } + + public static int computeLevenshteinDistance(char[] str1, char[] str2) { + int[][] distance = new int[str1.length+1][]; + + for(int i=0; i<=str1.length; i++){ + distance[i] = new int[str2.length+1]; + distance[i][0] = i; + } + for(int j=0; j<=str2.length; j++) + distance[0][j]=j; + + for(int i=1; i<=str1.length; i++) + for(int j=1;j<=str2.length; j++) + distance[i][j]= minimum(distance[i-1][j]+1, distance[i][j-1]+1, + distance[i-1][j-1]+((str1[i-1]==str2[j-1])?0:1)); + + return distance[str1.length][str2.length]; + } + +} |