plane-2d

Crates.ioplane-2d
lib.rsplane-2d
version0.1.8
sourcesrc
created_at2024-06-10 11:41:10.829204
updated_at2024-10-07 12:55:51.390558
descriptionContinuous 2D data structure representing infinite 2d plane.
homepage
repositoryhttps://github.com/vil-mo/plane-2d
max_upload_size
id1266970
size153,345
vil'mo (vil-mo)

documentation

https://docs.rs/plane-2d

README

Two Dimensional Plane

Models continuous, infinitely big (within integer and storage limits) 2D data structure. The purpose of this crate is to provide a data structure that is faster than a HashMap<(i32, i32), T> in specific scenarios and provides better API for working with 2D plane.

This crate will always provide a 2D data structure. The Plane<T> type is a container for all kinds of data that implement Default trait. You can use Option<T> to store optionally initialized data.

No other dependencies except for the std lib are used, besides dependencies hidden behind feature flags.

Memory layout

Uses almost exact copy of grid crate to use Grid<T> type. Stores a dense chunk of the plane in Vec<T> (Grid<T>, provided by copy of the grid crate) and HashMap<(i32, i32), T> to store cells that are out of bounds of the Grid<T>. Unlike HashMap<(i32, i32), T>, two allocations are being done.

Commit count: 15

cargo fmt