martini_rtin

Crates.iomartini_rtin
lib.rsmartini_rtin
version0.2.0
created_at2025-10-27 13:15:08.303084+00
updated_at2025-10-27 13:15:08.303084+00
descriptionA Rust implementation of the RTIN algorithm
homepagehttps://github.com/milkcask/martini_rtin
repositoryhttps://github.com/milkcask/martini_rtin
max_upload_size
id1902883
size19,174
milkcask (milkcask)

documentation

README

martini_rtin

A Rust port of the RTIN (Right-Triangulated Irregular Network) algorithm previously implemented as Mapbox's Awesome Right-Triangulated Irregular Networks, Improved (MARTINI).

It's an experimental library for real-time terrain mesh generation from height data. Given a (2k+1) × (2k+1) terrain grid, it generates a hierarchy of triangular meshes of varying level of detail in milliseconds. A work in progress.

Crates.io Documentation

Based on the paper "Right-Triangulated Irregular Networks" by Will Evans et. al. (1997) and inspired by Mapbox's Martini library.

MARTINI terrain demo

Features

  • Fast terrain mesh generation from height data
  • Configurable level of detail based on error tolerance
  • Memory-efficient hierarchical mesh representation
  • No unsafe code

Usage

Add this to your Cargo.toml:

[dependencies]
martini_rtin = "0.2.0"

Example

use martini_rtin::Martini;

// Create a mesh generator for a 257x257 grid (2^8 + 1)
let martini = Martini::with_capacity(257);

// Generate terrain data (flat array of height values)
let terrain: Vec<f32> = (0..257*257).map(|i| {
    let x = i % 257;
    let y = i / 257;
    // Simple sine wave terrain
    ((x as f32 * 0.1).sin() + (y as f32 * 0.1).sin()) * 10.0
}).collect();

// Create a tile from the terrain data
let tile = martini.create_tile(terrain);

// Generate a mesh with maximum error of 1.0
let (vertices, triangles) = tile.get_mesh(1.0);

println!("Generated {} vertices and {} triangles", 
         vertices.len(), triangles.len() / 3);

Algorithm

The RTIN algorithm works by:

  1. Building a hierarchy of right triangles from the terrain grid
  2. Computing approximation errors for each triangle level
  3. Generating meshes by recursively subdividing triangles that exceed the error threshold

This approach allows for efficient level-of-detail mesh generation suitable for real-time applications.

Grid Size Requirements

The grid size must be of the form 2^n + 1 (e.g., 3, 5, 9, 17, 33, 65, 129, 257, 513, 1025).

Performance

The algorithm is designed for real-time use and can generate meshes from large terrain grids in milliseconds.

License

ISC

Commit count: 0

cargo fmt