Crates.io | qhull |
lib.rs | qhull |
version | 0.3.1 |
source | src |
created_at | 2024-02-07 11:35:40.456741 |
updated_at | 2024-02-09 16:50:50.891468 |
description | Rust bindings to Qhull |
homepage | |
repository | https://github.com/LucaCiucci/qhull-rs |
max_upload_size | |
id | 1130415 |
size | 89,761 |
Safe Rust Qhull bindings
Qhull computes the convex hull, Delaunay triangulation, Voronoi diagram, halfspace intersection about a point, furthest-site Delaunay triangulation, and furthest-site Voronoi diagram. The source code runs in 2-d, 3-d, 4-d, and higher dimensions. Qhull implements the Quickhull algorithm for computing the convex hull. It handles roundoff errors from floating point arithmetic. It computes volumes, surface areas, and approximations to the convex hull.
Qhull does not support triangulation of non-convex surfaces, mesh generation of non-convex objects, medium-sized inputs in 9-D and higher, alpha shapes, weighted Voronoi diagrams, Voronoi volumes, or constrained Delaunay triangulations.
- Qhull main page (retrieved 2024-09-02)
cargo run --example hull
qhull-rs
provides some binary targets from the original Qhull source code:
qconvex
qdelaunay
qhalf
qhull
qvoronoi
rbox
To get them:
cargo install qhull
qhull
Add this to your Cargo.toml
:
qhull = "0.3"
For the current development version:
[dependencies]
qhull = { git = "https://github.com/LucaCiucci/qhull-rs" }
A 2D convex hull:
use qhull::Qh;
let qh = Qh::builder()
.compute(true)
.build_from_iter([
[0.0, 0.0],
[1.0, 0.0],
[0.0, 1.0],
[0.25, 0.25],
]).unwrap();
for simplex in qh.simplices() {
let vertices = simplex
.vertices().unwrap()
.iter()
.map(|v| v.id())
.collect::<Vec<_>>();
println!("{:?}", vertices);
}
See the [examples
] module/folder for more examples.
This crate uses Qhull, please refer to the Qhull license for more information when using this crate.