Spatial library for Rust
Switch branches/tags
Clone or download
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
benches impl Folder for references Dec 10, 2018
src remove unecessary feature Dec 14, 2018
.gitignore add incomplete octree implementation Sep 24, 2018
Cargo.toml expand impls of Folder over tuples of Folder Dec 10, 2018
LICENSE Initial commit Sep 23, 2018
README.md update readme with new info from #20 Nov 14, 2018

README.md

space

Crates.io MIT/Apache docs.rs LoC

A library that attempts to create good abstractions and implementations for common spatial data structures.

What it currently has

  • Morton encoding (z-order encoding) of 3d coordinates into and from u64 and u128
  • Octrees
    • Iteration
    • Gathering data from leaf nodes for internal nodes
      • Uses linear hashed octree LRU cache to speed up gathering.
      • Random sampling approach to gathering supported (e.g., run a barnes hut simulation, but limit a box's samples)
    • Performing a tree fold from the leaves to the root of the tree
    • Pointer based octrees
    • Linear hashed octrees

What it should have

  • Quering what is in a region (for colision detection)
    • This can be implemented in an abstract way currently using the explore parameter to gather operations, but it convenience wrappers need to be created to search over regions (possibly using combinator functions).
  • k-d trees
  • R trees
  • R* trees
  • M trees

What it shouldn't have

  • Specific file format loading
  • Physics (though it should provide enough abstractions to implement physics outside the library)

Contributing

  • I would love contributions to get this library to where it needs to be to support the point cloud, game, and physics developers in the community.
  • We need more benchmarks currently, and various levels of n-body simulation would probably be a good benchmark.
  • Also, see the above section What should it have.