Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/theodesp/go-tries
Go tries implements several types of Trie data structures for experimental use.
https://github.com/theodesp/go-tries
data-structures golang trie
Last synced: about 1 month ago
JSON representation
Go tries implements several types of Trie data structures for experimental use.
- Host: GitHub
- URL: https://github.com/theodesp/go-tries
- Owner: theodesp
- License: mit
- Created: 2017-11-29T16:50:43.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2017-12-06T11:18:25.000Z (about 7 years ago)
- Last Synced: 2024-10-19T07:37:27.259Z (3 months ago)
- Topics: data-structures, golang, trie
- Language: Go
- Size: 26.4 KB
- Stars: 2
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Go Tries
Go tries implements several types of Tries for experimental use.
The implementations are optimized for Get performance and to allocate
0 bytes of heap memory (i.e. garbage) per Get.A typical use case is to perform Puts and Deletes upfront to populate the Trie,
then perform Gets very quickly.When Tries are chosen over maps, it is typically for their space efficiency.
Trie Types
---**SimpleTrie**: A simple implementation using a map of TrieNodes.
```go
t := NewSimpleTrie()
t.Add("cat", 0)
t.Add("fox", 1)
t.Add("dog", 2)
t.Add("dog and", 3)
t.Add("dog and cat", 4)t.Get("Cat") // nil
t.Get("cat") // cat
```* It has a bigger memory footprint.
* It is fast for finding not existing keys.
* It gets slower as the keys become complicated with lots of spaces between as the algorithm will split the words first.
* Put operations are heavier.**DoubleArrayTrie**: A more complex implementation of a Trie using 2 Lists.
This is supposed to have better search performance in expense of slower insertions.
Based on the [Sato and Morimoto paper](http://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.14.8665&rep=rep1&type=pdf)* It has a smaller memory footprint. Only 3 slices that resize when necessary.
* It is fast for finding keys
* It does not get substantially slower when the keys become complicated with lots of spaces between,
as the algorithm has a good amortized cost over the `Get` operations.
The heaviest operation is `ReadTail` which just tries to concat slices.Benchmarks
---
**Single threaded benchmarks**: Simple Trie.
```bash
BenchmarkSimpleTriePutStringKey-4 50000000 35.6 ns/op 8 B/op 1 allocs/op
BenchmarkSimpleTrieGetStringKey-4 100000000 16.0 ns/op 0 B/op 0 allocs/op
BenchmarkSimpleTriePutPhraseKey-4 20000000 69.5 ns/op 8 B/op 1 allocs/op
BenchmarkSimpleTrieGetPhraseKey-4 30000000 42.1 ns/op 0 B/op 0 allocs/op
```Single threaded benchmarks: Double Array Trie
```bash
BenchmarkDoubleArrayTrieGetSimpleStringKey-4 50000000 26.7 ns/op 0 B/op 0 allocs/op
```License
---MIT License