#hilbert-curve #curve #hilbert #fractal

hilbert_2d

Functions for mapping between 1D and 2D space using the Hilbert curve, and its approximations

2 stable releases

1.1.0 Jan 6, 2023
1.0.0 Sep 1, 2020

#517 in Math

Download history 533/week @ 2024-11-21 469/week @ 2024-11-28 739/week @ 2024-12-05 403/week @ 2024-12-12 362/week @ 2024-12-19 241/week @ 2024-12-26 458/week @ 2025-01-02 608/week @ 2025-01-09 381/week @ 2025-01-16 744/week @ 2025-01-23 616/week @ 2025-01-30 963/week @ 2025-02-06 715/week @ 2025-02-13 749/week @ 2025-02-20 531/week @ 2025-02-27 558/week @ 2025-03-06

2,731 downloads per month
Used in 10 crates (6 directly)

MIT/Apache

105KB
555 lines

Hilbert 2D

Latest Version API Documentation rustc 1.46+

Rust functions for mapping between 1D and 2D space using the Hilbert curve, and its approximations.

Examples

Usage

Add this to your Cargo.toml:

[dependencies]
hilbert_2d = "1.1.0"

When working with images and matrices, use the h2xy_discrete and xy2h_discrete functions:

use hilbert_2d::{h2xy_discrete, xy2h_discrete, Variant};

let (x, y) = h2xy_discrete(7, 2, Variant::Hilbert); // (1, 2)
let h = xy2h_discrete(2, 1, 2, Variant::Hilbert); // 13

When performing real-valued calculations, use the continuous functions instead:

use hilbert_2d::{h2xy_continuous_f64, Variant};

// Approaches the bottom-left corner
let (x1, y1) = h2xy_continuous_f64(0.0, Variant::Hilbert); 
// Approaches the bottom-right corner
let (x2, y2) = h2xy_continuous_f64(1.0, Variant::Hilbert); 

Some of the pattern variants of the Hilbert curve have also been implemented:

use hilbert_2d::{h2xy_continuous_f64, Variant};

// In the Liu L1 variant, both ends of the curve approach the center of the square
let (x1, y1) = h2xy_continuous_f64(0.0, Variant::Liu1); // (~0.5, ~0.5)
let (x2, y2) = h2xy_continuous_f64(1.0, Variant::Liu1); // (~0.5, ~0.5)

License

Licensed under either of

at your option.

Contribution

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

No runtime deps