#search #text #double-array #trie

no-std crawdad

Crawdad: ChaRActer-Wise Double-Array Dictionary

6 releases (3 breaking)

Uses new Rust 2021

0.4.0 Sep 2, 2022
0.3.0 Aug 1, 2022
0.2.1 Jun 4, 2022
0.2.0 Apr 23, 2022
0.1.1 Apr 13, 2022

#381 in Text processing

Download history 46/week @ 2022-10-08 157/week @ 2022-10-15 77/week @ 2022-10-22 69/week @ 2022-10-29 23/week @ 2022-11-05 75/week @ 2022-11-12 39/week @ 2022-11-19 49/week @ 2022-11-26 49/week @ 2022-12-03 539/week @ 2022-12-10 46/week @ 2022-12-17 30/week @ 2022-12-24 32/week @ 2022-12-31 105/week @ 2023-01-07 173/week @ 2023-01-14 75/week @ 2023-01-21

389 downloads per month
Used in 2 crates (via vibrato)

MIT/Apache

58KB
1.5K SLoC

🦞 Crawdad: ChaRActer-Wise Double-Array Dictionary

Crates.io Documentation Build Status

Overview

Crawdad is a library of natural language dictionaries using character-wise double-array tries. The implementation is optimized for strings of multibyte-characters, and you can enjoy fast text processing on strings such as Japanese or Chinese.

For example, on a large Japanese dictionary of IPADIC+Neologd, Crawdad has a better time-space tradeoff than other Rust libraries.

The detailed experimental settings and other results are available on Wiki.

What can do

  • Key-value mapping: Crawdad stores a set of string keys with mapping arbitrary integer values.
  • Exact match: Crawdad supports a fast lookup for an input key.
  • Common prefix search: Crawdad supports fast common prefix search that can be used to enumerate all keys appearing in a text.

Data structures

Crawdad contains the two trie implementations:

  • crawdad::Trie is a standard trie form that often provides the fastest queries.
  • crawdad::MpTrie is a minimal-prefix trie form that is memory-efficient for long strings.

License

Licensed under either of

at your option.

For softwares under bench/data, follow the license terms of each software.

Acknowledgment

The initial version of this software was developed by LegalForce, Inc., but not an officially supported LegalForce product.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

No runtime deps

Features

  • alloc