[LIB]: Knuth-Morris-Pratt textsearch algorithm
authorThomas Graf <tgraf@suug.ch>
Fri, 24 Jun 2005 03:58:37 +0000 (20:58 -0700)
committerDavid S. Miller <davem@davemloft.net>
Fri, 24 Jun 2005 03:58:37 +0000 (20:58 -0700)
Implements a linear-time string-matching algorithm due to Knuth,
Morris, and Pratt [1]. Their algorithm avoids the explicit
computation of the transition function DELTA altogether. Its
matching time is O(n), for n being length(text), using just an
auxiliary function PI[1..m], for m being length(pattern),
precomputed from the pattern in time O(m). The array PI allows
the transition function DELTA to be computed efficiently
"on the fly" as needed. Roughly speaking, for any state
"q" = 0,1,...,m and any character "a" in SIGMA, the value
PI["q"] contains the information that is independent of "a" and
is needed to compute DELTA("q", "a") [2]. Since the array PI
has only m entries, whereas DELTA has O(m|SIGMA|) entries, we
save a factor of |SIGMA| in the preprocessing time by computing
PI rather than DELTA.

[1] Cormen, Leiserson, Rivest, Stein
    Introdcution to Algorithms, 2nd Edition, MIT Press
[2] See finite automation theory

Signed-off-by: Thomas Graf <tgraf@suug.ch>
Signed-off-by: David S. Miller <davem@davemloft.net>
lib/Kconfig
lib/Makefile
lib/ts_kmp.c [new file with mode: 0644]

index 5bc2d52..16b8fa2 100644 (file)
@@ -70,4 +70,14 @@ config TEXTSEARCH
          Say Y here if you want to provide a textsearch infrastructure
          to other subsystems.
 
+config TEXTSEARCH_KMP
+       depends on TEXTSEARCH
+       tristate "Knuth-Morris-Pratt"
+       help
+         Say Y here if you want to be able to search text using the
+         Knuth-Morris-Pratt textsearch algorithm.
+
+         To compile this code as a module, choose M here: the
+         module will be called ts_kmp.
+
 endmenu
index 3e91743..6cdb10f 100644 (file)
@@ -37,6 +37,7 @@ obj-$(CONFIG_ZLIB_DEFLATE) += zlib_deflate/
 obj-$(CONFIG_REED_SOLOMON) += reed_solomon/
 
 lib-$(CONFIG_TEXTSEARCH) += textsearch.o
+obj-$(CONFIG_TEXTSEARCH_KMP) += ts_kmp.o
 
 hostprogs-y    := gen_crc32table
 clean-files    := crc32table.h
diff --cc lib/ts_kmp.c
Simple merge