Skip to content

Fast 2D Delaunay triangulation in Rust. A port of Delaunator.

License

Notifications You must be signed in to change notification settings

andreesteve/delaunator-rs

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

24 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

delaunator-rs

A very fast static 2D Delaunay triangulation library for Rust. A port of Delaunator.

delaunator on Crates.io Build Status

Example

use delaunator::{Point, triangulate};

let points = vec![
    Point { x: 0., y: 0. },
    Point { x: 1., y: 0. },
    Point { x: 1., y: 1. },
    Point { x: 0., y: 1. },
];

let result = triangulate(&points).expect("No triangulation exists.");

println!("{:?}", result.triangles); // [0, 2, 1, 0, 3, 2]

Performance

Results for 3.1 GHz Intel Core i7 on a Macbook Pro 15'' (2017):

points time
100 16.478µs
1,000 277.64µs
10,000 3.753ms
100,000 63.627ms
1,000,000 898.78ms
10,000,000 11.857s

About

Fast 2D Delaunay triangulation in Rust. A port of Delaunator.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Rust 100.0%