blob: 37b9d6a5add8a16d96772b686ede5062f54c97d2 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
struct RayBounds {
t_entry: f32,
t_exit: f32,
hit: bool,
};
fn ray_box_intersection(ro: vec3f, rd: vec3f, extent: vec3f) -> RayBounds {
let inv_rd = 1.0 / rd;
let t0 = (-extent - ro) * inv_rd;
let t1 = (extent - ro) * inv_rd;
let tmin_vec = min(t0, t1);
let tmax_vec = max(t0, t1);
let t_entry = max(0.0, max(tmin_vec.x, max(tmin_vec.y, tmin_vec.z)));
let t_exit = min(tmax_vec.x, min(tmax_vec.y, tmax_vec.z));
return RayBounds(t_entry, t_exit, t_entry <= t_exit);
}
|