blob: a2545268b18d58128a96e9c1e7be76c5e8728c12 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
`acap`
======
[data:image/s3,"s3://crabby-images/6e9a5/6e9a508dfff286faf9309d572c01b18ff8945cfb" alt="crates.io"](https://crates.io/crates/acap)
[data:image/s3,"s3://crabby-images/027b4/027b4c90720ee8f58af021902bba51ac2f1547aa" alt="Documentation"](https://docs.rs/acap)
[data:image/s3,"s3://crabby-images/cd905/cd905e0a2ca7bdcc1e24610cd29a025951ccf9ef" alt="License"](https://github.com/tavianator/knn/blob/main/LICENSE)
[data:image/s3,"s3://crabby-images/c5ef9/c5ef90840b4f543a4fb945a209890db7c83c9387" alt="CI Status"](https://github.com/tavianator/acap/actions/workflows/ci.yml)
As Close As Possible — [nearest neighbor search] in Rust.
[nearest neighbor search]: https://en.wikipedia.org/wiki/Nearest_neighbor_search
Example
-------
```rust
use acap::euclid::Euclidean;
use acap::vp::VpTree;
use acap::NearestNeighbors;
let tree = VpTree::balanced(vec![
Euclidean([3, 4]),
Euclidean([5, 12]),
Euclidean([8, 15]),
Euclidean([7, 24]),
]);
let nearest = tree.nearest(&[7, 7]).unwrap();
assert_eq!(nearest.item, &Euclidean([3, 4]));
assert_eq!(nearest.distance, 5);
```
|