#nearest-neighbor #knn #kdtree #data-structures #computer-vision

no-std nabo

A fast K Nearest Neighbor (KNN) library for low-dimensional spaces

6 releases (breaking)

0.5.0 Dec 20, 2024
0.4.0 Dec 20, 2024
0.3.0 Jun 28, 2023
0.2.1 Sep 13, 2021
0.1.0 Sep 3, 2021

#134 in Math

Download history 20/week @ 2024-09-30 37/week @ 2024-10-07 40/week @ 2024-10-14 20/week @ 2024-10-21 16/week @ 2024-10-28 10/week @ 2024-11-04 29/week @ 2024-11-11 57/week @ 2024-11-18 5/week @ 2024-11-25 46/week @ 2024-12-02 53/week @ 2024-12-09 316/week @ 2024-12-16 29/week @ 2024-12-23 33/week @ 2024-12-30 151/week @ 2025-01-06 130/week @ 2025-01-13

362 downloads per month
Used in nblast

MIT/Apache

50KB
963 lines

nabo

Crates.io Docs.rs Build Status

Overview

nabo is a fast K Nearest Neighbour (KNN) library for low-dimensional spaces. It is a re-implementation in pure Rust of the C++ library of the same name by its original author. This work has been sponsored by Enlightware GmbH.

nabo is no_std compatible.

Usage

To use nabo in your project, you need to either:

  • Use nabo::simple_point::SimplePoint as your point type.
  • Implement the nabo::Point trait for your own point type.

If you want to avoid a dependency to rand, disable the rand feature. In that case, the random generation of point clouds for SimplePoint will not be available.

Benchmark

You can benchmark nabo using the following command:

cargo bench

Citing nabo

If you use nabo in the academic context, please cite this paper that evaluates its performances in the context of robotics mapping research:

@article{elsebergcomparison,
	title={Comparison of nearest-neighbor-search strategies and implementations for efficient shape registration},
	author={Elseberg, J. and Magnenat, S. and Siegwart, R. and N{\"u}chter, A.},
	journal={Journal of Software Engineering for Robotics (JOSER)},
	pages={2--12},
	volume={3},
	number={1},
	year={2012},
	issn={2035-3928}
}

License

Licensed under either of

at your option.

Contribution

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

Dependencies

~1MB
~18K SLoC