Upgrade dependent version: github.com/open-policy-agent/opa v0.18.0 -> v0.45.0 Signed-off-by: hongzhouzi <hongzhouzi@kubesphere.io> Signed-off-by: hongzhouzi <hongzhouzi@kubesphere.io>
58 lines
1.7 KiB
Markdown
58 lines
1.7 KiB
Markdown
levenshtein [](https://travis-ci.org/agnivade/levenshtein) [](https://goreportcard.com/report/github.com/agnivade/levenshtein) [](https://godoc.org/github.com/agnivade/levenshtein)
|
|
===========
|
|
|
|
[Go](http://golang.org) package to calculate the [Levenshtein Distance](http://en.wikipedia.org/wiki/Levenshtein_distance)
|
|
|
|
The library is fully capable of working with non-ascii strings. But the strings are not normalized. That is left as a user-dependant use case. Please normalize the strings before passing it to the library if you have such a requirement.
|
|
- https://blog.golang.org/normalization
|
|
|
|
Install
|
|
-------
|
|
|
|
go get github.com/agnivade/levenshtein
|
|
|
|
Example
|
|
-------
|
|
|
|
```go
|
|
package main
|
|
|
|
import (
|
|
"fmt"
|
|
"github.com/agnivade/levenshtein"
|
|
)
|
|
|
|
func main() {
|
|
s1 := "kitten"
|
|
s2 := "sitting"
|
|
distance := levenshtein.ComputeDistance(s1, s2)
|
|
fmt.Printf("The distance between %s and %s is %d.\n", s1, s2, distance)
|
|
// Output:
|
|
// The distance between kitten and sitting is 3.
|
|
}
|
|
|
|
```
|
|
|
|
Benchmarks
|
|
----------
|
|
|
|
```
|
|
name time/op
|
|
Simple/ASCII-4 537ns ± 2%
|
|
Simple/French-4 956ns ± 0%
|
|
Simple/Nordic-4 1.95µs ± 1%
|
|
Simple/Tibetan-4 1.53µs ± 2%
|
|
|
|
name alloc/op
|
|
Simple/ASCII-4 96.0B ± 0%
|
|
Simple/French-4 128B ± 0%
|
|
Simple/Nordic-4 192B ± 0%
|
|
Simple/Tibetan-4 144B ± 0%
|
|
|
|
name allocs/op
|
|
Simple/ASCII-4 1.00 ± 0%
|
|
Simple/French-4 1.00 ± 0%
|
|
Simple/Nordic-4 1.00 ± 0%
|
|
Simple/Tibetan-4 1.00 ± 0%
|
|
```
|