3 releases

0.1.0-beta.2 Jan 3, 2025
0.1.0-beta.1 Dec 20, 2024
0.1.0-beta.0 Dec 15, 2024

#133 in Graphics APIs

Download history 101/week @ 2024-12-11 139/week @ 2024-12-18 4/week @ 2024-12-25 113/week @ 2025-01-01 14/week @ 2025-01-08

276 downloads per month

MIT license

60KB
353 lines

tinybvh-rs

Rust wrapper for tinybvh.

Features

Provides BVH (Bounding Volume Hierarchy) construction and intersection:

  • Construction: [BVH], BVH4, CWBVH
  • Intersection

For more information about each layout: tinybvh.

Examples

BVH Wald

use tinybvh_rs::{Intersector, Ray};

let primitives = vec![
    [-2.0, 1.0, -1.0, 0.0],    //
    [-1.0, 1.0, -1.0, 0.0],    // Left triangle
    [-2.0, 0.0, -1.0, 0.0],    //

    [2.0, 1.0, -1.0, 0.0],     //
    [2.0, 0.0, -1.0, 0.0],     // Right triangle
    [1.0, 0.0, -1.0, 0.0],     //
];

let bvh = wald::BVH::new(&primitives);

// No intersection, ray pass between the primitives
let mut ray = Ray::new([0.0, 0.0, 0.0], [0.0, 0.0, -1.0]);
bvh.intersect(&mut ray);
println!("Hit distance: {}", ray.hit.t); // 1e30

// Intersects left primitive
let mut ray = Ray::new([-1.5, 0.5, 0.0], [0.0, 0.0, -1.0]);
bvh.intersect(&mut ray);
println!("Hit distance & primtive: {} / {}", ray.hit.t, ray.hit.prim); // 1.0 / 0

// Intersects right primitive
let mut ray = Ray::new([1.5, 0.45, 0.0], [0.0, 0.0, -1.0]);
bvh.intersect(&mut ray);
println!("Hit distance & primtive: {} / {}", ray.hit.t, ray.hit.prim); // 1.0 / 1

Strided

If the vertices position are strided (located in a Vertex struct for instance), you can enable the strided feature and use:

use tinybvh_rs::{Intersector, Ray};

#[repr(C)]
#[derive(Clone, Copy, bytemuck::Pod, bytemuck::Zeroable)]
struct Vertex {
    position: [f32; 4],
    normal: [f32; 3],
}

let vertices = [
    Vertex {
        position: [-1.0, 1.0, -1.0, 0.0],
        normal: [0.0, 0.0, 1.0]
    },
    Vertex {
        position: [-0.5, 1.0, -1.0, 0.0],
        normal: [0.0, 0.0, 1.0]
    },
    Vertex {
        position: [-1.0, 0.0, -1.0, 0.0],
        normal: [0.0, 0.0, 1.0]
    },
];
let positions = pas::slice_attr!(vertices, [0].position);
let bvh = wald::BVH::new_strided(&positions);

Dependencies

~0.7–2.3MB
~37K SLoC