commit | c03a9d0c7c6757b63b9c1ff2690e8b156cffe575 | [log] [tgz] |
---|---|---|
author | James Farrell <[email protected]> | Wed May 22 23:45:07 2024 +0000 |
committer | Automerger Merge Worker <[email protected]> | Wed May 22 23:45:07 2024 +0000 |
tree | 1e2135474e248c29cdec7f7b9819ce719e7ef652 | |
parent | 0f701232b9d0277bcbbc2f64a76b710d63f386dc [diff] | |
parent | 2ca42d9ea4b80affb7fb5671b63889a814492d78 [diff] |
Update Android.bp by running cargo_embargo am: 4fef949c73 am: 2ca42d9ea4 Original change: https://android-review.googlesource.com/c/platform/external/rust/crates/strsim/+/3096364 Change-Id: Iec6acce5554902981f90dca9f23f60ec3fc9aba3 Signed-off-by: Automerger Merge Worker <[email protected]>
Rust implementations of string similarity metrics:
The normalized versions return values between 0.0
and 1.0
, where 1.0
means an exact match.
There are also generic versions of the functions for non-string inputs.
strsim
is available on crates.io. Add it to your project:
cargo add strsim
Go to Docs.rs for the full documentation. You can also clone the repo, and run $ cargo doc --open
.
extern crate strsim; use strsim::{hamming, levenshtein, normalized_levenshtein, osa_distance, damerau_levenshtein, normalized_damerau_levenshtein, jaro, jaro_winkler, sorensen_dice}; fn main() { match hamming("hamming", "hammers") { Ok(distance) => assert_eq!(3, distance), Err(why) => panic!("{:?}", why) } assert_eq!(levenshtein("kitten", "sitting"), 3); assert!((normalized_levenshtein("kitten", "sitting") - 0.571).abs() < 0.001); assert_eq!(osa_distance("ac", "cba"), 3); assert_eq!(damerau_levenshtein("ac", "cba"), 2); assert!((normalized_damerau_levenshtein("levenshtein", "löwenbräu") - 0.272).abs() < 0.001); assert!((jaro("Friedrich Nietzsche", "Jean-Paul Sartre") - 0.392).abs() < 0.001); assert!((jaro_winkler("cheeseburger", "cheese fries") - 0.911).abs() < 0.001); assert_eq!(sorensen_dice("web applications", "applications of the web"), 0.7878787878787878); }
Using the generic versions of the functions:
extern crate strsim; use strsim::generic_levenshtein; fn main() { assert_eq!(2, generic_levenshtein(&[1, 2, 3], &[0, 2, 5])); }
If you don't want to install Rust itself, you can run $ ./dev
for a development CLI if you have Docker installed.
Benchmarks require a Nightly toolchain. Run $ cargo +nightly bench
.